Hello, I would like to be able to suspend wasm machine execution, scrape whole execution state, and persist it to be able to resume execution even after application restart. Users write their code as wasm binaries and launch them on a server. Wasm provides the sandbox, application provides specific API. But nuance here is that all the launched binaries can be very long playing and must be persistable to survive server restarts and to be independently paused/unloaded by server at any moment of time.
Persisting memory instances should be quite straighforward: they're simply chunks of continuous bytes. But I'm in doubt if it's possible to access/reconstuct the stack. And if it's possible to pause in any place, even in the middle of wasm code (and call/jmp it again to the same place).
Most likely all of that is not possible with current API. What amount of effort is required to implement this? (I'm not asking to do this, or even to merge such features into upstream, I just need to know how deep is the rabbit hole).
@neumond indeed yeah the call stack is the hard part, and this is something that wasmtime doesn't currently support
afaik the "best" way known to implement this is to run wasm on a different call stack so you can serialize that out as well
@neumond Lucet has similar requirements. You might talk to @Aaron Turon.
Last updated: Jan 24 2025 at 00:11 UTC