1
0
Fork 0
tractor/tractor
Tyler Goodlet d83d991f21 Handle stale registrar entries; detect and delete
In cases where an actor's transport server task (by default handling new
TCP connections) terminates early but does not de-register from the
pertaining registry (aka the registrar) actor's address table, the
trying-to-connect client actor will get a connection error on that
address. In the case where client handles a (local) `OSError` (meaning
the target actor address is likely being contacted over `localhost`)
exception, make a further call to the registrar to delete the stale
entry and `yield None` gracefully indicating to calling code that no
`Portal` can be delivered to the target address.

This issue was originally discovered in `piker` where the `emsd`
(clearing engine) actor would sometimes crash on rapid client
re-connects and then leave a `pikerd` stale entry. With this fix new
clients will attempt connect via an endpoint which will re-spawn the
`emsd` when a `None` portal is delivered (via `maybe_spawn_em()`).
2023-08-28 11:26:36 -04:00
..
experimental Move move context code into new `._context` mod 2023-05-15 10:00:45 -04:00
trionics Tidy up `typing` imports in broadcaster mod 2023-06-14 15:31:52 -04:00
__init__.py Handle stale registrar entries; detect and delete 2023-08-28 11:26:36 -04:00
_child.py Rename our core module to `_runtime` 2022-09-15 23:41:28 -04:00
_clustering.py Passthrough runtime kwargs from `open_actor_cluster()` 2022-12-11 19:56:08 -05:00
_context.py Remote cancellation runtime-internal vars renames 2023-05-19 14:31:55 -04:00
_debug.py Fix frame-selection display on first REPL entry 2023-07-07 14:51:44 -04:00
_discovery.py Handle stale registrar entries; detect and delete 2023-08-28 11:26:36 -04:00
_entry.py Change a bunch of log levels to cancel, including any `ContextCancelled` handling 2023-05-15 10:00:45 -04:00
_exceptions.py Only tuplize `.canceller` if non-`None` 2023-05-15 10:00:45 -04:00
_forkserver_override.py Re-license code base for distribution under AGPL 2021-12-14 23:33:27 -05:00
_ipc.py Adjust all default is `None` annots (per new `mypy`) 2022-12-12 13:18:22 -05:00
_mp_fixup_main.py Avoid importing mp for as long as possible 2022-02-17 11:55:26 -05:00
_portal.py Expose `allow_overruns` to `Portal.open_context()` 2023-05-15 10:00:45 -04:00
_root.py Map `breakpoint()` built-in to new `.pause_from_sync()` ep 2023-07-07 15:35:52 -04:00
_runtime.py Add `Arbiter.delete_sockaddr()` to remove addrs 2023-08-21 19:07:14 -04:00
_shm.py Updates from latest `piker.data._sharedmem` changes 2023-06-22 17:16:17 -04:00
_spawn.py Just import `mp` top level in `._spawn` 2023-06-14 15:32:15 -04:00
_state.py Move `NoRuntime` import inside `current_actor()` to avoid cycle 2023-05-15 10:00:45 -04:00
_streaming.py Move move context code into new `._context` mod 2023-05-15 10:00:45 -04:00
_supervise.py Hide actor nursery exit frame 2023-05-14 21:24:26 -04:00
log.py .log: more correct handling for `get_logger(__name__)` usage 2023-07-07 14:48:37 -04:00
msg.py Make `NamespacePath` work on object refs 2023-07-12 13:07:30 -04:00
to_asyncio.py Move `.to_asyncio` to modern optional value type annots 2023-07-21 15:08:46 -04:00