2014-04-19 13:49:20 -07:00
|
|
|
# Consul [![Build Status](https://travis-ci.org/hashicorp/consul.png)](https://travis-ci.org/hashicorp/consul)
|
2013-11-04 14:15:27 -08:00
|
|
|
|
2014-04-14 11:45:31 -07:00
|
|
|
* Website: http://www.consul.io
|
|
|
|
* IRC: `#consul` on Freenode
|
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
|
|
|
|
|
|
|
Consul runs on Linux, Mac OS X, and Windows. It is recommended to run the
|
2014-04-16 22:04:28 -07:00
|
|
|
Consul servers only on Linux, however.
|
2014-04-14 11:45:31 -07:00
|
|
|
|
|
|
|
## Quick Start
|
|
|
|
|
|
|
|
An extensive quick quick start is viewable on the Consul website:
|
|
|
|
|
2014-04-14 12:20:48 -07:00
|
|
|
http://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:
|
|
|
|
|
|
|
|
http://www.consul.io/docs
|
|
|
|
|
|
|
|
## 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)
|
2015-01-17 09:14:34 +01:00
|
|
|
installed (version 1.4+ 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:
|
|
|
|
|
|
|
|
```
|
2014-09-02 10:49:28 -07:00
|
|
|
$ go get -u ./...
|
2014-04-14 11:45:31 -07:00
|
|
|
$ make
|
|
|
|
...
|
|
|
|
$ bin/consul
|
|
|
|
...
|
|
|
|
```
|
|
|
|
|
|
|
|
*note: `make` will also place a copy of the binary in the first part of your $GOPATH*
|
|
|
|
|
|
|
|
You can run tests by typing `make test`.
|
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
### Building Consul on Windows
|
|
|
|
|
|
|
|
Make sure Go 1.4+ is installed on your system and that the Go command is in your
|
|
|
|
%PATH%.
|
|
|
|
|
|
|
|
For building Consul on Windows, you also need to have MinGW installed.
|
|
|
|
[TDM-GCC](http://tdm-gcc.tdragon.net/) is a simple bundle installer which has all
|
|
|
|
the required tools for building Consul with MinGW.
|
|
|
|
|
|
|
|
Install TDM-GCC and make sure it has been added to your %PATH%.
|
|
|
|
|
|
|
|
If all goes well, you should be able to build Consul by running `make.bat` from a
|
|
|
|
command prompt.
|
|
|
|
|
|
|
|
See also [golang/winstrap](https://github.com/golang/winstrap) and
|
|
|
|
[golang/wiki/WindowsBuild](https://github.com/golang/go/wiki/WindowsBuild)
|
|
|
|
for more information of how to set up a general Go build environment on Windows
|
|
|
|
with MinGW.
|
|
|
|
|