|
|
@@ -3,18 +3,20 @@
|
|
|
README version 0.3.0
|
|
|
|
|
|
A highly-available key value store for shared configuration and service discovery.
|
|
|
-etcd is inspired by zookeeper and doozer, with a focus on:
|
|
|
+etcd is inspired by [Apache ZooKeeper][zookeeper] and [doozer][doozer], with a focus on being:
|
|
|
|
|
|
-* Simple: curl'able user facing API (HTTP+JSON)
|
|
|
-* Secure: optional SSL client cert authentication
|
|
|
-* Fast: benchmarked 1000s of writes/s per instance
|
|
|
-* Reliable: Properly distributed using Raft
|
|
|
+* *Simple*: curl'able user facing API (HTTP+JSON)
|
|
|
+* *Secure*: optional SSL client cert authentication
|
|
|
+* *Fast*: benchmarked 1000s of writes/s per instance
|
|
|
+* *Reliable*: properly distributed using Raft
|
|
|
|
|
|
-Etcd is written in Go and uses the [Raft][raft] consensus algorithm to manage a highly-available replicated log.
|
|
|
+etcd is written in Go and uses the [Raft][raft] consensus algorithm to manage a highly-available replicated log.
|
|
|
|
|
|
See [etcdctl][etcdctl] for a simple command line client.
|
|
|
Or feel free to just use curl, as in the examples below.
|
|
|
|
|
|
+[zookeeper]: http://zookeeper.apache.org/
|
|
|
+[doozer]: https://github.com/ha/doozerd
|
|
|
[raft]: http://raftconsensus.github.io/
|
|
|
[etcdctl]: http://github.com/coreos/etcdctl/
|
|
|
|
|
|
@@ -22,7 +24,7 @@ Or feel free to just use curl, as in the examples below.
|
|
|
|
|
|
### Getting etcd
|
|
|
|
|
|
-The latest release and setup instructions are available at [Github][github-release].
|
|
|
+The latest release and setup instructions are available at [GitHub][github-release].
|
|
|
|
|
|
[github-release]: https://github.com/coreos/etcd/releases/
|
|
|
|
|
|
@@ -45,13 +47,13 @@ _NOTE_: you need go 1.2+. Please check your installation with
|
|
|
go version
|
|
|
```
|
|
|
|
|
|
-See the [development tools documentation][development-tools.md] for alternative build methods like using Vagrant.
|
|
|
+See the [development tools documentation][development-tools] for alternative build methods like using Vagrant.
|
|
|
|
|
|
-[development-tools.md]: https://github.com/coreos/etcd/blob/master/Documentation/development-tools.md
|
|
|
+[development-tools]: https://github.com/coreos/etcd/blob/master/Documentation/development-tools.md
|
|
|
|
|
|
### Running
|
|
|
|
|
|
-First start a single machine cluster of etcd:
|
|
|
+First start a single-machine cluster of etcd:
|
|
|
|
|
|
```sh
|
|
|
./bin/etcd
|
|
|
@@ -59,43 +61,43 @@ First start a single machine cluster of etcd:
|
|
|
|
|
|
This will bring up etcd listening on port 4001 for client communication and on port 7001 for server-to-server communication.
|
|
|
|
|
|
-Next lets set a single key and then retrieve it:
|
|
|
+Next, let's set a single key, and then retrieve it:
|
|
|
|
|
|
```
|
|
|
curl -L http://127.0.0.1:4001/v2/keys/mykey -XPUT -d value="this is awesome"
|
|
|
curl -L http://127.0.0.1:4001/v2/keys/mykey
|
|
|
```
|
|
|
|
|
|
-You have successfully started an etcd on a single machine and written a key to the store. Now it time to dig into the full etcd API and other guides.
|
|
|
+You have successfully started an etcd on a single machine and written a key to the store. Now it's time to dig into the full etcd API and other guides.
|
|
|
|
|
|
### Next Steps
|
|
|
|
|
|
-- Explore the full [API][api.md].
|
|
|
-- Setup a [multi-machine cluster][clustering.md].
|
|
|
-- Learn the [config format, env variables and flags][configuration.md].
|
|
|
-- Find [language bindings and tools][libraries-and-tools.md].
|
|
|
-- Learn about the dashboard, lock and leader election [modules][modules.md].
|
|
|
-- Use TLS to [secure an etcd cluster][security.md].
|
|
|
-- [Tune etcd][tuning.md].
|
|
|
-
|
|
|
-[api.md]: https://github.com/coreos/etcd/blob/master/Documentation/api.md
|
|
|
-[clustering.md]: https://github.com/coreos/etcd/blob/master/Documentation/clustering.md
|
|
|
-[configuration.md]: https://github.com/coreos/etcd/blob/master/Documentation/configuration.md
|
|
|
-[libraries-and-tools.md]: https://github.com/coreos/etcd/blob/master/Documentation/libraries-and-tools.md
|
|
|
-[modules.md]: https://github.com/coreos/etcd/blob/master/Documentation/modules.md
|
|
|
-[security.md]: https://github.com/coreos/etcd/blob/master/Documentation/security.md
|
|
|
-[tuning.md]: https://github.com/coreos/etcd/blob/master/Documentation/tuning.md
|
|
|
+- Explore the full [API][api].
|
|
|
+- Set up a [multi-machine cluster][clustering].
|
|
|
+- Learn the [config format, env variables and flags][configuration].
|
|
|
+- Find [language bindings and tools][libraries-and-tools].
|
|
|
+- Learn about the dashboard, lock and leader election [modules][modules].
|
|
|
+- Use TLS to [secure an etcd cluster][security].
|
|
|
+- [Tune etcd][tuning].
|
|
|
+
|
|
|
+[api]: https://github.com/coreos/etcd/blob/master/Documentation/api.md
|
|
|
+[clustering]: https://github.com/coreos/etcd/blob/master/Documentation/clustering.md
|
|
|
+[configuration]: https://github.com/coreos/etcd/blob/master/Documentation/configuration.md
|
|
|
+[libraries-and-tools]: https://github.com/coreos/etcd/blob/master/Documentation/libraries-and-tools.md
|
|
|
+[modules]: https://github.com/coreos/etcd/blob/master/Documentation/modules.md
|
|
|
+[security]: https://github.com/coreos/etcd/blob/master/Documentation/security.md
|
|
|
+[tuning]: https://github.com/coreos/etcd/blob/master/Documentation/tuning.md
|
|
|
|
|
|
## Contact
|
|
|
|
|
|
-- Mailing list: http://coreos.com/lists/etcd-dev/
|
|
|
-- IRC: #coreos on irc.freenode.net
|
|
|
-- Planning/Roadmap: https://trello.com/b/OiEbU547/etcd
|
|
|
-- Bugs: https://github.com/coreos/etcd/issues
|
|
|
+- Mailing list: [etcd-dev](http://coreos.com/lists/etcd-dev/)
|
|
|
+- IRC: #[coreos](irc://irc.freenode.org:6667/#coreos) oon freenode.org
|
|
|
+- Planning/Roadmap: [milestones](https://github.com/coreos/etcd/issues/milestones)
|
|
|
+- Bugs: [issues](https://github.com/coreos/etcd/issues)
|
|
|
|
|
|
## Contributing
|
|
|
|
|
|
-See [CONTRIBUTING](https://github.com/coreos/etcd/blob/master/CONTRIBUTING.md) for details on submitting patches and contacting developers via IRC and mailing lists.
|
|
|
+See [CONTRIBUTING](CONTRIBUTING.md) for details on submitting patches and the contribution workflow.
|
|
|
|
|
|
## Project Details
|
|
|
|
|
|
@@ -103,7 +105,7 @@ See [CONTRIBUTING](https://github.com/coreos/etcd/blob/master/CONTRIBUTING.md) f
|
|
|
|
|
|
#### Service Versioning
|
|
|
|
|
|
-etcd uses [semantic versioning][semver].
|
|
|
+etcd uses [semantic versioning](http://semver.org)
|
|
|
New minor versions may add additional features to the API.
|
|
|
|
|
|
You can get the version of etcd by issuing a request to /version:
|
|
|
@@ -112,8 +114,6 @@ You can get the version of etcd by issuing a request to /version:
|
|
|
curl -L http://127.0.0.1:4001/version
|
|
|
```
|
|
|
|
|
|
-[semver]: http://semver.org/
|
|
|
-
|
|
|
#### API Versioning
|
|
|
|
|
|
Clients are encouraged to use the `v2` API. The `v1` API will not change.
|
|
|
@@ -124,6 +124,4 @@ During the pre-v1.0.0 series of releases we may break the API as we fix bugs and
|
|
|
|
|
|
### License
|
|
|
|
|
|
-etcd is under the Apache 2.0 license. See the [LICENSE][license] file for details.
|
|
|
-
|
|
|
-[license]: https://github.com/coreos/etcd/blob/master/LICENSE
|
|
|
+etcd is under the Apache 2.0 license. See the [LICENSE](LICENSE) file for details.
|