Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Clarify what a restart means #966

Merged
merged 4 commits into from
Dec 6, 2023
Merged
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 8 additions & 0 deletions docs/messaging.rst
Original file line number Diff line number Diff line change
Expand Up @@ -1049,6 +1049,14 @@ multiple cases:
IPythonQt client) to force a kernel restart to get a clean kernel without
losing client-side state like history or inlined figures.

A restart should optimally preserve as many resources outside the kernel as
possible (e.g. only restart the kernel and its subprocesses and not any
parent processes). That is, ideally a restart should be "in-place". For local
kernels, there is typically no parent process so a "hard" restart and an in-place
restart are identical whereas for remote kernels this is not generally the same.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Great! Maybe worth giving an example, e.g. for a kernel running a container, the container may be kept running and a new kernel process started in the same container without restarting the container. It may also be worth making clear that this is a note for the code starting kernels, since most docs here are about how the kernel should respond to messages.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thoughts on the new wording?


.. versionchanged:: 5.4
mlucool marked this conversation as resolved.
Show resolved Hide resolved

The client sends a shutdown request to the kernel, and once it receives the
reply message (which is otherwise empty), it can assume that the kernel has
completed shutdown safely. The request is sent on the `control` channel.
Expand Down