Merge pull request #653 from ryanbreen/master

Grammatical cleanups to doc/agent/services
This commit is contained in:
Armon Dadgar 2015-01-29 11:11:56 -08:00
commit c8c5e308a1

View File

@ -3,16 +3,16 @@ layout: "docs"
page_title: "Service Definition" page_title: "Service Definition"
sidebar_current: "docs-agent-services" sidebar_current: "docs-agent-services"
description: |- description: |-
One of the main goals of service discovery is to provide a catalog of available services. To that end, the agent provides a simple service definition format to declare the availability of a service, and to potentially associate it with a health check. A health check is considered to be application level if it associated with a service. A service is defined in a configuration file, or added at runtime over the HTTP interface. One of the main goals of service discovery is to provide a catalog of available services. To that end, the agent provides a simple service definition format to declare the availability of a service and to potentially associate it with a health check. A health check is considered to be application level if it associated with a service. A service is defined in a configuration file or added at runtime over the HTTP interface.
--- ---
# Services # Services
One of the main goals of service discovery is to provide a catalog of available One of the main goals of service discovery is to provide a catalog of available
services. To that end, the agent provides a simple service definition format services. To that end, the agent provides a simple service definition format
to declare the availability of a service, and to potentially associate it with to declare the availability of a service and to potentially associate it with
a health check. A health check is considered to be application level if it a health check. A health check is considered to be application level if it
associated with a service. A service is defined in a configuration file, associated with a service. A service is defined in a configuration file
or added at runtime over the HTTP interface. or added at runtime over the HTTP interface.
## Service Definition ## Service Definition
@ -36,37 +36,40 @@ A service definition that is a script looks like:
} }
``` ```
A service definition must include a `name`, and may optionally provide A service definition must include a `name` and may optionally provide
an `id`, `tags`, `address`, `port`, and `check`. The `id` is set to the `name` if not an `id`, `tags`, `address`, `port`, and `check`. The `id` is set to the `name` if not
provided. It is required that all services have a unique ID per node, so if names provided. It is required that all services have a unique ID per node, so if names
might conflict then unique ID's should be provided. might conflict then unique IDs should be provided.
The `tags` is a list of opaque value to Consul, but can be used to distinguish The `tags` property is a list of values that are opaque to Consul but can be used to
between "master" or "slave" nodes, different versions, or any other service level labels. distinguish between "master" or "slave" nodes, different versions, or any other service
The `address` can be used to specify a service specific IP address. By default, level labels.
the IP address of the agent is used, and this does not need to be provided.
The `port` can be used as well to make a service oriented architecture The `address` field can be used to specify a service-specific IP address. By
simpler to configure. This way the address and port of a service can default, the IP address of the agent is used, and this does not need to be provided.
The `port` field can be used as well to make a service-oriented architecture
simpler to configure; this way, the address and port of a service can
be discovered. be discovered.
A service can have an associated health check. This is a powerful feature as A service can have an associated health check. This is a powerful feature as
it allows a web balancer to gracefully remove failing nodes, or a database it allows a web balancer to gracefully remove failing nodes, a database
to replace a failed slave, etc. The health check is strongly integrated in to replace a failed slave, etc. The health check is strongly integrated in
the DNS interface as well. If a service is failing its health check or a the DNS interface as well. If a service is failing its health check or a
node has any failing system-level check, the DNS interface will omit that node has any failing system-level check, the DNS interface will omit that
node from any service query. node from any service query.
There is more information about [checks here](/docs/agent/checks.html). The The check must be of the script, HTTP, or TTL type. If it is a script type, `script`
check must be of the script, HTTP or TTL type. If it is a script type, `script` and and `interval` must be provided. If it is a HTTP type, `http` and
`interval` must be provided. If it is a HTTP type, `http` and
`interval` must be provided. If it is a TTL type, then only `ttl` must be `interval` must be provided. If it is a TTL type, then only `ttl` must be
provided. The check name is automatically generated as provided. The check name is automatically generated as
`service:<service-id>`. If there are multiple service checks registered, the `service:<service-id>`. If there are multiple service checks registered, the
ID will be generated as `service:<service-id>:<num>`, where `<num>` is an ID will be generated as `service:<service-id>:<num>` where `<num>` is an
incrementing number starting from `1`. incrementing number starting from `1`.
Note: there is more information about [checks here](/docs/agent/checks.html).
To configure a service, either provide it as a `-config-file` option to the To configure a service, either provide it as a `-config-file` option to the
agent, or place it inside the `-config-dir` of the agent. The file must agent or place it inside the `-config-dir` of the agent. The file must
end in the ".json" extension to be loaded by Consul. Check definitions can end in the ".json" extension to be loaded by Consul. Check definitions can
also be updated by sending a `SIGHUP` to the agent. Alternatively, the also be updated by sending a `SIGHUP` to the agent. Alternatively, the
service can be registered dynamically using the [HTTP API](/docs/agent/http.html). service can be registered dynamically using the [HTTP API](/docs/agent/http.html).