1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-10 16:11:13 -05:00
denoland-deno/ext/kv
林炳权 2080669943
chore: update to Rust 1.72 (#20258)
<!--
Before submitting a PR, please read https://deno.com/manual/contributing

1. Give the PR a descriptive title.

  Examples of good title:
    - fix(std/http): Fix race condition in server
    - docs(console): Update docstrings
    - feat(doc): Handle nested reexports

  Examples of bad title:
    - fix #7123
    - update docs
    - fix bugs

2. Ensure there is a related issue and it is referenced in the PR text.
3. Ensure there are tests that cover the changes.
4. Ensure `cargo test` passes.
5. Ensure `./tools/format.js` passes without changing files.
6. Ensure `./tools/lint.js` passes.
7. Open as a draft PR if your work is still in progress. The CI won't
run
   all steps, but you can add '[ci]' to a commit message to force it to.
8. If you would like to run the benchmarks on the CI, add the 'ci-bench'
label.
-->

As the title.

---------

Co-authored-by: Matt Mastracci <matthew@mastracci.com>
2023-08-26 22:04:12 -06:00
..
proto feat(ext/kv): connect to remote database (#20178) 2023-08-22 13:56:00 +08:00
01_db.ts feat(ext/kv): key expiration (#20091) 2023-08-18 17:34:16 +08:00
build.rs feat(ext/kv): connect to remote database (#20178) 2023-08-22 13:56:00 +08:00
Cargo.toml chore: forward v1.36.3 release commit to main (#20270) 2023-08-24 17:53:01 +00:00
codec.rs fix(ext/kv): reverse mapping between AnyValue::Bool and KeyPart::Bool (#18365) 2023-03-22 21:53:16 +01:00
dynamic.rs feat(ext/kv): connect to remote database (#20178) 2023-08-22 13:56:00 +08:00
interface.rs feat(ext/kv): connect to remote database (#20178) 2023-08-22 13:56:00 +08:00
lib.rs fix(kv) increase number of allowed mutations in atomic (#20126) 2023-08-26 18:26:09 -07:00
README.md feat(ext/kv): connect to remote database (#20178) 2023-08-22 13:56:00 +08:00
remote.rs chore: update to Rust 1.72 (#20258) 2023-08-26 22:04:12 -06:00
sqlite.rs chore: update to Rust 1.72 (#20258) 2023-08-26 22:04:12 -06:00

deno_kv

This crate provides a key/value store for Deno. For an overview of Deno KV, please read the manual.

Storage Backends

Deno KV has a pluggable storage interface that supports multiple backends:

  • SQLite - backed by a local SQLite database. This backend is suitable for development and is the default when running locally.
  • Remote - backed by a remote service that implements the KV Connect protocol, for example Deno Deploy.

Additional backends can be added by implementing the DatabaseHandler trait.

KV Connect

The KV Connect protocol has separate control and data planes to maximize throughput and minimize latency. Metadata Exchange and Data Path are the two sub-protocols that are used when talking to a KV Connect-compatible service.

Metadata Exchange

To connect to a KV Connect service, the user provides an HTTP or HTTPS URL to Deno.openKv. A background task is then spawned to periodically make HTTP POST requests to the provided URL to refresh database metadata.

The HTTP Authorization header is included and have the format Bearer <access-token>. The <access-token> is a static token issued by the service provider. For Deno Deploy, this is the personal access token generated from the dashboard. You can specify the access token with the environment variable DENO_KV_ACCESS_TOKEN.

Request body is currently unused. The response is a JSON message that satisfies the JSON Schema definition in cli/schemas/kv-metadata-exchange-response.v1.json.

Semantics of the response fields:

  • version: Protocol version. The only supported value is 1.
  • databaseId: UUID of the database.
  • endpoints: Data plane endpoints that can serve requests to the database, along with their consistency levels.
  • token: An ephemeral authentication token that must be included in all requests to the data plane. This value is an opaque string and the client should not depend on its format.
  • expiresAt: The time at which the token expires. Encoded as an ISO 8601 string.

Data Path

After the first metadata exchange has completed, the client can talk to the data plane endpoints listed in the endpoints field using a Protobuf-over-HTTP protocol called the Data Path. The Protobuf messages are defined in proto/datapath.proto.

Two sub-endpoints are available under a data plane endpoint URL:

  • POST /snapshot_read: Used for read operations: kv.get() and kv.getMany().
    • Request type: SnapshotRead
    • Response type: SnapshotReadOutput
  • POST /atomic_write: Used for write operations: kv.set() and kv.atomic().commit().
    • Request type: AtomicWrite
    • Response type: AtomicWriteOutput

An HTTP Authorization header in the format Bearer <ephemeral-token> must be included in all requests to the data plane. The value of <ephemeral-token> is the token field from the metadata exchange response.

Error handling

All non-client errors (i.e. network errors and HTTP 5xx status codes) are handled by retrying the request. Randomized exponential backoff is applied to each retry.

Client errors cannot be recovered by retrying. A JavaScript exception is generated for each of those errors.