Skip to content

Commit 8d1a614

Browse files
Release ReadySet Core
In preparation for a public release of ReadySet Core, this commit renames all crates to their external-facing name, flattening out nested crates along the way, updating dependency paths and `use` statements accordingly. Notably, since the filtered history of the external-facing part of the repository excluded changes to Cargo.lock, this also adds a newly generated Cargo.lock file, based on the Cargo.lock in our internal repository but with all internal crates removed. This commit does *not* include any configuration for CI pipelines, since the way we test our code is currently tighly coupled to our internal CI system - going forward, we will pull that apart and publish a public component of our CI pipeline in this repository. Some references to internal-only concepts, issue trackers, and code may still exist at this point in the history - we'll be working on removing those going forwards. Co-authored-by: Griffin Smith <[email protected]> Change-Id: I2bb18980c93d21712d6b0c54e10614dab3e2b31c
1 parent 6f620d0 commit 8d1a614

File tree

380 files changed

+7317
-1256
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

380 files changed

+7317
-1256
lines changed

Cargo.lock

Lines changed: 6064 additions & 0 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

Cargo.toml

Lines changed: 33 additions & 27 deletions
Original file line numberDiff line numberDiff line change
@@ -5,41 +5,47 @@ eui48 = { git = "https://github.com/readysettech/eui48.git", branch = "master" }
55

66
[workspace]
77
members = [
8+
"array2",
89
"database-utils",
9-
"mysql-srv",
10-
"mysql-time",
11-
"nom-sql",
12-
"noria-client",
13-
"noria-client/test-helpers",
14-
"noria-mysql",
15-
"noria-psql",
16-
"noria/data",
17-
"noria/errors",
18-
"noria/noria",
19-
"noria/server",
20-
"noria/server/sql-passes",
21-
"noria/server/dataflow/partial_map",
22-
"noria/server/dataflow/reader_map",
23-
"noria/server/dataflow/state",
24-
"noria/clustertest",
25-
"noria/clustertest/macros",
10+
"dataflow-expression",
11+
"dataflow-state",
2612
"failpoint-macros",
2713
"failpoint-macros/proc-macros",
28-
"noria/tools",
29-
"noria/noria-logictest",
30-
"noria/timestamp_service",
31-
"psql-srv",
32-
"merging-interval-tree",
3314
"launchpad",
34-
"replicators",
35-
"query_generator",
3615
"maths",
16+
"merging-interval-tree",
3717
"metrics-aggregator",
38-
"test_utils",
18+
"mysql-srv",
19+
"mysql-time",
20+
"nom-sql",
21+
"partial-map",
22+
"psql-srv",
23+
"query-generator",
24+
"reader-map",
25+
"readyset",
26+
"readyset-client",
27+
"readyset-client-adapter",
28+
"readyset-client-metrics",
29+
"readyset-client-test-helpers",
30+
"readyset-clustertest",
31+
"readyset-common",
32+
"readyset-clustertest",
33+
"readyset-data",
34+
"readyset-dataflow",
35+
"readyset-errors",
36+
"readyset-logictest",
37+
"readyset-mir",
38+
"readyset-mysql",
39+
"readyset-psql",
40+
"readyset-repl",
41+
"readyset-server",
42+
"readyset-sql-passes",
43+
"readyset-tools",
3944
"readyset-tracing",
4045
"readyset-tracing/proc-macros",
41-
"readyset-repl",
42-
"array2",
46+
"replicators",
47+
"test-utils",
48+
"timestamp-service",
4349
"tournament-kway"
4450
]
4551
resolver = "2"

LICENSE

Lines changed: 97 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,97 @@
1+
Business Source License 1.1
2+
3+
Parameters
4+
5+
Licensor: ReadySet, Inc.
6+
Licensed Work: ReadySet Core v0.1
7+
The Licensed Work is (c) 2022 ReadySet, Inc.
8+
9+
Additional Use Grant: You may make use of the Licensed Work, provided that
10+
you may not use the Licensed Work for a Database Service. A ‘Database
11+
Service’ is a commercial offering that allows third parties (other than
12+
your employees and contractors) to access the functionality of the Licensed Work.
13+
14+
Change Date: 2026-06-09
15+
16+
Change License: Apache License, Version 2.0
17+
18+
19+
Notice
20+
21+
The Business Source License (this document, or the “License”) is not an Open
22+
Source license. However, the Licensed Work will eventually be made available
23+
under an Open Source License, as stated in this License.
24+
25+
License text copyright (c) 2017 MariaDB Corporation Ab, All Rights Reserved.
26+
“Business Source License” is a trademark of MariaDB Corporation Ab.
27+
28+
-----------------------------------------------------------------------------
29+
30+
Business Source License 1.1
31+
32+
Terms
33+
34+
The Licensor hereby grants you the right to copy, modify, create derivative
35+
works, redistribute, and make non-production use of the Licensed Work. The
36+
Licensor may make an Additional Use Grant, above, permitting limited
37+
production use.
38+
39+
Effective on the Change Date, or the fourth anniversary of the first publicly
40+
available distribution of a specific version of the Licensed Work under this
41+
License, whichever comes first, the Licensor hereby grants you rights under
42+
the terms of the Change License, and the rights granted in the paragraph
43+
above terminate.
44+
45+
If your use of the Licensed Work does not comply with the requirements
46+
currently in effect as described in this License, you must purchase a
47+
commercial license from the Licensor, its affiliated entities, or authorized
48+
resellers, or you must refrain from using the Licensed Work.
49+
50+
All copies of the original and modified Licensed Work, and derivative works
51+
of the Licensed Work, are subject to this License. This License applies
52+
separately for each version of the Licensed Work and the Change Date may vary
53+
for each version of the Licensed Work released by Licensor.
54+
55+
You must conspicuously display this License on each original or modified copy
56+
of the Licensed Work. If you receive the Licensed Work in original or
57+
modified form from a third party, the terms and conditions set forth in this
58+
License apply to your use of that work.
59+
60+
Any use of the Licensed Work in violation of this License will automatically
61+
terminate your rights under this License for the current and all other
62+
versions of the Licensed Work.
63+
64+
This License does not grant you any right in any trademark or logo of
65+
Licensor or its affiliates (provided that you may use a trademark or logo of
66+
Licensor as expressly required by this License).
67+
68+
TO THE EXTENT PERMITTED BY APPLICABLE LAW, THE LICENSED WORK IS PROVIDED ON
69+
AN “AS IS” BASIS. LICENSOR HEREBY DISCLAIMS ALL WARRANTIES AND CONDITIONS,
70+
EXPRESS OR IMPLIED, INCLUDING (WITHOUT LIMITATION) WARRANTIES OF
71+
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, NON-INFRINGEMENT, AND
72+
TITLE.
73+
74+
MariaDB hereby grants you permission to use this License’s text to license
75+
your works, and to refer to it using the trademark “Business Source License”,
76+
as long as you comply with the Covenants of Licensor below.
77+
78+
Covenants of Licensor
79+
80+
In consideration of the right to use this License’s text and the “Business
81+
Source License” name and trademark, Licensor covenants to MariaDB, and to all
82+
other recipients of the licensed work to be provided by Licensor:
83+
84+
1. To specify as the Change License the GPL Version 2.0 or any later version,
85+
or a license that is compatible with GPL Version 2.0 or a later version,
86+
where “compatible” means that software provided under the Change License can
87+
be included in a program with software provided under GPL Version 2.0 or a
88+
later version. Licensor may specify additional Change Licenses without
89+
limitation.
90+
91+
2. To either: (a) specify an additional grant of rights to use that does not
92+
impose any additional restriction on the right granted in this License, as
93+
the Additional Use Grant; or (b) insert the text “None”.
94+
95+
3. To specify a Change Date.
96+
97+
4. Not to modify this License in any other way.

README.md

Lines changed: 193 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,193 @@
1+
<p align="center">
2+
<img src="https://user-images.githubusercontent.com/38481289/172237414-023c0b04-c597-44b7-8b14-b5b0c382dc07.png" width='70%'>
3+
</p>
4+
<p align="center">
5+
<a href='https://join.slack.com/t/readysetcommunity/shared_invite/zt-1c7bxdxo7-Y6KuoLfc1YWagLk3xHSrsw'><img src='https://img.shields.io/badge/Slack-Join%20the%20community-4A154B?style=flat&logo=slack&logoColor=white'></a>
6+
<a href='https://readysettech.typeform.com/to/BqovNk8A?typeform-source=github.com'><img src='https://img.shields.io/badge/ReadySet-Join%20the%20cloud%20waitlist-7648B5?logo='></a>
7+
</p>
8+
9+
---
10+
11+
ReadySet is a SQL caching engine designed to help developers enhance the performance and scalability of their existing database-backed applications.
12+
13+
- [What is ReadySet?](#what-is-readyset)
14+
- [Getting Started](#getting-started)
15+
- [Documentation](#documentation)
16+
- [Join the Community](#join-the-community)
17+
- [Development](#development)
18+
- [License](#license)
19+
20+
## What is ReadySet?
21+
22+
ReadySet is a lightweight SQL caching engine that precomputes frequently-accessed query results and automatically keeps these results up-to-date over time as the underlying data in your database changes. ReadySet is wire-compatible with MySQL and Postgres and can be adopted without code changes.
23+
24+
<br>
25+
<p align="center">
26+
<img src='https://user-images.githubusercontent.com/38481289/172237407-e0546ef3-2095-49ab-be82-a177e507c6d1.png' width='70%'>
27+
</p>
28+
<br>
29+
30+
ReadySet acts as both a SQL cache and a proxy– when you first connect ReadySet to your application, it defaults to proxying all of your queries to your backing database, so it doesn't change the behavior of your application.
31+
32+
From there, you can monitor the performance of your queries using the ReadySet dashboard, and cache a subset of them in ReadySet. ReadySet automatically keeps cached results up-to-date over time as the underlying data in your database changes, so there's no need to write cache maintenance logic.
33+
34+
35+
## Getting Started
36+
37+
### Deploy ReadySet
38+
The ReadySet orchestrator is a command line tool that uses Docker Compose to spin up a ReadySet instance on your local machine. The following command downloads and runs the ReadySet orchestrator:
39+
40+
```
41+
bash -c "$(curl -sSL https://launch.readyset.io)"
42+
```
43+
The orchestrator will prompt you to select a wire protocol, and to connect ReadySet to an existing database (or create a new one).
44+
45+
### Connect to ReadySet
46+
47+
- **To connect to ReadySet via the MySQL or Postgres command line**, run the command that the orchestrator prints after successfully deploying a ReadySet instance.
48+
- **To connect ReadySet to your application**, use the ReadySet connection string (printed by the orchestrator after successfully deploying ReadySet) in the same way you would if it were a MySQL or Postgres connection string. Check out our [docs](https://docs.readyset.io/connecting) for more information.
49+
50+
Once you connect to ReadySet, you can start issuing queries as you would with a traditional database.
51+
52+
### Monitor Query Performance
53+
54+
By default, all queries sent to ReadySet are proxied to the backing database. You can see the current list of proxied queries and their performance profiles via the ReadySet dashboard which is accessible on `http://localhost:4000`.
55+
56+
57+
### Cache Queries
58+
ReadySet supports caching both prepared statements (i.e. parameterized queries) and one-off queries. To cache a query in ReadySet, you’ll need either the query ID (which can be found in the dashboard, or by running `SHOW CACHES`) or the full query text (i.e. the `SELECT` statement).
59+
60+
From there, you can run `CREATE CACHE FROM <query ID>` or `CREATE CACHE FROM <select statement>` via the MySQL or Postgres client.
61+
62+
#### Write Handling
63+
You can either send writes to ReadySet or directly to your backing database. If you send ReadySet a write, it will be proxied to your backing database. ReadySet waits to receive updates from your database's bin logs before updating the cached state to reflect those writes.
64+
65+
**Note:** The ReadySet Orchestrator is updated frequently with releases built off our internal ReadySet repository. Because of this, the orchestrator may have features not yet in our public repo. We're working on making our live codebase available on Github.
66+
67+
## FAQs
68+
**Q: How does ReadySet work under the hood?**
69+
70+
A: The heart of ReadySet is a query engine based on partially-stateful, streaming data flow. To learn more about how it works, see [our docs](https://docs.readyset.io/concepts/overview).
71+
72+
**Q: How does ReadySet keep cached state up to date?**
73+
74+
A: ReadySet receives updates about data changes from your backing database via binlog replication and uses those updates to automatically update its internal state.
75+
76+
**Q: Do I have to send all of my database traffic to ReadySet?**
77+
78+
A: You can if you want to, but it’s not required. You can manually route a subset of your traffic to ReadySet (as you would with a traditional database read replica), or you can send all of it to ReadySet. It's important to note that not all of the queries sent to ReadySet need to be cached– you have fine-grained control over what is cached vs. what is proxied.
79+
80+
## Documentation
81+
For more information, check out our full docs site [here](http://docs.readyset.io).
82+
83+
## Join the Community
84+
85+
For questions or support, join us on the [ReadySet Community Slack](https://join.slack.com/t/readysetcommunity/shared_invite/zt-18z5bxv02-C5R08CYFL00jXmIqjd7Ziw). You can also post questions on our [Github forum](https://github.com/readysettech/readyset/discussions). Everyone is welcome!
86+
87+
## Development
88+
89+
### Prerequisites
90+
91+
#### Install Dependencies
92+
93+
Prior to running ReadySet, you may need to install the following dependencies:
94+
clang
95+
libclang-dev
96+
libssl-dev
97+
liblz4-dev
98+
build-essential
99+
100+
**macOS:**
101+
```
102+
brew install lz4
103+
brew install [email protected]
104+
```
105+
106+
**Ubuntu:**
107+
```
108+
sudo apt update && sudo apt install -y build-essential libssl-dev pkg-config llvm clang liblz4-dev cmake
109+
```
110+
#### Install Rust
111+
ReadySet is written entirely in Rust. If you don’t already have Rust installed, you can install it via rustup (select the version of ‘nightly’ specified in the `rust-toolchain` file):
112+
113+
```curl https://sh.rustup.rs -sSf | sh```
114+
#### Runtime Dependencies: Upstream Database and Consul
115+
##### Local Development
116+
To streamline local development, all runtime dependencies (Consul, MySQL, Postgres) can be run with:
117+
118+
```
119+
cp docker-compose.override.yml.example docker-compose.override.yml
120+
docker-compose up -d
121+
```
122+
123+
##### Full Deployment
124+
ReadySet runs alongside a backing MySQL or Postgres database and uses Consul for leader election. You’ll need to pass in your database’s connection string when running the ReadySet server and adapter, and have a Consul instance running.
125+
126+
*Note:* Consul persists data per deployment. Using the same deployment name will carry over any previously installed queries into a new deployment.
127+
128+
129+
### Run ReadySet
130+
#### ReadySet Server
131+
132+
First, compile and run ReadySet server.
133+
134+
```
135+
cargo run --bin readyset-server --features display_literals --release -- --replication-url <upstream-url> --deployment <deployment name>
136+
```
137+
138+
If using the databases supplied by the docker-compose environment in this repository, replace <upstream-url> with the URL of the database corresponding to your database engine:
139+
140+
* MySQL: `mysql://root:[email protected]/readyset`
141+
* PostgreSQL: `postgresql://root:[email protected]/readyset`
142+
143+
If running with an existing external database, replace <upstream-url> with the connection string for that database.
144+
145+
#### ReadySet MySQL or Postgres Adapter
146+
147+
Then, run the adapter binary corresponding to your upstream database (MySQL or Postgres) The adapter will communicate with servers that have the same deployment name.
148+
149+
**MySQL**
150+
```
151+
cargo run --bin readyset-mysql --features display_literals --release -- --upstream-db-url mysql://root:[email protected]/readyset --allow-unauthenticated-connections
152+
--address 0.0.0.0:3307 --deployment <deployment name> --prometheus-metrics --query-log --query-log-ad-hoc
153+
```
154+
155+
**Postgres**
156+
```
157+
cargo run --bin readyset-psql --features display_literals --release -- --upstream-db-url postgresql://postgres:[email protected]/readyset --allow-unauthenticated-connections
158+
--address 0.0.0.0:5433 --deployment <deployment name> --prometheus-metrics --query-log --query-log-ad-hoc
159+
```
160+
161+
The adapter listens for connections at the address specified in the `address` flag.
162+
163+
The `query-log` and `query-log-ad-hoc` flags ensure that queries are sent to the Prometheus client running in the adapter.
164+
165+
The `prometheus-metrics` flag exposes an HTTP endpoint in the adapter to allow querying of metrics. This can be reached with an HTTP GET request to <adapter-address>:6034/prometheus (e.g., `curl -X GET 127.0.0.1:6034/prometheus`).
166+
167+
### Testing
168+
169+
To run tests for the project, run the following command:
170+
171+
```
172+
cargo test --skip integration_serial
173+
```
174+
##### Testing Notes
175+
176+
Certain tests cannot be run in parallel with others, and these tests are typically in files postfixed with _serial. Running the entire set of tests for a package, i.e. `cargo test -p readyset-server` may fail if serial tests are included.
177+
178+
Running tests may require increasing file descriptor limits. You can do so by running `ulimit -Sn 65535`.
179+
180+
### Performance
181+
182+
When running ReadySet in a performance-critical setting, make sure you compile with the `--release` flag.
183+
184+
**Note:** This repository contains a snapshot of the current state of the
185+
ReadySet internal repository. Our team is currently working on getting our live
186+
codebase, including all development history, ready to be hosted on GitHub, at
187+
which point we'll force push to this repository.
188+
189+
## License
190+
191+
ReadySet is licensed under the BSL 1.1 license, converting to the open-source Apache 2.0 license after 4 years. It is free to use on any number of nodes. The ReadySet team is hard at work getting the codebase ready to be hosted on Github.
192+
193+
ReadySet is also available as a paid cloud service that can be deployed to your accounts or hosted entirely by ReadySet. You can get early access to our cloud product by signing up [here](https://readysettech.typeform.com/to/BqovNk8A).

array2/Cargo.toml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@
22
name = "array2"
33
version = "0.0.1"
44
publish = false
5-
authors = ["Readyset"]
5+
authors = ["ReadySet Technology, Inc. <[email protected]>"]
66
edition = "2021"
77

88
[dependencies]

database-utils/Cargo.toml

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2,6 +2,7 @@
22
name = "database-utils"
33
version = "0.1.0"
44
publish = false
5+
authors = ["ReadySet Technology, Inc. <[email protected]>"]
56
edition = "2021"
67

78
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

0 commit comments

Comments
 (0)