 Documentation
      ¶
      Documentation
      ¶
    
    
  
    
  
    Overview ¶
Package main is a simple wrapper of the real etcd entrypoint package (located at github.com/coreos/etcd/etcdmain) to ensure that etcd is still "go getable"; e.g. `go get github.com/coreos/etcd` works as expected and builds a binary in $GOBIN/etcd
This package should NOT be extended or modified in any way; to modify the etcd binary, work in the `github.com/coreos/etcd/etcdmain` package.
       Directories
      ¶
      Directories
      ¶
    
    | Path | Synopsis | 
|---|---|
| Package alarm manages health status alarms in etcd. | Package alarm manages health status alarms in etcd. | 
| Package auth provides client role authentication for accessing keys in etcd. | Package auth provides client role authentication for accessing keys in etcd. | 
| 
          
            authpb
            
            
          
           Package authpb is a generated protocol buffer package. | Package authpb is a generated protocol buffer package. | 
| Package client provides bindings for the etcd APIs. | Package client provides bindings for the etcd APIs. | 
| 
          
            integration
            
            
          
           Package integration implements tests built upon embedded etcd, focusing on the correctness of the etcd v2 client. | Package integration implements tests built upon embedded etcd, focusing on the correctness of the etcd v2 client. | 
| Package clientv3 implements the official Go etcd client for v3. | Package clientv3 implements the official Go etcd client for v3. | 
| 
          
            clientv3util
            
            
          
           Package clientv3util contains utility functions derived from clientv3. | Package clientv3util contains utility functions derived from clientv3. | 
| 
          
            concurrency
            
            
          
           Package concurrency implements concurrency operations on top of etcd such as distributed locks, barriers, and elections. | Package concurrency implements concurrency operations on top of etcd such as distributed locks, barriers, and elections. | 
| 
          
            integration
            
            
          
           Package integration implements tests built upon embedded etcd, and focuses on correctness of etcd client. | Package integration implements tests built upon embedded etcd, and focuses on correctness of etcd client. | 
| 
          
            leasing
            
            
          
           Package leasing serves linearizable reads from a local cache by acquiring exclusive write access to keys through a client-side leasing protocol. | Package leasing serves linearizable reads from a local cache by acquiring exclusive write access to keys through a client-side leasing protocol. | 
| 
          
            mirror
            
            
          
           Package mirror implements etcd mirroring operations. | Package mirror implements etcd mirroring operations. | 
| 
          
            namespace
            
            
          
           Package namespace is a clientv3 wrapper that translates all keys to begin with a given prefix. | Package namespace is a clientv3 wrapper that translates all keys to begin with a given prefix. | 
| 
          
            naming
            
            
          
           Package naming provides an etcd-backed gRPC resolver for discovering gRPC services. | Package naming provides an etcd-backed gRPC resolver for discovering gRPC services. | 
| 
          
            ordering
            
            
          
           Package ordering is a clientv3 wrapper that caches response header revisions to detect ordering violations from stale responses. | Package ordering is a clientv3 wrapper that caches response header revisions to detect ordering violations from stale responses. | 
| 
          
            yaml
            
            
          
           Package yaml handles yaml-formatted clientv3 configuration data. | Package yaml handles yaml-formatted clientv3 configuration data. | 
| Package compactor implements automated policies for compacting etcd's mvcc storage. | Package compactor implements automated policies for compacting etcd's mvcc storage. | 
| contrib
       | |
| 
          
            raftexample
            
            command
          
           raftexample is a simple KV store using the raft and rafthttp libraries. | raftexample is a simple KV store using the raft and rafthttp libraries. | 
| 
          
            recipes
            
            
          
           Package recipe contains experimental client-side distributed synchronization primitives. | Package recipe contains experimental client-side distributed synchronization primitives. | 
| 
          
            systemd/etcd2-backup-coreos
            
            command
          
          
         | |
| Package discovery provides an implementation of the cluster discovery that is used by etcd. | Package discovery provides an implementation of the cluster discovery that is used by etcd. | 
| Package e2e implements tests built upon etcd binaries, and focus on end-to-end testing. | Package e2e implements tests built upon etcd binaries, and focus on end-to-end testing. | 
| Package embed provides bindings for embedding an etcd server in a program. | Package embed provides bindings for embedding an etcd server in a program. | 
| Package error describes errors in etcd project. | Package error describes errors in etcd project. | 
| etcdctl is a command line application that controls etcd. | etcdctl is a command line application that controls etcd. | 
| 
          
            ctlv2
            
            
          
           Package ctlv2 contains the main entry point for the etcdctl for v2 API. | Package ctlv2 contains the main entry point for the etcdctl for v2 API. | 
| 
          
            ctlv2/command
            
            
          
           Package command is a set of libraries for etcdctl commands. | Package command is a set of libraries for etcdctl commands. | 
| 
          
            ctlv3
            
            
          
           Package ctlv3 contains the main entry point for the etcdctl for v3 API. | Package ctlv3 contains the main entry point for the etcdctl for v3 API. | 
| 
          
            ctlv3/command
            
            
          
           Package command is a set of libraries for etcd v3 commands. | Package command is a set of libraries for etcd v3 commands. | 
| Package etcdmain contains the main entry point for the etcd binary. | Package etcdmain contains the main entry point for the etcd binary. | 
| Package etcdserver defines how etcd servers interact and store their states. | Package etcdserver defines how etcd servers interact and store their states. | 
| 
          
            api
            
            
          
           Package api manages the capabilities and features that are exposed to clients by the etcd cluster. | Package api manages the capabilities and features that are exposed to clients by the etcd cluster. | 
| 
          
            api/etcdhttp
            
            
          
           Package etcdhttp implements HTTP transportation layer for etcdserver. | Package etcdhttp implements HTTP transportation layer for etcdserver. | 
| 
          
            api/v2http
            
            
          
           Package v2http provides etcd client and server implementations. | Package v2http provides etcd client and server implementations. | 
| 
          
            api/v2http/httptypes
            
            
          
           Package httptypes defines how etcd's HTTP API entities are serialized to and deserialized from JSON. | Package httptypes defines how etcd's HTTP API entities are serialized to and deserialized from JSON. | 
| 
          
            api/v2v3
            
            
          
           Package v2v3 provides a ServerV2 implementation backed by clientv3.Client. | Package v2v3 provides a ServerV2 implementation backed by clientv3.Client. | 
| 
          
            api/v3client
            
            
          
           Package v3client provides clientv3 interfaces from an etcdserver. | Package v3client provides clientv3 interfaces from an etcdserver. | 
| 
          
            api/v3election
            
            
          
           Package v3election provides a v3 election service from an etcdserver. | Package v3election provides a v3 election service from an etcdserver. | 
| 
          
            api/v3election/v3electionpb
            
            
          
           Package v3electionpb is a generated protocol buffer package. | Package v3electionpb is a generated protocol buffer package. | 
| 
          
            api/v3election/v3electionpb/gw
            
            
          
           Package v3electionpb is a reverse proxy. | Package v3electionpb is a reverse proxy. | 
| 
          
            api/v3lock
            
            
          
           Package v3lock provides a v3 locking service from an etcdserver. | Package v3lock provides a v3 locking service from an etcdserver. | 
| 
          
            api/v3lock/v3lockpb
            
            
          
           Package v3lockpb is a generated protocol buffer package. | Package v3lockpb is a generated protocol buffer package. | 
| 
          
            api/v3lock/v3lockpb/gw
            
            
          
           Package v3lockpb is a reverse proxy. | Package v3lockpb is a reverse proxy. | 
| 
          
            api/v3rpc
            
            
          
           Package v3rpc implements etcd v3 RPC system based on gRPC. | Package v3rpc implements etcd v3 RPC system based on gRPC. | 
| 
          
            api/v3rpc/rpctypes
            
            
          
           Package rpctypes has types and values shared by the etcd server and client for v3 RPC interaction. | Package rpctypes has types and values shared by the etcd server and client for v3 RPC interaction. | 
| 
          
            auth
            
            
          
           Package auth implements etcd authentication. | Package auth implements etcd authentication. | 
| 
          
            etcdserverpb
            
            
          
           Package etcdserverpb is a generated protocol buffer package. | Package etcdserverpb is a generated protocol buffer package. | 
| 
          
            etcdserverpb/gw
            
            
          
           Package etcdserverpb is a reverse proxy. | Package etcdserverpb is a reverse proxy. | 
| 
          
            membership
            
            
          
           Package membership describes individual etcd members and clusters of members. | Package membership describes individual etcd members and clusters of members. | 
| 
          
            stats
            
            
          
           Package stats defines a standard interface for etcd cluster statistics. | Package stats defines a standard interface for etcd cluster statistics. | 
| Package integration implements tests built upon embedded etcd, and focus on etcd correctness. | Package integration implements tests built upon embedded etcd, and focus on etcd correctness. | 
| Package lease provides an interface and implementation for time-limited leases over arbitrary resources. | Package lease provides an interface and implementation for time-limited leases over arbitrary resources. | 
| 
          
            leasehttp
            
            
          
           Package leasehttp serves lease renewals made through HTTP requests. | Package leasehttp serves lease renewals made through HTTP requests. | 
| 
          
            leasepb
            
            
          
           Package leasepb is a generated protocol buffer package. | Package leasepb is a generated protocol buffer package. | 
| Package mvcc defines etcd's stable MVCC storage. | Package mvcc defines etcd's stable MVCC storage. | 
| 
          
            backend
            
            
          
           Package backend defines a standard interface for etcd's backend MVCC storage. | Package backend defines a standard interface for etcd's backend MVCC storage. | 
| 
          
            mvccpb
            
            
          
           Package mvccpb is a generated protocol buffer package. | Package mvccpb is a generated protocol buffer package. | 
| pkg
       | |
| 
          
            adt
            
            
          
           Package adt implements useful abstract data types. | Package adt implements useful abstract data types. | 
| 
          
            contention
            
            
          
           Package contention provides facilities for detecting system contention. | Package contention provides facilities for detecting system contention. | 
| 
          
            cors
            
            
          
           Package cors handles cross-origin HTTP requests (CORS). | Package cors handles cross-origin HTTP requests (CORS). | 
| 
          
            cpuutil
            
            
          
           Package cpuutil provides facilities for detecting cpu-specific features. | Package cpuutil provides facilities for detecting cpu-specific features. | 
| 
          
            crc
            
            
          
           Package crc provides utility function for cyclic redundancy check algorithms. | Package crc provides utility function for cyclic redundancy check algorithms. | 
| 
          
            debugutil
            
            
          
           Package debugutil includes utility functions for debugging. | Package debugutil includes utility functions for debugging. | 
| 
          
            expect
            
            
          
           Package expect implements a small expect-style interface | Package expect implements a small expect-style interface | 
| 
          
            fileutil
            
            
          
           Package fileutil implements utility functions related to files and paths. | Package fileutil implements utility functions related to files and paths. | 
| 
          
            flags
            
            
          
           Package flags implements command-line flag parsing. | Package flags implements command-line flag parsing. | 
| 
          
            httputil
            
            
          
           Package httputil provides HTTP utility functions. | Package httputil provides HTTP utility functions. | 
| 
          
            idutil
            
            
          
           Package idutil implements utility functions for generating unique, randomized ids. | Package idutil implements utility functions for generating unique, randomized ids. | 
| 
          
            ioutil
            
            
          
           Package ioutil implements I/O utility functions. | Package ioutil implements I/O utility functions. | 
| 
          
            logutil
            
            
          
           Package logutil includes utilities to facilitate logging. | Package logutil includes utilities to facilitate logging. | 
| 
          
            mock/mockstorage
            
            
          
           Package mockstorage provides mock implementations for etcdserver's storage interface. | Package mockstorage provides mock implementations for etcdserver's storage interface. | 
| 
          
            mock/mockstore
            
            
          
           Package mockstore provides mock structures for the etcd store package. | Package mockstore provides mock structures for the etcd store package. | 
| 
          
            mock/mockwait
            
            
          
           Package mockwait provides mock implementations for pkg/wait. | Package mockwait provides mock implementations for pkg/wait. | 
| 
          
            netutil
            
            
          
           Package netutil implements network-related utility functions. | Package netutil implements network-related utility functions. | 
| 
          
            osutil
            
            
          
           Package osutil implements operating system-related utility functions. | Package osutil implements operating system-related utility functions. | 
| 
          
            pathutil
            
            
          
           Package pathutil implements utility functions for handling slash-separated paths. | Package pathutil implements utility functions for handling slash-separated paths. | 
| 
          
            pbutil
            
            
          
           Package pbutil defines interfaces for handling Protocol Buffer objects. | Package pbutil defines interfaces for handling Protocol Buffer objects. | 
| 
          
            report
            
            
          
           Package report generates human-readable benchmark reports. | Package report generates human-readable benchmark reports. | 
| 
          
            runtime
            
            
          
           Package runtime implements utility functions for runtime systems. | Package runtime implements utility functions for runtime systems. | 
| 
          
            schedule
            
            
          
           Package schedule provides mechanisms and policies for scheduling units of work. | Package schedule provides mechanisms and policies for scheduling units of work. | 
| 
          
            srv
            
            
          
           Package srv looks up DNS SRV records. | Package srv looks up DNS SRV records. | 
| 
          
            stringutil
            
            
          
           Package stringutil exports string utility functions. | Package stringutil exports string utility functions. | 
| 
          
            testutil
            
            
          
           Package testutil provides test utility functions. | Package testutil provides test utility functions. | 
| 
          
            tlsutil
            
            
          
           Package tlsutil provides utility functions for handling TLS. | Package tlsutil provides utility functions for handling TLS. | 
| 
          
            transport
            
            
          
           Package transport implements various HTTP transport utilities based on Go net package. | Package transport implements various HTTP transport utilities based on Go net package. | 
| 
          
            types
            
            
          
           Package types declares various data types and implements type-checking functions. | Package types declares various data types and implements type-checking functions. | 
| 
          
            wait
            
            
          
           Package wait provides utility functions for polling, listening using Go channel. | Package wait provides utility functions for polling, listening using Go channel. | 
| proxy
       | |
| 
          
            grpcproxy
            
            
          
           Package grpcproxy is an OSI level 7 proxy for etcd v3 API requests. | Package grpcproxy is an OSI level 7 proxy for etcd v3 API requests. | 
| 
          
            grpcproxy/adapter
            
            
          
           Package adapter provides gRPC adapters between client and server gRPC interfaces without needing to go through a gRPC connection. | Package adapter provides gRPC adapters between client and server gRPC interfaces without needing to go through a gRPC connection. | 
| 
          
            grpcproxy/cache
            
            
          
           Package cache exports functionality for efficiently caching and mapping `RangeRequest`s to corresponding `RangeResponse`s. | Package cache exports functionality for efficiently caching and mapping `RangeRequest`s to corresponding `RangeResponse`s. | 
| 
          
            httpproxy
            
            
          
           Package httpproxy implements etcd httpproxy. | Package httpproxy implements etcd httpproxy. | 
| 
          
            tcpproxy
            
            
          
           Package tcpproxy is an OSI level 4 proxy for routing etcd clients to etcd servers. | Package tcpproxy is an OSI level 4 proxy for routing etcd clients to etcd servers. | 
| Package raft sends and receives messages in the Protocol Buffer format defined in the raftpb package. | Package raft sends and receives messages in the Protocol Buffer format defined in the raftpb package. | 
| 
          
            raftpb
            
            
          
           Package raftpb is a generated protocol buffer package. | Package raftpb is a generated protocol buffer package. | 
| 
          
            rafttest
            
            
          
           Package rafttest provides functional tests for etcd's raft implementation. | Package rafttest provides functional tests for etcd's raft implementation. | 
| Package rafthttp implements HTTP transportation layer for etcd/raft pkg. | Package rafthttp implements HTTP transportation layer for etcd/raft pkg. | 
| Package snap stores raft nodes' states with snapshots. | Package snap stores raft nodes' states with snapshots. | 
| 
          
            snappb
            
            
          
           Package snappb is a generated protocol buffer package. | Package snappb is a generated protocol buffer package. | 
| Package store defines etcd's in-memory key/value store. | Package store defines etcd's in-memory key/value store. | 
| tools
       | |
| 
          
            benchmark
            
            command
          
           benchmark is a program for benchmarking etcd v3 API performance. | benchmark is a program for benchmarking etcd v3 API performance. | 
| 
          
            benchmark/cmd
            
            
          
           Package cmd implements individual benchmark commands for the benchmark utility. | Package cmd implements individual benchmark commands for the benchmark utility. | 
| 
          
            etcd-dump-db
            
            command
          
           etcd-dump-db inspects etcd db files. | etcd-dump-db inspects etcd db files. | 
| 
          
            etcd-dump-logs
            
            command
          
           etcd-dump-logs is a program for analyzing etcd server write ahead logs. | etcd-dump-logs is a program for analyzing etcd server write ahead logs. | 
| 
          
            functional-tester/etcd-agent
            
            command
          
           etcd-agent is a daemon for controlling an etcd process via HTTP RPC. | etcd-agent is a daemon for controlling an etcd process via HTTP RPC. | 
| 
          
            functional-tester/etcd-agent/client
            
            
          
           Package client provides a client implementation to control an etcd-agent. | Package client provides a client implementation to control an etcd-agent. | 
| 
          
            functional-tester/etcd-runner
            
            command
          
           etcd-runner is a program for testing etcd clientv3 features against a fault injected cluster. | etcd-runner is a program for testing etcd clientv3 features against a fault injected cluster. | 
| 
          
            functional-tester/etcd-runner/command
            
            
          
           Package command implements individual etcd-runner commands for the etcd-runner utility. | Package command implements individual etcd-runner commands for the etcd-runner utility. | 
| 
          
            functional-tester/etcd-tester
            
            command
          
           etcd-tester is a single controller for all etcd-agents to manage an etcd cluster and simulate failures. | etcd-tester is a single controller for all etcd-agents to manage an etcd cluster and simulate failures. | 
| 
          
            local-tester/bridge
            
            command
          
           Package main is the entry point for the local tester network bridge. | Package main is the entry point for the local tester network bridge. | 
| Package version implements etcd version parsing and contains latest version information. | Package version implements etcd version parsing and contains latest version information. | 
| Package wal provides an implementation of a write ahead log that is used by etcd. | Package wal provides an implementation of a write ahead log that is used by etcd. | 
| 
          
            walpb
            
            
          
           Package walpb is a generated protocol buffer package. | Package walpb is a generated protocol buffer package. | 
 Click to show internal directories. 
   Click to hide internal directories. 
