2021-08-30 19:03:20 +00:00
|
|
|
# Consul Developer Documentation
|
|
|
|
|
|
|
|
See [our contributing guide](../.github/CONTRIBUTING.md) to get started.
|
|
|
|
|
|
|
|
This directory contains documentation intended for anyone interested in
|
|
|
|
understanding, and contributing changes to, the Consul codebase.
|
|
|
|
|
|
|
|
## Overview
|
|
|
|
|
|
|
|
This documentation is organized into the following categories. Each category is
|
|
|
|
either a significant architectural layer, or major functional area of Consul.
|
|
|
|
These documents assume a basic understanding of Consul's feature set, which can
|
|
|
|
be found in the public [user documentation].
|
|
|
|
|
|
|
|
[user documentation]: https://www.consul.io/docs
|
|
|
|
|
|
|
|
![Overview](./overview.svg)
|
|
|
|
|
|
|
|
<sup>[source](./overview.mmd)</sup>
|
|
|
|
|
|
|
|
## Contents
|
|
|
|
|
|
|
|
1. [Command-Line Interface (CLI)](./cli)
|
|
|
|
1. [HTTP API](./http-api)
|
|
|
|
1. [Agent Configuration](./config)
|
|
|
|
1. [RPC](./rpc)
|
|
|
|
1. [Cluster Persistence](./persistence)
|
2023-05-15 11:34:36 +00:00
|
|
|
1. [Resources and Controllers](./resources)
|
2021-08-30 19:03:20 +00:00
|
|
|
1. [Client Agent](./client-agent)
|
|
|
|
1. [Service Discovery](./service-discovery)
|
|
|
|
1. [Service Mesh (Connect)](./service-mesh)
|
|
|
|
1. [Cluster Membership](./cluster-membership)
|
|
|
|
1. [Key/Value Store](./kv)
|
|
|
|
1. [ACL](./acl)
|
|
|
|
1. [Multi-Cluster Federation](./cluster-federation)
|
|
|
|
|
|
|
|
Also see the [FAQ](./faq.md).
|
|
|
|
|
2022-09-13 17:00:02 +00:00
|
|
|
## Other Docs
|
|
|
|
|
|
|
|
1. [Integration Tests](../test/integration/connect/envoy/README.md)
|
2023-03-20 18:26:43 +00:00
|
|
|
1. [Upgrade Tests](../test/integration/consul-container/test/upgrade/README.md)
|
2023-06-20 15:14:15 +00:00
|
|
|
1. [Remote Debugging Integration Tests](../test/integration/consul-container/test/debugging.md)
|
2022-09-13 17:00:02 +00:00
|
|
|
|
2021-08-30 19:03:20 +00:00
|
|
|
## Important Directories
|
|
|
|
|
|
|
|
Most top level directories contain Go source code. The directories listed below
|
|
|
|
contain other important source related to Consul.
|
|
|
|
|
|
|
|
* [ui] contains the source code for the Consul UI.
|
|
|
|
* [website] contains the source for [consul.io](https://www.consul.io/). A pull requests
|
|
|
|
can update the source code and Consul's documentation at the same time.
|
2023-04-19 16:19:29 +00:00
|
|
|
* [.github] contains the source for our CI and GitHub repository
|
2021-08-30 19:03:20 +00:00
|
|
|
automation.
|
|
|
|
* [.changelog] contains markdown files that are used by [hashicorp/go-changelog] to produce the
|
|
|
|
[CHANGELOG.md].
|
|
|
|
* [build-support] contains bash functions and scripts used to automate.
|
|
|
|
development tasks. Generally these scripts are called from the [GNUmakefile].
|
|
|
|
* [grafana] contains the source for a [Grafana dashboard] that can be used to
|
|
|
|
monitor Consul.
|
|
|
|
|
|
|
|
[ui]: https://github.com/hashicorp/consul/tree/main/ui
|
|
|
|
[website]: https://github.com/hashicorp/consul/tree/main/website
|
|
|
|
[.github]: https://github.com/hashicorp/consul/tree/main/.github
|
|
|
|
[.changelog]: https://github.com/hashicorp/consul/tree/main/.changelog
|
|
|
|
[hashicorp/go-changelog]: https://github.com/hashicorp/go-changelog
|
|
|
|
[CHANGELOG.md]: https://github.com/hashicorp/consul/blob/main/CHANGELOG.md
|
|
|
|
[build-support]: https://github.com/hashicorp/consul/tree/main/build-support
|
|
|
|
[GNUmakefile]: https://github.com/hashicorp/consul/tree/main/GNUmakefile
|
|
|
|
[Grafana dashboard]: https://grafana.com/grafana/dashboards
|
|
|
|
[grafana]: https://github.com/hashicorp/consul/tree/main/grafana
|
|
|
|
|
|
|
|
|
|
|
|
## Contributing to these docs
|
|
|
|
|
|
|
|
This section is meta documentation about contributing to these docs.
|
|
|
|
|
|
|
|
### Diagrams
|
|
|
|
|
|
|
|
The diagrams in these documents are created using the [mermaid-js live editor].
|
|
|
|
The [mermaid-js docs] provide a complete reference for how to create and edit
|
|
|
|
the diagrams. Use the [consul-mermaid-theme.json] (paste it into the Config tab
|
|
|
|
in the editor) to maintain a consistent Consul style for the diagrams.
|
|
|
|
|
|
|
|
[mermaid-js live editor]: https://mermaid-js.github.io/mermaid-live-editor/edit/
|
|
|
|
[mermaid-js docs]: https://mermaid-js.github.io/mermaid/
|
|
|
|
[consul-mermaid-theme.json]: ./consul-mermaid-theme.json
|