Skip to content

Commit

Permalink
Add debug logs
Browse files Browse the repository at this point in the history
  • Loading branch information
carlcsaposs-canonical committed Apr 12, 2024
1 parent 521e339 commit 4e4193f
Showing 1 changed file with 21 additions and 0 deletions.
21 changes: 21 additions & 0 deletions lib/charms/opensearch/v0/opensearch_locking.py
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@ def request_lock(self):
return
self._relation.data[self._charm.unit]["lock-requested"] = json.dumps(True)
if self._charm.unit.is_leader():
logger.debug("[Node lock] Requested peer lock as leader unit")
# A separate relation-changed event won't get fired
self._on_peer_relation_changed()

Expand All @@ -65,6 +66,7 @@ def release_lock(self):
return
self._relation.data[self._charm.unit].pop("lock-requested", None)
if self._charm.unit.is_leader():
logger.debug("[Node lock] Released peer lock as leader unit")
# A separate relation-changed event won't get fired
self._on_peer_relation_changed()

Expand Down Expand Up @@ -109,13 +111,16 @@ def _on_peer_relation_changed(self, _=None):
self._charm.model.get_unit(self._unit_with_lock)
):
# Lock still in use, do not release
logger.debug("[Node lock] (leader) lock still in use")
return
# TODO: adjust which unit gets priority on lock?
for unit in (*self._relation.units, self._charm.unit):
if self._unit_requested_lock(unit):
self._unit_with_lock = unit.name
logger.debug(f"[Node lock] (leader) granted peer lock to {unit.name=}")
break
else:
logger.debug("[Node lock] (leader) cleared peer lock")
del self._unit_with_lock


Expand Down Expand Up @@ -158,14 +163,17 @@ def acquired(self) -> bool: # noqa: C901
Whether lock was acquired
"""
# In peer databag, check if lock acquired by another unit
logger.debug(f"[Node lock] {self._peer.state=}")
if self._peer.state is _PeerLockState.ACQUIRED_BY_ANOTHER_UNIT:
logger.debug("[Node lock] Not acquired: another unit has peer lock")
return False

if self._opensearch.is_node_up():
host = self._charm.unit_ip
else:
host = None
if host or self._charm.alt_hosts:
logger.debug("[Node lock] Using opensearch for lock")
# Acquire opensearch lock
# Create index if it doesn't exist
try:
Expand Down Expand Up @@ -206,19 +214,26 @@ def acquired(self) -> bool: # noqa: C901
# Another unit has lock
# (Or document deleted after last request & before request in
# `self._lock_acquired()`)
logger.debug("[Node lock] Not acquired: another unit has opensearch lock")
return False
else:
raise
# Lock acquired
# Release peer databag lock, if any
logger.debug("[Node lock] Acquired via opensearch")
self._peer.release_lock()
logger.debug("[Node lock] Released redundant peer lock (if held)")
return True
else:
logger.debug("[Node lock] Using peer databag for lock")
# Request peer databag lock
self._peer.request_lock()
# If expression is True:
# - Lock granted in previous Juju event
# - OR, unit is leader & lock granted in this Juju event
logger.debug(
f"[Node lock] Attempted to acquire peer lock. Result: {self._peer.state=}"
)
return self._peer.state is _PeerLockState.ACQUIRED_BY_THIS_UNIT

def release(self):
Expand All @@ -227,13 +242,16 @@ def release(self):
Limitation: if lock acquired via OpenSearch document and all units offline, OpenSearch
document lock will not be released
"""
logger.debug("[Node lock] Releasing lock")
if self._opensearch.is_node_up():
host = self._charm.unit_ip
else:
host = None
if host or self._charm.alt_hosts:
logger.debug("[Node lock] Checking which unit has opensearch lock")
# Check if this unit currently has lock
if self._lock_acquired(host):
logger.debug("[Node lock] Releasing opensearch lock")
# Delete document id 0
try:
self._opensearch.request(
Expand All @@ -246,4 +264,7 @@ def release(self):
except OpenSearchHttpError as e:
if e.response_code != 404:
raise
logger.debug("[Node lock] Released opensearch lock")
self._peer.release_lock()
logger.debug("[Node lock] Released peer lock (if held)")
logger.debug("[Node lock] Released lock")

0 comments on commit 4e4193f

Please sign in to comment.