From e4f1f0dc53781029b8b1ea6e5612ca9340ed67f7 Mon Sep 17 00:00:00 2001 From: Alex Gleason Date: Thu, 5 Oct 2023 21:01:13 -0500 Subject: [PATCH] Add debugging.md --- docs/debugging.md | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) create mode 100644 docs/debugging.md diff --git a/docs/debugging.md b/docs/debugging.md new file mode 100644 index 0000000..84e057a --- /dev/null +++ b/docs/debugging.md @@ -0,0 +1,17 @@ +# Debugging Ditto + +Running the command `deno task debug` will start the Ditto server in debug mode, making it possible to inspect with Chromium-based browsers by visiting `chrome://inspect`. + +From there, go to the "Performance" tab and click "Start profiling". Perform the actions you want to profile, then click "Stop profiling". You can then inspect the call stack and see where the time is being spent. + +## Remote debugging + +If the Ditto server is on a separate machine, you will first need to put it into debug mode. Edit its systemd file (usually located at `/etc/systemd/system/ditto.service`) and change `deno task start` to `deno task debug` in the `ExecStart` line. Then run `systemctl daemon-reload` and `systemctl restart ditto`. + +To access the debugger remotely, you can use SSH port forwarding. Run this command on your local machine, replacing `@` with the SSH login for the remote machine: + +```sh +ssh -L 9229:localhost:9229 @ +``` + +Then, in Chromium, go to `chrome://inspect` and the Ditto server should be available. \ No newline at end of file