Create and submit a job to Nomad
In Nomad, the description of the job and all its requirements are maintained in a single file called the "job file". This job file resides locally on disk and it is highly recommended that you check job files into source control.
The general flow for submitting a job in Nomad is:
- Author a job file according to the job specification
- Plan and review changes with a Nomad server
- Submit the job file to a Nomad server
- (Optional) Review job status and logs
Here is a very basic example to get you started.
Author a job file
Nomad attempts to strike a balance between ease and expressiveness in its job
specification. Nomad also provides the nomad init
command to generate sample
job files. For more detailed information about the Nomad job specification,
please consult the Nomad documentation.
Here is a sample job file which runs a small docker container web server to start with.
This job file exists on your local workstation in plain text. When you are satisfied with this job file, you will plan and review the scheduler decision. It is generally a best practice to commit job files to source control, especially if you are working in a team.
Plan the job
Once the job file is authored, you probably want to preview the changes Nomad
will make when it runs. The nomad job plan
command invokes a dry-run of the
scheduler and output which scheduling decisions would take place.
Note that no action was taken. This job is not running. This is a complete dry-run and no allocations have taken place.
Submit the job
Assuming the output of the plan looks acceptable, now ask Nomad to execute the
job. This is done via the nomad job run
command. You can optionally supply the
modify index provided by the plan command to ensure no changes to this job have
taken place between our plan and now.
Now that the job is scheduled, it may or may not be running. You need to inspect the allocation status and logs to make sure the job started correctly. The next section on inspecting state details ways to examine this job's state.
Update and plan the job
When making updates to the job, it is best to always run the plan command and then the run command. For example:
After saving these changes to disk, run the nomad job plan
command:
Reserved port collisions
Because this job uses a static port, it is possible for some instances to not be placeable depending on the number of clients you have in your Nomad cluster. If your plan output contains:
This indicates that every feasible client in your cluster has or will have something placed at the requested port, leaving no place for some of these allocations to run. To resolve this, you need to reduce the requested count, add additional clients, or migrate from static ports to dynamic ports in your job specification.
Run the job
Now, assuming the output is okay, execute the nomad job run
command. Including
the check-index
parameter ensures that the job
was not changed between the plan and run phases.
For more details on advanced job updating strategies such as canary builds and build-green deployments, consult the documentation on job update strategies.