iawia002 opened PR #8983 from iawia002:wasi-keyvalue
to bytecodealliance:main
:
The wasi-keyvalue API has entered Phase 2. This patch implements the API, giving wasm components access to key-value storages.
Currently, only the Redis storage backend has been implemented, and support for more kv storage (e.g. etcd, etc.) will be added in the future.
cc @alexcrichton
iawia002 requested wasmtime-core-reviewers for a review on PR #8983.
iawia002 requested pchickey for a review on PR #8983.
iawia002 requested wasmtime-default-reviewers for a review on PR #8983.
iawia002 updated PR #8983.
iawia002 updated PR #8983.
Would it make sense to have a local storage method too? That would allow quick tests without requiring the setup of an entire database.
iawia002 commented on PR #8983:
Would it make sense to have a local storage method too? That would allow quick tests without requiring the setup of an entire database.
Sure, I'll implement an in-memory backend and make the other database backends optional.
iawia002 updated PR #8983.
iawia002 commented on PR #8983:
I will fix the dead-code warning, but I have no idea why the runtime_config_get test failed:
---- runtime_config_get stdout ---- thread 'runtime_config_get' panicked at crates/wasmtime/src/runtime/vm/libcalls.rs:147:5: internal error: entered unreachable code
iawia002 updated PR #8983.
iawia002 commented on PR #8983:
I will fix the dead-code warning, but I have no idea why the runtime_config_get test failed:
---- runtime_config_get stdout ---- thread 'runtime_config_get' panicked at crates/wasmtime/src/runtime/vm/libcalls.rs:147:5: internal error: entered unreachable code
I have figured it out (#8997) and made a temporary solution by adding the
wasmtime/wmemcheck
feature towasi-runtime-config
:[features] # Do not use, this is only used for testing in CI, # see https://github.com/bytecodealliance/wasmtime/issues/8997 test = ["wasmtime/wmemcheck"]
alexcrichton submitted PR review:
This is looking quite good to me, thanks for the PR and the work here! The biggest question below I have is about how buckets are opened.
alexcrichton submitted PR review:
This is looking quite good to me, thanks for the PR and the work here! The biggest question below I have is about how buckets are opened.
alexcrichton created PR review comment:
Since
::default()
is used here it looks like there's no way to configure this in-memory configuration?
alexcrichton created PR review comment:
Is there perhaps a more "official" action to use here to setup redis? We in theory try to avoid third-party dependencies on actions because of security concerns, but if it's a complicated and/or widely-enough-used action we can make an exception.
alexcrichton created PR review comment:
This exposes the ability for wasm to make a connection to any redis server it wants without the host being able to intervene. In general we try to model the implementations of WASI proposals to deny access to things by default with explicit opt-ins to provide access.
Perhaps as an alternative design, could the configuration for
WasiKeyValueCtx
look along the lines of one of:
- Provides are added ahead-of-time to
WasiKeyValueCtx
which means the host has an allow-listed set of provides each component gets access to.- The host has a callback or trait which receives the
open
call here and returns aBox<dyn Host>
? That would enable the host to customize whether it wants the logic this method has implemneted or something more custom.
alexcrichton created PR review comment:
It loosk like this is silently ignoring non-integer previous values and converting them to 0?
iawia002 submitted PR review.
iawia002 created PR review comment:
Yes, the in-memory implementation is very simple. Currently, it doesn't have any configurable features, so configuration is not supported here.
iawia002 submitted PR review.
iawia002 created PR review comment:
Fixed, now, non-integer data conversion errors will be returned directly.
iawia002 updated PR #8983.
iawia002 submitted PR review.
iawia002 created PR review comment:
I am now using GitHub's Redis service containers to start a Redis service, but the drawback is that it can only run on Linux. Therefore, the previous macOS testing has been removed, but I think this is an acceptable compromise.
iawia002 submitted PR review.
iawia002 created PR review comment:
I chose the whitelist strategy and added a general configuration method that applies to all providers. By default, servers at all addresses are blocked from connecting. Which addresses the components can connect to depends on the runtime configuration.
iawia002 commented on PR #8983:
All comments addressed ec3373a, PTAL
alexcrichton submitted PR review.
alexcrichton created PR review comment:
Yeah that sounds reasonable to me too, thanks!
alexcrichton submitted PR review.
alexcrichton created PR review comment:
Could this be renamed to
allow_redis_hosts
?
alexcrichton created PR review comment:
I'm at least personally a bit hesitant to include this when it doesn't have any support/tests/etc. Would it be possible to hook this up to the configuration of
WasiKeyValueCtx
? Or somehow expose the ability to configure this? Otherwise I think it'd be better to remove the internals ofInMemory
and make it an empty struct which is a noop implementation of the trait.
iawia002 updated PR #8983.
iawia002 submitted PR review.
iawia002 created PR review comment:
I added a configuration option to the In-Memory provider that allows presetting some data. I believe this provider is valuable, especially in testing scenarios, where users can use this provider to mock some data without relying on a real database. PTAL if this is reasonable.
iawia002 updated PR #8983.
iawia002 commented on PR #8983:
All comments addressed b9d2bd2, PTAL.
The CI failed due to the feature combinations issue we encountered before. Since the changes are not related to this PR, I have submitted a separate PR #9016 to address that issue. Once that PR is merged, I will rebase this PR, and the CI should be happy then.
alexcrichton submitted PR review:
Looks good to me, thanks! I'll queue for merge after a rebase makes CI happy
(thanks for helping to debug CI and fix the issue!)
iawia002 updated PR #8983.
iawia002 commented on PR #8983:
Hi @alexcrichton, CI is happy now except
cargo vet
, I believe that should be handled by you.
alexcrichton updated PR #8983.
alexcrichton has enabled auto merge for PR #8983.
alexcrichton merged PR #8983.
thomastaylor312 commented on PR #8983:
Hey there! wasi-keyvalue champion here. So I don't think any of the champions knew this was landing. I'm super excited someone implemented it here (thanks @iawia002)! However, we are in the process of incorporating a last round of feedback now that we've had people implementing against it: https://github.com/WebAssembly/wasi-keyvalue/pull/46. We might want to hold off on releasing this until we can make those changes and go to a full 0.2.0 release of wasi-keyvalue
thomastaylor312 edited a comment on PR #8983:
Hey there! wasi-keyvalue champion here. So I don't think any of the champions knew this was landing. I'm super excited someone implemented it here (thanks @iawia002)! However, we are in the process of incorporating a last round of feedback now that we've had people implementing against it: https://github.com/WebAssembly/wasi-keyvalue/pull/46. We might want to hold off on releasing this until we can make those changes and go to a full 0.2.0 release of wasi-keyvalue.
Also, and in memory KV store makes sense to me, but I don't think we want to take hard deps on other KV stores in something like wasmtime. This was something that we had loosely talked about as being "host plugins" using something like wRPC
thomastaylor312 edited a comment on PR #8983:
Hey there! wasi-keyvalue champion here. So I don't think any of the champions knew this was landing. I'm super excited someone implemented it here (thanks @iawia002)! However, we are in the process of incorporating a last round of feedback now that we've had people implementing against it: https://github.com/WebAssembly/wasi-keyvalue/pull/46. We might want to hold off on releasing this until we can make those changes and go to a full 0.2.0 release of wasi-keyvalue.
Also, an in memory KV store makes sense to me, but I don't think we want to take hard deps on other KV stores in something like wasmtime. This was something that we had loosely talked about as being "host plugins" using something like wRPC
iawia002 commented on PR #8983:
Hi @thomastaylor312, basically, when a proposal enters Phase 2, we can start implementing it. If we wait for it to be completely ready before we begin, the timeline would become excessively long. Therefore, we also have corresponding implementations for draft versions of proposals, allowing users to start experimenting with the API.
For the
wasi-keyvalue
, the implementation targets a specific tag 219ea36. I will continue to track the latest changes in this proposal to keep the implementation up to date.Regarding the release issue, strictly speaking, this has not yet been landed. According to the wasmtime release schedule, the code will be frozen on the 5th and will not be released until the 20th of this month. So we still have time to follow up on the latest changes in the
wasi-keyvalue
proposal.Overall, I think we can go ahead and release this, allowing users of wasmtime v24 to try out the
wasi-keyvalue@0.2.0-draft
API.but I don't think we want to take hard deps on other KV stores in something like wasmtime. This was something that we had loosely talked about as being "host plugins" using something like wRPC
I agree with this, there are too many KV storage solutions. But I'm not sure if we should move all KV storage implementations out of wasmtime, because depending on Redis/etcd/Memcached, etc., does not affect
wasmtime
itself. It only affects the standalone cratewasmtime-wasi-keyvalue
and thewasmtime-cli
. I hope to implement some very popular providers in wasmtime and turn the others into "host plugins".
thomastaylor312 commented on PR #8983:
Yeah we chatted about this today in the wasmtime meeting. So I think we are ok with the current pinned tag, especially since things are behind a feature flag.
However, I still think keeping Redis in tree is a bad idea. The reason why even the super popular ones should be a plugin type model is that now any time the redis client has a bug, you have to update the keyvalue crate and the CLI just to get the bug fix. I know this could happen with any crate, but with client APIs, these kinds of fixes happen quite often. If it happens to be security sensitive, it would necessitate a release of the crate and CLI for anyone depending on it. This wouldn't happen if this was done by loading a plugin separately
iawia002 commented on PR #8983:
I understand your concerns. I am not sure what the "host plugins" will look like exactly. Since you mentioned wrpc, I assume it will involve a server and a client? If we turn all in-tree providers into plugins, would the user have to go through the following additional steps to access Redis?
- Deploy the plugin server
- Import the plugin
Compared to releasing patch versions for
wasmtime-wasi-keyvalue
andwasmtime-cli
, I am more worried about the impact on usability. Will this be too difficult for users, especially the step of deploying a separate plugin server?Anyway, before the 0.2 release of
wasi-keyvalue
, I don't plan to add more providers. I originally intended to consider these after the official release, but now it seems this will be on hold until we decide how to handle these providers.
iawia002 deleted a comment on PR #8983:
I understand your concerns. I am not sure what the "host plugins" will look like exactly. Since you mentioned wrpc, I assume it will involve a server and a client? If we turn all in-tree providers into plugins, would the user have to go through the following additional steps to access Redis?
- Deploy the plugin server
- Import the plugin
Compared to releasing patch versions for
wasmtime-wasi-keyvalue
andwasmtime-cli
, I am more worried about the impact on usability. Will this be too difficult for users, especially the step of deploying a separate plugin server?Anyway, before the 0.2 release of
wasi-keyvalue
, I don't plan to add more providers. I originally intended to consider these after the official release, but now it seems this will be on hold until we decide how to handle these providers.
iawia002 commented on PR #8983:
I have now seen the meeting notes. I apologize for any inconvenience caused by not notifying you during the implementation. I will submit a PR to revert the introduction of Redis.
thomastaylor312 commented on PR #8983:
No problem! I just wanted to make sure we had our ducks in a row here as we move forward adding new interfaces
Last updated: Jan 24 2025 at 00:11 UTC