Skip to content

Commit

Permalink
Merge pull request #300 from JasonYangShadow/issue/2325
Browse files Browse the repository at this point in the history
update DMTCP checkpoint demo code
  • Loading branch information
DrDaveD authored Oct 21, 2024
2 parents a799e67 + 1a0f5c3 commit f77a5a0
Show file tree
Hide file tree
Showing 3 changed files with 50 additions and 44 deletions.
5 changes: 4 additions & 1 deletion .github/workflows/pull_request.yml
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,10 @@ jobs:

- name: Install Sphinx
run: |
pip install --user --upgrade --upgrade-strategy eager setuptools sphinx sphinx-rtd-theme restructuredtext_lint rstcheck pygments m2r2
# docutils==0.16 is a temporary downgrade to fix a compiling issue
# see https://github.com/CrossNox/m2r2/issues/68
# requiring docutils version <0.21
pip install --user --upgrade --upgrade-strategy eager docutils==0.16 setuptools sphinx sphinx-rtd-theme restructuredtext_lint rstcheck pygments m2r2
- name: Lint rst
run: |
Expand Down
2 changes: 1 addition & 1 deletion apptainer_source
Submodule apptainer_source updated 240 files
87 changes: 45 additions & 42 deletions checkpoint.rst
Original file line number Diff line number Diff line change
Expand Up @@ -99,45 +99,36 @@ state has been successfully restored upon restart.
.. code::
Bootstrap: docker
From: python:3.10-buster
From: python:3.10-bookworm
%post
mkdir /app
cat > /app/server.py <<EOF
import socketserver
import argparse
from http.server import BaseHTTPRequestHandler, HTTPServer
state = "0"
count = 0
parser = argparse.ArgumentParser(description='Optional app description')
parser.add_argument('port', type=int, help='A required integer port argument')
args = parser.parse_args()
class handler(BaseHTTPRequestHandler):
def do_GET(self):
self.send_response(200)
self.send_header('Content-type','text/plain')
self.end_headers()
self.wfile.write(bytes(state, "utf8"))
def do_POST(self):
self.send_response(200)
self.send_header('Content-type','text/plain')
self.end_headers()
global state
state = self.rfile.read(1).decode("utf8")
self.wfile.write(bytes(state, "utf8"))
with HTTPServer(('', args.port), handler) as server:
server.serve_forever()
class Handler(socketserver.BaseRequestHandler):
def handle(self):
global count
count += 1
response = bytes("request:{}\n".format(count), "ascii")
self.request.sendall(response)
if __name__ == "__main__":
with socketserver.TCPServer(('', args.port), Handler) as server:
server.allow_reuse_address = True
server.serve_forever()
EOF
%startscript
python3 /app/server.py $@
We can build this container using:

.. code::
Expand Down Expand Up @@ -168,21 +159,19 @@ the state of a variable on the server.

.. code::
$ curl localhost:8888; echo
0
$ curl --http0.9 localhost:8888
request:1
We can see that it is set to ``0`` by default when this application is started
normally. We can now update the state of the server from ``0`` to ``1`` with
the following ``POST`` request:
We can see that the request count value is ``1`` when this application is started
and accessed via curl. After making another call to the application, we can see that the request
count is ``2`` as expected.

.. code::
$ curl -X POST localhost:8888 -d '1'; echo
1
$ curl localhost:8888; echo
1
$ curl --http0.9 localhost:8888
request:2
Now that variable on our server is in a new state, ``1``, we can use the
Now that the request count variable on our server is in a new state, ``2``, we can use the
``checkpoint instance`` command and reference the instance via the
``instance://`` URI format:

Expand Down Expand Up @@ -210,14 +199,28 @@ our application's state:
INFO: instance started successfully
And now we can verify the variable on the server has been properly restored to
a value of ``1``, instead of the default of ``0``:
And now when we get access to the application again, the request count value is ``3`` as expected,
meaning that the previous request count value was ``2``.

.. code::
$ curl localhost:8888; echo
1
$ curl --http0.9 localhost:8888
$ request:3
We can repeat the previous two steps, i.e. stop the server instance and restart it via dmtcp to verify the restoration
of the value of the request count.

.. code::
$ {command} instance stop server
$ {command} instance start --dmtcp-restart example-checkpoint server.sif restarted-server 8888
Then access the application and see that the request count value is restored as expected.

.. code::
$ curl --http0.9 localhost:8888
$ request:3
Finally, we can stop our instance running our restored application and delete our
checkpoint if we no longer need it to restart our application from this state:
Expand Down

0 comments on commit f77a5a0

Please sign in to comment.