etcd3
etcd3 aims to be (with its first stable release) a high-quality, production-ready client for the Protocol Buffer-based etcdv3 API. It includes load balancing, reconnections, transactions, software transactional memory, high-level query builders and lease management, watchers, mocking, and is type-safe for TypeScript consumers.
Quickstart
Install via:
npm install --save etcd3
Start CRUD-ing!
const { Etcd3 } = require('etcd3');
const client = new Etcd3();
(() => {
await client.put('foo').value('bar');
const fooValue = await client.get('foo').string();
console.log('foo was:', fooValue);
const allFValues = client.getAll().prefix('f').keys()
console.log('all our keys starting with "f":', allFValues);
await client.delete().all();
})
API Documentation
Our TypeDoc docs are available here.
Our test cases are also readable.
Running tests
$ npm install
$ docker-compose up
$ npm test
$ docker-compose down
Contributing
Running tests for this module requires running an etcd3 server locally. The tests try to use the default port initially, and you can configure this by setting the ETCD_ADDR
environment variable, like export ETCD_ADDR=localhost:12345
.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.