4.7 KiB
| title | description | keywords | |
|---|---|---|---|
| DTR architecture | Learn about the architecture of Docker Trusted Registry. |
|
Docker Trusted Registry (DTR) is a Dockerized application that runs on a Docker Universal Control Plane cluster.
Containers
When you install DTR on a node, the following containers are started:
| Name | Description |
|---|---|
| dtr-api-<replica_id> | Executes the DTR business logic. It serves the DTR web application, and API |
| dtr-etcd-<replica_id> | A key-value store for persisting DTR configuration settings |
| dtr-jobrunner-<replica_id> | Runs cleanup jobs in the background |
| dtr-nginx-<replica_id> | Receives http and https requests and proxies them to other DTR components. By default it listens to ports 80 and 443 of the host |
| dtr-notary-server-<replica_id> | Receives, validates, and serves content trust metadata, and is consulted when pushing or pulling to DTR with content trust enabled |
| dtr-notary-signer-<replica_id> | Performs server-side timestamp and snapshot signing for content trust metadata |
| dtr-registry-<replica_id> | Implements the functionality for pulling and pushing Docker images. It also handles how images are stored |
| dtr-rethinkdb-<replica_id> | A database for persisting repository metadata |
All these components are for internal use of DTR. Don't use them in your applications.
Networks
To allow containers to communicate, when installing DTR the following networks are created:
| Name | Type | Description |
|---|---|---|
| dtr-br | bridge | Allows DTR components on the same node to communicate with each other in a secure way |
| dtr-ol | overlay | Allows DTR components running on different nodes to communicate, to replicate DTR data |
Volumes
DTR uses these named volumes for persisting data:
| Volume name | Description |
|---|---|
| dtr-ca-<replica_id> | Root key material for the DTR root CA that issues certificates |
| dtr-etcd-<replica_id> | DTR configuration data |
| dtr-notary-<replica_id> | Certificate and keys for the Notary components |
| dtr-registry-<replica_id> | Docker images data, if DTR is configured to store images on the local filesystem |
| dtr-rethink-<replica_id> | Repository metadata |
| dtr-nfs-registry-<replica_id> | Docker images data, if DTR is configured to store images on NFS |
You can customize the volume driver used for these volumes, by creating the volumes before installing DTR. During the installation, DTR checks which volumes don't exist in the node, and creates them using the default volume driver.
By default, the data for these volumes can be found at
/var/lib/docker/volumes/<volume-name>/_data.
Image storage
By default, Docker Trusted Registry stores images on the filesystem of the node where it is running.
You can also configure DTR to use these storage backends:
- NFS
- Amazon S3
- Cleversafe
- OpenStack Swift
- Microsoft Azure
For highly available installations, you should use a cloud storage system instead of an NFS mount, since they usually have better performance.
High-availability support
For load balancing and high-availability, you can install multiple replicas of DTR, and join them to create a cluster. Learn more about high availability.
