1**This is the documentation for etcd2 releases. Read [etcd3 doc][v3-docs] for etcd3 releases.**
2
3[v3-docs]: ../docs.md#documentation
4
5
6# Libraries and Tools
7
8**Tools**
9
10- [etcdctl](https://github.com/coreos/etcd/tree/master/etcdctl) - A command line client for etcd
11- [etcd-backup](https://github.com/fanhattan/etcd-backup) - A powerful command line utility for dumping/restoring etcd - Supports v2
12- [etcd-dump](https://npmjs.org/package/etcd-dump) - Command line utility for dumping/restoring etcd.
13- [etcd-fs](https://github.com/xetorthio/etcd-fs) - FUSE filesystem for etcd
14- [etcddir](https://github.com/rekby/etcddir) - Realtime sync etcd and local directory. Work with windows and linux.
15- [etcd-browser](https://github.com/henszey/etcd-browser) - A web-based key/value editor for etcd using AngularJS
16- [etcd-lock](https://github.com/datawisesystems/etcd-lock) - Master election & distributed r/w lock implementation using etcd - Supports v2
17- [etcd-console](https://github.com/matishsiao/etcd-console) - A web-base key/value editor for etcd using PHP
18- [etcd-viewer](https://github.com/nikfoundas/etcd-viewer) - An etcd key-value store editor/viewer written in Java
19- [etcdtool](https://github.com/mickep76/etcdtool) - Export/Import/Edit etcd directory as JSON/YAML/TOML and Validate directory using JSON schema
20- [etcd-rest](https://github.com/mickep76/etcd-rest) - Create generic REST API in Go using etcd as a backend with validation using JSON schema
21- [etcdsh](https://github.com/kamilhark/etcdsh) - A command line client with support of command history and tab completion. Supports v2
22
23**Go libraries**
24
25- [etcd/client](https://github.com/coreos/etcd/blob/master/client) - the officially maintained Go client
26- [go-etcd](https://github.com/coreos/go-etcd) - the deprecated official client. May be useful for older (<2.0.0) versions of etcd.
27
28**Java libraries**
29
30- [boonproject/etcd](https://github.com/boonproject/boon/blob/master/etcd/README.md) - Supports v2, Async/Sync and waits
31- [justinsb/jetcd](https://github.com/justinsb/jetcd)
32- [diwakergupta/jetcd](https://github.com/diwakergupta/jetcd) - Supports v2
33- [jurmous/etcd4j](https://github.com/jurmous/etcd4j) - Supports v2, Async/Sync, waits and SSL
34- [AdoHe/etcd4j](http://github.com/AdoHe/etcd4j) - Supports v2 (enhance for real production cluster)
35
36**Python libraries**
37
38- [jplana/python-etcd](https://github.com/jplana/python-etcd) - Supports v2
39- [russellhaering/txetcd](https://github.com/russellhaering/txetcd) - a Twisted Python library
40- [cholcombe973/autodock](https://github.com/cholcombe973/autodock) - A docker deployment automation tool
41- [lisael/aioetcd](https://github.com/lisael/aioetcd) - (Python 3.4+) Asyncio coroutines client (Supports v2)
42
43**Node libraries**
44
45- [stianeikeland/node-etcd](https://github.com/stianeikeland/node-etcd) - Supports v2 (w Coffeescript)
46- [lavagetto/nodejs-etcd](https://github.com/lavagetto/nodejs-etcd) - Supports v2
47- [deedubs/node-etcd-config](https://github.com/deedubs/node-etcd-config) - Supports v2
48
49**Ruby libraries**
50
51- [iconara/etcd-rb](https://github.com/iconara/etcd-rb)
52- [jpfuentes2/etcd-ruby](https://github.com/jpfuentes2/etcd-ruby)
53- [ranjib/etcd-ruby](https://github.com/ranjib/etcd-ruby) - Supports v2
54
55**C libraries**
56
57- [jdarcy/etcd-api](https://github.com/jdarcy/etcd-api) - Supports v2
58- [shafreeck/cetcd](https://github.com/shafreeck/cetcd) - Supports v2
59
60**C++ libraries**
61
62- [edwardcapriolo/etcdcpp](https://github.com/edwardcapriolo/etcdcpp) - Supports v2
63- [suryanathan/etcdcpp](https://github.com/suryanathan/etcdcpp) - Supports v2 (with waits)
64- [nokia/etcd-cpp-api](https://github.com/nokia/etcd-cpp-api) - Supports v2
65- [nokia/etcd-cpp-apiv3](https://github.com/nokia/etcd-cpp-apiv3)
66
67**Clojure libraries**
68
69- [aterreno/etcd-clojure](https://github.com/aterreno/etcd-clojure)
70- [dwwoelfel/cetcd](https://github.com/dwwoelfel/cetcd) - Supports v2
71- [rthomas/clj-etcd](https://github.com/rthomas/clj-etcd) - Supports v2
72
73**Erlang libraries**
74
75- [marshall-lee/etcd.erl](https://github.com/marshall-lee/etcd.erl)
76
77**.Net Libraries**
78
79- [wangjia184/etcdnet](https://github.com/wangjia184/etcdnet) - Supports v2
80- [drusellers/etcetera](https://github.com/drusellers/etcetera)
81
82**PHP Libraries**
83
84- [linkorb/etcd-php](https://github.com/linkorb/etcd-php)
85
86**Haskell libraries**
87
88- [wereHamster/etcd-hs](https://github.com/wereHamster/etcd-hs)
89
90**R libraries**
91
92- [ropensci/etseed](https://github.com/ropensci/etseed)
93
94**Tcl libraries**
95
96- [efrecon/etcd-tcl](https://github.com/efrecon/etcd-tcl) - Supports v2, except wait.
97
98**Chef Integration**
99
100- [coderanger/etcd-chef](https://github.com/coderanger/etcd-chef)
101
102**Chef Cookbook**
103
104- [spheromak/etcd-cookbook](https://github.com/spheromak/etcd-cookbook)
105
106**BOSH Releases**
107
108- [cloudfoundry-community/etcd-boshrelease](https://github.com/cloudfoundry-community/etcd-boshrelease)
109- [cloudfoundry/cf-release](https://github.com/cloudfoundry/cf-release/tree/master/jobs/etcd)
110
111**Projects using etcd**
112
113- [binocarlos/yoda](https://github.com/binocarlos/yoda) - etcd + ZeroMQ
114- [calavera/active-proxy](https://github.com/calavera/active-proxy) - HTTP Proxy configured with etcd
115- [derekchiang/etcdplus](https://github.com/derekchiang/etcdplus) - A set of distributed synchronization primitives built upon etcd
116- [go-discover](https://github.com/flynn/go-discover) - service discovery in Go
117- [gleicon/goreman](https://github.com/gleicon/goreman/tree/etcd) - Branch of the Go Foreman clone with etcd support
118- [garethr/hiera-etcd](https://github.com/garethr/hiera-etcd) - Puppet hiera backend using etcd
119- [mattn/etcd-vim](https://github.com/mattn/etcd-vim) - SET and GET keys from inside vim
120- [mattn/etcdenv](https://github.com/mattn/etcdenv) - "env" shebang with etcd integration
121- [kelseyhightower/confd](https://github.com/kelseyhightower/confd) - Manage local app config files using templates and data from etcd
122- [configdb](https://git.autistici.org/ai/configdb/tree/master) - A REST relational abstraction on top of arbitrary database backends, aimed at storing configs and inventories.
123- [fleet](https://github.com/coreos/fleet) - Distributed init system
124- [kubernetes/kubernetes](https://github.com/kubernetes/kubernetes) - Container cluster manager introduced by Google.
125- [mailgun/vulcand](https://github.com/mailgun/vulcand) - HTTP proxy that uses etcd as a configuration backend.
126- [duedil-ltd/discodns](https://github.com/duedil-ltd/discodns) - Simple DNS nameserver using etcd as a database for names and records.
127- [skynetservices/skydns](https://github.com/skynetservices/skydns) - RFC compliant DNS server
128- [xordataexchange/crypt](https://github.com/xordataexchange/crypt) - Securely store values in etcd using GPG encryption
129- [spf13/viper](https://github.com/spf13/viper) - Go configuration library, reads values from ENV, pflags, files, and etcd with optional encryption
130- [lytics/metafora](https://github.com/lytics/metafora) - Go distributed task library
131- [ryandoyle/nss-etcd](https://github.com/ryandoyle/nss-etcd) - A GNU libc NSS module for resolving names from etcd.
132