2016-10-25 18:11:35 -07:00
# Consul [![Build Status](https://travis-ci.org/hashicorp/consul.svg?branch=master)](https://travis-ci.org/hashicorp/consul) [![Join the chat at https://gitter.im/hashicorp-consul/Lobby](https://badges.gitter.im/hashicorp-consul/Lobby.svg)](https://gitter.im/hashicorp-consul/Lobby?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
2016-10-07 00:29:26 +00:00
2016-01-13 17:44:01 -05:00
* Website: https://www.consul.io
2016-10-06 17:31:40 -07:00
* Chat: [Gitter ](https://gitter.im/hashicorp-consul/Lobby )
2014-04-14 12:19:28 -07:00
* Mailing list: [Google Groups ](https://groups.google.com/group/consul-tool/ )
2014-04-14 11:45:31 -07:00
2014-04-16 22:04:28 -07:00
Consul is a tool for service discovery and configuration. Consul is
distributed, highly available, and extremely scalable.
2014-04-14 11:45:31 -07:00
2014-04-16 22:04:28 -07:00
Consul provides several key features:
2014-04-14 11:45:31 -07:00
2014-04-16 22:04:28 -07:00
* **Service Discovery** - Consul makes it simple for services to register
themselves and to discover other services via a DNS or HTTP interface.
External services such as SaaS providers can be registered as well.
* **Health Checking** - Health Checking enables Consul to quickly alert
2014-04-14 11:45:31 -07:00
operators about any issues in a cluster. The integration with service
discovery prevents routing traffic to unhealthy hosts and enables service
level circuit breakers.
2014-04-16 22:04:28 -07:00
* **Key/Value Storage** - A flexible key/value store enables storing
dynamic configuration, feature flagging, coordination, leader election and
more. The simple HTTP API makes it easy to use anywhere.
2014-04-14 11:45:31 -07:00
2014-04-16 22:04:28 -07:00
* **Multi-Datacenter** - Consul is built to be datacenter aware, and can
support any number of regions without complex configuration.
2014-04-14 11:45:31 -07:00
2018-01-23 12:32:54 -08:00
Consul runs on Linux, Mac OS X, FreeBSD, Solaris, and Windows. A commercial
version called [Consul Enterprise ](https://www.hashicorp.com/products/consul )
is also available.
2014-04-14 11:45:31 -07:00
## Quick Start
2016-05-12 21:38:43 -07:00
An extensive quick start is viewable on the Consul website:
2014-04-14 11:45:31 -07:00
2016-01-13 17:44:01 -05:00
https://www.consul.io/intro/getting-started/install.html
2014-04-14 11:45:31 -07:00
## Documentation
Full, comprehensive documentation is viewable on the Consul website:
2016-01-13 17:44:01 -05:00
https://www.consul.io/docs
2014-04-14 11:45:31 -07:00
## Developing Consul
2015-01-24 23:58:04 +01:00
If you wish to work on Consul itself, you'll first need [Go ](https://golang.org )
2017-08-29 15:31:31 -07:00
installed (version 1.9+ is _required_ ). Make sure you have Go properly installed,
2015-01-24 23:58:04 +01:00
including setting up your [GOPATH ](https://golang.org/doc/code.html#GOPATH ).
2014-04-14 11:45:31 -07:00
Next, clone this repository into `$GOPATH/src/github.com/hashicorp/consul` and
then just type `make` . In a few moments, you'll have a working `consul` executable:
```
$ make
...
$ bin/consul
...
```
2017-06-09 01:11:38 -07:00
*Note: `make` will build all os/architecture combinations. Set the environment variable `CONSUL_DEV=1` to build it just for your local machine's os/architecture, or use `make dev` .*
2017-06-05 15:46:36 -07:00
2016-08-26 21:51:07 -07:00
*Note: `make` will also place a copy of the binary in the first part of your `$GOPATH` .*
2014-04-14 11:45:31 -07:00
2018-01-05 16:47:14 -05:00
You can run tests by typing `make test` . The test suite may fail if
over-parallelized, so if you are seeing stochastic failures try
`GOTEST_FLAGS="-p 2 -parallel 2" make test` .
2014-04-14 11:45:31 -07:00
If you make any changes to the code, run `make format` in order to automatically
format the code according to Go standards.
2015-01-24 23:58:04 +01:00
2016-07-19 17:13:25 -07:00
## Vendoring
2016-08-08 18:53:35 -07:00
Consul currently uses [govendor ](https://github.com/kardianos/govendor ) for
2017-10-23 12:42:00 +02:00
vendoring and [vendorfmt ](https://github.com/magiconair/vendorfmt ) for formatting
`vendor.json` to a more merge-friendly "one line per package" format.