The Equinix Metal cloud bare-metal machine driver for Docker.
This repository is Maintained meaning that this software is supported by Equinix Metal and its community - available to use in production environments.
Usage
You can provision bare-metal hosts once you have built and installed the docker-machine driver. The binary will be placed in your $PATH
directory.
Test that the installation worked by typing in:
docker-machine create --driver metal
You can find the supported arguments by running docker-machine create -d metal --help
(Equinix Metal specific arguments are shown below):
Argument |
Default |
Description |
Environment |
Config |
--metal-api-key |
|
Deprecated API Key flag (use auth token) |
METAL_API_KEY |
|
--metal-auth-token |
|
Equinix Metal Authentication Token |
METAL_AUTH_TOKEN |
token or auth-token |
--metal-billing-cycle |
hourly |
Equinix Metal billing cycle, hourly or monthly |
METAL_BILLING_CYCLE |
|
--metal-facility-code |
|
Equinix Metal facility code |
METAL_FACILITY_CODE |
facility |
--metal-hw-reservation-id |
|
Equinix Metal Reserved hardware ID |
METAL_HW_ID |
|
--metal-metro-code |
|
Equinix Metal metro code ("dc" is used if empty and facility is not set) |
METAL_METRO_CODE |
metro |
--metal-os |
ubuntu_20_04 |
Equinix Metal OS |
METAL_OS |
operating-system |
--metal-plan |
c3.small.x86 |
Equinix Metal Server Plan |
METAL_PLAN |
plan |
--metal-project-id |
|
Equinix Metal Project Id |
METAL_PROJECT_ID |
project |
--metal-spot-instance |
|
Request a Equinix Metal Spot Instance |
METAL_SPOT_INSTANCE |
|
--metal-spot-price-max |
|
The maximum Equinix Metal Spot Price |
METAL_SPOT_PRICE_MAX |
|
--metal-termination-time |
|
The Equinix Metal Instance Termination Time |
METAL_TERMINATION_TIME |
|
--metal-ua-prefix |
|
Prefix the User-Agent in Equinix Metal API calls with some 'product/version' |
METAL_UA_PREFIX |
|
--metal-userdata |
|
Path to file with cloud-init user-data |
METAL_USERDATA |
|
Where denoted, values may be loaded from the environment or from the ~/.config/equinix/metal.yaml
file which can be created with the Equinix Metal CLI.
In order to support existing installations, a Packet branded binary is also available with each release. When the packet
binary is used, all METAL
environment variables and metal
arguments should be substituted for PACKET
and packet
, respectively.
Example usage
This creates the following:
$ docker-machine create sloth \
--driver metal --metal-api-key=$API_KEY --metal-os=ubuntu_20_04 --metal-project-id=$PROJECT --metal-metro-code "ny" --metal-plan "c3.small.x86"
Creating CA: /home/alex/.docker/machine/certs/ca.pem
Creating client certificate: /home/alex/.docker/machine/certs/cert.pem
Running pre-create checks...
Creating machine...
(sloth) Creating SSH key...
(sloth) Provisioning Equinix Metal server...
(sloth) Created device ID $DEVICE, IP address 147.x.x.x
(sloth) Waiting for Provisioning...
Waiting for machine to be running, this may take a few minutes...
Detecting operating system of created instance...
Waiting for SSH to be available...
Detecting the provisioner...
Provisioning with ubuntu(systemd)...
Installing Docker...
Copying certs to the local machine directory...
Copying certs to the remote machine...
Setting Docker configuration on the remote daemon...
Checking connection to Docker...
Docker is up and running!
To see how to connect your Docker Client to the Docker Engine running on this virtual machine, run: docker-machine env sloth
Provision time can take several minutes
At this point you can now docker-machine env sloth
and then start using your Docker bare-metal host!
Development
Building
Pre-reqs: docker-machine
and make
-
Install the Golang SDK https://golang.org/dl/ (at least 1.11 required for modules support
-
Download the source-code with git clone http://github.com/equinix/docker-machine-driver-metal.git
-
Build and install the driver:
cd docker-machine-driver-metal
make
sudo make install
Now you will now be able to specify a -driver
of metal
to docker-machine
commands.
Debugging
To monitor the Docker debugging details and the Equinix Metal API calls:
go build
PACKNGO_DEBUG=1 PATH=`pwd`:$PATH docker-machine \
--debug create -d metal \
--metal-auth-token=$METAL_AUTH_TOKEN \
--metal-project-id=$METAL_PROJECT \
foo
Release Process
This project adheres to Semantic Versioning.
Releases are handled by GitHub Workflows and goreleaser.
To push a new release, checkout the commit that you want released and: make tag version=v0.2.3
. Robots handle the rest.
Maintainers should verify that the release notes convey to users all of the notable changes between releases, in a human readable way.
The format for each release should be based on Keep a Changelog.
Releases and Changes
See https://github.com/equinix/docker-machine-driver-metal/releases for the latest releases, install archives, and the project changelog.