A RESTful implementation of the DCRX Docker library.
Project description
dcrx-api
DCRX-API is a RESTful implementation of the dcrx library, allowing you to create Docker images on request! DCRX-API extends dcrx, providing integrations with the Docker API and dcrx that allow images to be built by making REST requests.
DCRX-API also includes basic JWT authorization and user management (no-RBAC), and is intended to be deployed as an internal-facing service. dcrx also provides OpenAPI documentation to make getting started intuitive, and features integrations with SQLite, Postgres, and MySQL for storing and managing users.
Setup and Installation
DCRX-API is available both as a Docker image and as a PyPi package. For local use, we recommend using PyPi, Python 3.10+, and a virtual environment. To install, run:
python -m venv ~/.dcrx && \
source ~/.dcrx/bin/activate && \
pip install dcrx-api
To get the Docker image, run:
docker pull adalundhe/dcrx-api:latest
Getting Started
DCRX-API requires a slew of environmental variables in order to run correctly. These include:
DCRX_API_MAX_MEMORY_PERCENT_USAGE=50 # The percent of system memory DCRX-API and Docker image builds created by DCRX-API can use. If exceeded, new jobs will be rejected and requests will return a 400 error.
DCRX_API_JOB_PRUNE_INTERVAL='1s' # How often dcrx-api checks for done, failed, or cancelled jobs to remove from in-memory storage.
DCRX_API_JOB_MAX_AGE='1m'= # Time before done, failed, or cancelled jobs are pruned from in-memory storage.
DCRX_API_JOB_POOL_SIZE=10 # Maximum number of concurrent builds. Default is 10.
DCRX_API_JOB_WORKERS=4 # Number of workers to use per-job. Default is the number os OS threads.
DCRX_API_TOKEN_EXPIRATION='15m' # Time for JWT authorization token to expire. Default is 15 minutes.
DCRX_API_SECRET_KEY=testingthis # Initial secret used to hash user passwords.
DCRX_API_AUTH_ALGORITHM=HS256 # Algorithm to use for hashing user passwords.
DCRX_API_DATABASE_TYPE=sqlite # Type of database to use. Default is sqlite and options are mysql, asyncpg, and sqlite.
DCRX_API_DATABASE_USER=admin # Username used for database connection authentication
DCRX_API_DATABASE_PASSWORD=test1234 # Password used for database connection authentrication
DCRX_API_DATABASE_NAME=dcrx # Name of database to use for storing users. Default is dcrx.
DCRX_API_DATABASE_URI=sqlite+aiosqlite:///dcrx # URL/URI of SQL database for storing users and job metadata.
DCRX_API_DATABASE_PORT=3369 # Port of SQL database for storing users and job metadata.
DOCKER_REGISTRY_URI=https://docker.io/v1/myrepo/test-images # Default Docker image registry to push images to.
DOCKER_REGISTRY_USERNAME=test # Default Username to authenticate Docker pushes to the provided registry.
DOCKER_REGISTRY_PASSWORD=test-repo-password # Default Password to authenticate Docker pushes to the provided registry.
Prior to starting the server, we recommend seeding the database with an initial user. To do so, run the command:
dcrx-api database initialize --username $USERNAME --password $PASSWORD --first-name $FIRST_NAME --last-name $LAST_NAME --email $EMAIL
If you've chosen to run the Docker image, this step is taken care of for you, with the default user being:
username: admin
password: dcrxadmin1*
first-name: admin
last-name: user
email: admin@admin.com
Next run:
dcrx-api server run
and navigate to localhost:2277/docs
, where you'll find dcrx-api's OpenAPI documentation.
Authenticating and Building an Image
From here, we'll need to authenticate using the initial user we created above. Open the tab for /users/login
, and for the username
and password
fields enter the username and password of the initial user, then click Execute
. A 200
status response containg the initial user's username and id should return.
Next navigate to the /jobs/images/create
tab. As before, we'll need to fill out some data. Go ahead and copy paste the below into the input for the request body:
{
"name": "hello-world",
"tag": "latest",
"layers": [
{
"layer_type": "stage",
"base": "python",
"tag": "3.11-slim"
},
{
"layer_type": "entrypoint",
"command": [
"echo",
"Hello world!"
]
}
]
}
A dcrx-api image build request requires, at-minimum, a name
, tag
and one or more layer
objects, which will be processed and build in-order of appearance. Note that each layer object almost exactly corresponds to its dcrx
call. The above corresponds exactly to:
from dcrx import Image
hello_world = Image('hello-world')
hello_world.stage(
'python',
'3.11-slim'
).entrypoint([
'echo',
'Hello world!'
])
Go ahead and submit the request via the Execute
button. This will start a job to build the specified image and push it to the repository specified in dcrx-api's environmental variables.
Note that dcrx-api doesn't wait for the image to be built, instead returning a JobMetadata
response with a status code of 200
, including the job_id
. Building images is time-intensive and could potentially bog down a server, so dcrx-api builds and pushes images in the background. We can use the job_id
of a Job to make further GET
requests to the /jobs/images/{job_id}/get
endpoint to monitor and check how our job is progressing. If we need to cancel a job for any reason, we can simple make a DELETE
request to /jobs/images/{job_id}/cancel
.
Running the Docker Image
To run the Docker image, we recommend first creating a .env
file with the required environment variables noted above. Then run the image:
docker run -p 2277:2277 --env-file .env --privileged dcrx-api:latest
Deploying via Helm
DCRX-API has a minimal helm chart to help you scale up when ready. To begin, first create a Kuberenetes secret as below:
kubectl create secret generic dcrx-api-secrets --from-literal="DCRX_API_SECRET_KEY=$DCRX_API_SECRET_KEY" --from-literal="DOCKER_REGISTRY_USERNAME=$DOCKER_REGISTRY_USERNAME" --from-literal="DOCKER_REGISTRY_PASSWORD=$DOCKER_REGISTRY_PASSWORD"
Then install the provided helm chart:
helm install dcrx-api helm/dcrx-api/ --values helm/dcrx-api/values.yml
The chart creates three replica dcrx-api pods, a LoadBalancer service, and Nginx ingress to get you up and running in your Kubernetes cluster!
Notes and Gotchas
-
Does dcrx-api require a volume to run? - Yes. While dcrx-api builds images in-memory, Docker still (frustratingly) requires that a physical file be present in the build directory. This means that, if running dcrx-api in Docker or via Kubernetes, you will need to have a volume with the correct permissions mounted.
-
Does the dcrx-api Docker image require root? - Currently yes. The dcrx-api image is based on the latest version of Docker's
dind
image, which runs as and requires root privlidges. We're working on getting the rootless version ofdind
working though! -
Can I push to a registry besides the default? - Yes. New image job requests can be submitted with optional Registry configuration. For example:
{
"name": "hello-world",
"tag": "latest",
"registry": {
"registry_url": "https://docker.io/v1/mytest/registry",
"registry_user": "DockerUser100",
"registry_password": "MyDockerHubToken999*"
},
"layers": [
{
"layer_type": "stage",
"base": "python",
"tag": "3.11-slim"
},
{
"layer_type": "entrypoint",
"command": [
"echo",
"Hello world!"
]
}
]
}
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file dcrx-api-0.2.7.tar.gz
.
File metadata
- Download URL: dcrx-api-0.2.7.tar.gz
- Upload date:
- Size: 30.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.17
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d8d6fdd96a74571fcaf0e27b38e0b8e8a44332f0e5cb8f5be79134ecce8227fa |
|
MD5 | f5382bbec7f6d232be195d249268b6d2 |
|
BLAKE2b-256 | 0410e9521b2406a86a427d85be44fd37e9b2e4ff851f4337a7da53ac59ff892f |
File details
Details for the file dcrx_api-0.2.7-py3-none-any.whl
.
File metadata
- Download URL: dcrx_api-0.2.7-py3-none-any.whl
- Upload date:
- Size: 46.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.17
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 47e62db3de99acaa8aaae7ad7780ac95c13c9bdd3fbc03d91cff2b7702b4ac66 |
|
MD5 | 8064c13851731f1a53bd4539ecc95a74 |
|
BLAKE2b-256 | c2a7871694683c7fd4af7b2cdd976f220f5e6e8a1b5ff999ea6ceb97273e7db3 |