Getting Started¶
Getting started with docker¶
You need nomad and docker installed on your system
- Clone the repo
- Start 2 terminal sessions at the root of this repo
Run the following in the first terminal:
Make sure that docker volumes are available
You can use the provided.deployment/nomad/agent.hcl
as a reference
Remember to set theNOMAD_ADDR
environment variable to the address of your nomad cluster
nomad agent -dev -bind 0.0.0.0 -log-level INFO -config .deployment/nomad/agent.hcl
This will bring up a nomad environment with docker volumes enabled. See nomad docs for more info.
Run the following in the second terminal:
nomad namespace apply nomad-ops
This makes sure that the namespace nomad-ops exists.
Deploy Nomad-Ops to nomad by running:
nomad job run .deployment/nomad/docker.hcl
Access the Admin UI¶
Go to http://localhost:8080/_/.
This will bring you to the login screen of pocketbase.
Login using admin@nomad-ops.org
and simple-nomad-ops
.
You only need to access this UI to create additional users. The main UI is available at http://localhost:8080/
Access the Nomad-Ops UI¶
You can access the UI of Nomad-Ops at http://localhost:8080/ and use your newly created credentials to login.
By default the following user is created:
- email:
user@nomad-ops.org
- password:
simple-nomad-ops
You can change the default user by setting the environment variables
DEFAULT_USER_EMAIL
andDEFAULT_USER_PASSWORD
.The Admin User
admin@nomad-ops.org
is only capable to access the pocketbase ui athttp://{your-nomad-ops-host}/_/
. To access the Nomad-Ops UI you need to use a normal user.
Installation Notes¶
Nomad Ops can be installed inside or outside of your nomad-cluster.
If you install Nomad Ops inside your cluster you can leverage the Workload Identities of Nomad v1.5.x.
Keep in mind that Nomad Ops stores its data on the local file system. Please use a NFS-mount or similar to enable scheduling around the cluster.
There are performace implications if using a network mount.
Prefer to use a local disk if possible.
For a simple deployment, consider restricting the deployment to a specific node.
Configuration¶
ENVIRONMENT Variable | Default | Description |
---|---|---|
DEFAULT_ADMIN_EMAIL | admin@nomad-ops.org | On first startup an admin user is created with this email |
DEFAULT_ADMIN_PASSWORD | simple-nomad-ops | On first startup an admin user is created with this password |
NOMAD_ADDR | '' | Nomad addr |
NOMAD_TOKEN | '' | Nomad token to access the Nomad API |
NOMAD_TOKEN_FILE | '' | If set will ignore NOMAD_TOKEN and read from this file instead |
TRACE | FALSE | If set to TRUE enables detailed logging |
SLACK_WEBHOOK_URL | '' | Set to your Webhook URL if you want to receive notifications about deployments |
SLACK_BASE_URL | 'localhost:3000/ui/' | included in the slack message as a link |
SLACK_ICON_SUCCESS | ':check:' | Icon to use for successful deployments |
SLACK_ICON_ERROR | ':check-no:' | Icon to use for unsuccessful deployments |
SLACK_ENV_INFO_TEXT | 'Sent by nomad-ops (dev)' | Send as a footer in the slack message |
There are a couple of Pocketbase settings that you can set as well. See here.
Email Settings¶
Pocketbase integrates a couple of workflows for user management (confirmation, password reset, ...). To use that please adjust the environment variables according to the docs. See here for the corresponding environment variables in Nomad-Ops.
Security¶
Deploy keys are saved in plain text. Please make sure that the application is only accessible by authorized personnel. This includes setting up TLS, users and a hardened runtime-environment.
Workflow¶
Nomad Ops pulls the desired state
from a git-repository on a regular basis. Additionally, certain events trigger a re-evaluation of the state as well.
After the desired state
has been fetched, the current state
is queried from the nomad
-cluster. The reconciler
performs the necessary steps to bring the cluster state
closer to the desired state
by adding, updating or deleting jobs.
User management¶
Users are currently managed by the admin interface of pocketbase
Restrictions¶
Nomad Ops does not perform any templating or rendering and expects the manifests in the repository to be ready-to-run
. Adjust your CI/CD pipeline to include the rendering step before you commit the file in the repository.
Do not store secrets in plain text in your repository. Consult the nomad docs on best practices to provide secrets to your jobs.