Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Bayer-Group/etcd-aws-cluster
A container to assist in managing a etcd2 cluster from an Amazon auto scaling group
https://github.com/Bayer-Group/etcd-aws-cluster
Last synced: about 2 months ago
JSON representation
A container to assist in managing a etcd2 cluster from an Amazon auto scaling group
- Host: GitHub
- URL: https://github.com/Bayer-Group/etcd-aws-cluster
- Owner: Bayer-Group
- License: bsd-3-clause
- Created: 2015-05-14T19:52:02.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2017-02-01T01:09:05.000Z (almost 8 years ago)
- Last Synced: 2024-08-03T09:03:22.617Z (5 months ago)
- Language: Shell
- Size: 28.3 KB
- Stars: 202
- Watchers: 20
- Forks: 102
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- top-pharma50 - **Bayer-Group/etcd-aws-cluster** - Clause "New" or "Revised" License <img src='https://github.com/HubTou/topgh/blob/main/icons/last.png'> 2017-02-01 01:09:05 | (Ranked by starred repositories)
- top-life-sciences - **Bayer-Group/etcd-aws-cluster** - Clause "New" or "Revised" License <img src='https://github.com/HubTou/topgh/blob/main/icons/last.png'> 2017-02-01 01:09:05 | (Ranked by starred repositories)
README
etcd-aws-cluster
==============This container serves to assist in the creation of an etcd (2.x) cluster from an AWS auto scaling group. It writes a file to /etc/sysconfig/etcd-peers that contains parameters for etcd:
- ETCD_INITIAL_CLUSTER_STATE
- either `new` or `existing`
- used to specify whether we are creating a new cluster or joining an existing one
- ETCD_NAME
- the name of the machine joining the etcd cluster
- this is obtained by getting the instance if from amazon of the host (e.g. i-694fad83)
- ETCD_INITIAL_CLUSTER
- this is a list of the machines (id and ip) expected to be in the cluster, including the new machine
- e.g., "i-5fc4c9e1=http://10.0.0.1:2380,i-694fad83=http://10.0.0.2:2380"This file can then be loaded as an EnvironmentFile in an etcd2 drop-in to properly configure etcd2:
```
[Service]
EnvironmentFile=/etc/sysconfig/etcd-peers
```Workflow
--------- get the instance id and ip from amazon
- fetch the autoscaling group this machine belongs to
- obtain the ip of every member of the auto scaling group
- for each member of the autoscaling group detect if they are running etcd and if so who they see as members of the clusterif no machines respond OR there are existing peers but my instance id is listed as a member of the cluster
- assume that this is a new cluster
- write a file using the ids/ips of the autoscaling group
else- assume that we are joining an existing cluster
- check to see if any machines are listed as being part of the cluster but are not part of the autoscaling group
- if so remove it from the etcd cluster
- add this machine to the current cluster
- write a file using the ids/ips obtained from query etcd for members of the clusterUsage
-----```docker run -v /etc/sysconfig/:/etc/sysconfig/ monsantoco/etcd-aws-cluster```
Environment Variables
* PROXY_ASG - If specified forces into proxy=on and uses the vaue of PROXY_ASG as the autocaling group that contains the master servers
* ASG_BY_TAG - If specified in conjunction with PROXY_ASG uses the value of PROXY_ASG to look up the server by the Tag Name
* ETCD_CLIENT_SCHEME - defaults to http
* ETCD_PEER_SCHEME - defaults to httpDemo
----We have created a CloudFomation script that shows sample usage of this container for creating a simple etcd cluster: https://gist.github.com/tj-corrigan/3baf86051471062b2fb7