architect.yml
For users of Visual Studio Code, check out the Architect extension!
Components described using this syntax can leverage the CLI and Kubernetes cluster to provision and update production-grade environments on-demand or via automation.
name: component-name
description: Human-readable description of my component
keywords:
- additional
- search
- keywords
secrets:
db_user:
required: true
description: Human-readable description of my secret
default: default-value
db_pass: shorthand-default-value
db_name: example
services:
database:
image: postgres:11
interfaces:
pg:
port: 5432
protocol: postgres
environment:
POSTGRES_USER: ${{ secrets.db_user }}
POSTGRES_PASSWORD: ${{ secrets.db_pass }}
POSTGRES_DATABASE: ${{ secrets.db_name }}
my-api:
depends_on:
- database
build:
context: ./path/to/docker/build/context
dockerfile: ./relative/to/context/Dockerfile
command: npm start
entrypoint: entrypoint override for dockerfile ENTRYPOINT
interfaces:
public:
port: 8080
protocol: http
admin: 8081
liveness_probe:
command: curl --fail localhost:8080/health
environment:
DB_ADDR: ${{ services.database.interfaces.pg.url }}/${{ secrets.db_name }}
DB_USER: ${{ secrets.db_user }}
DB_PASS: ${{ secrets.db_pass }}
my-frontend:
build:
context: .
interfaces:
webapp:
port: 3000
ingress:
subdomain: app
liveness_probe:
# Curl must be installed in the container
command: curl --fail localhost:3000/health
environment:
API_ADDR: ${{ services['my-api'].interfaces.public.url }}
# Local configuration for my-frontend service
debug:
command: npm run dev
volumes:
src:
description:
Mount the src directory to the container from the host when running
locally
host_path: ./src
mount_path: /usr/app/src
Configuration options
name
Name of the component that can be resolved by others. Component names must be unique within an Architect account.
description
(optional) A human-readable description of the component. This will be rendered when others view the component so that they know what it should be used for.
keywords
(optional) Additional search terms to be used when the component is indexed so that others can find it more easily.
services
A dictionary of named runtimes for the component. Each service described in an
architect.yml
file will be automatically deployed to your Kubernetes cluster
and registered with your service mesh and API gateway as needed.
Learn more about configuring services
dependencies
A key-value store of components and their respective tags that this component depends on. Dependency referencing and resolution is a key feature of Architect that enables distribute teams to collaborate without having to get into the specifics of how to operate dependencies.
Learn more about configuring dependencies
tasks
A dictionary of named tasks included with the component. Each task described in
an architect.yml
file will run on its specified schedule and/or be made
available as an executable via Architects CLI upon deployment.
Learn more about configuring tasks
secrets
(optional) A dictionary of named, configurable fields for the component. Each secret can include a description so that others know what to assign for values, a default value for when deployers don’t specify one, and an indication as to whether or not a value is required.