Preheat
This document will help you experience how to use Dragonfly's three preheat methods, namely Open API preheat, console preheat and harbor preheat.
Open API
Use Open API to preheat.
Create personal access token
Click the ADD PERSONAL ACCESS TOKENS
button to create personal access token.
Name: Set your token a descriptive name.
Description: Set a description.
Expiration: Set your token an expiration.
Scopes: Select the access permissions for the token.
Click SAVE
and copy the token and store it. For your security, it doesn't display again.
Preheat image
Use Open API for preheating image. First create a POST request for preheating.
scope: Select the scope of preheat as needed.
Single Seed Peer: Preheat to a seed peer.
All Seed Peers: Preheat to each seed peer in the P2P cluster.
All Peers: Preheat to each peer in the P2P cluster.
scheduler_cluster_ids: Specify the preheated scheduler cluster id,
if scheduler_cluster_ids
is empty, it means preheating all scheduler clusters.
curl --location --request POST 'http://dragonfly-manager:8080/oapi/v1/jobs' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer your_dragonfly_personal_access_token' \
--data-raw '{
"type": "preheat",
"args": {
"type": "image",
"url": "https://index.docker.io/v2/library/alpine/manifests/3.19",
"username": "your_registry_username",
"password": "your_registry_password",
"scope": "single_seed_peer",
"scheduler_cluster_ids":[1]
}
}'
The command-line log returns the preheat job id.
{
"id": 1,
"created_at": "0001-01-01T00:00:00Z",
"updated_at": "0001-01-01T00:00:00Z",
"task_id": "group_9523f30a-877d-41f7-a25f-0854228341f6",
"bio": "",
"type": "preheat",
"state": "PENDING",
"args": {
"platform": "",
"scope": "single_seed_peer",
"tag": "",
"type": "image",
"url": "https://dockerpull.org/v2/library/alpine/manifests/3.19"
},
"result": null,
"scheduler_clusters": [
{
"id": 1,
"created_at": "2024-12-11T07:57:44Z",
"updated_at": "2024-12-11T07:57:44Z",
"name": "cluster-1"
}
]
}
Polling the preheating status with job id.
curl --request GET 'http://dragonfly-manager:8080/oapi/v1/jobs/1' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer your_dragonfly_personal_access_token'
If the status is SUCCESS
, the preheating is successful.
{
"id": 1,
"created_at": "0001-01-01T00:00:00Z",
"updated_at": "0001-01-01T00:00:00Z",
"task_id": "group_9523f30a-877d-41f7-a25f-0854228341f6",
"bio": "",
"type": "preheat",
"state": "SUCCESS",
"args": {
"platform": "",
"scope": "single_seed_peer",
"tag": "",
"type": "image",
"url": "https://dockerpull.org/v2/library/alpine/manifests/3.19"
},
"result": null,
"scheduler_clusters": [
{
"id": 1,
"created_at": "2024-12-11T07:57:44Z",
"updated_at": "2024-12-11T07:57:44Z",
"name": "cluster-1"
}
]
}
Preheat file
Use Open API for preheating file. First create a POST request for preheating.
scope: Select the scope of preheat as needed.
Single Seed Peer: Preheat to a seed peer.
All Seed Peers: Preheat to each seed peer in the P2P cluster.
All Peers: Preheat to each peer in the P2P cluster.
scheduler_cluster_ids: Specify the preheated scheduler cluster id,
if scheduler_cluster_ids
is empty, it means preheating all scheduler clusters.
curl --location --request POST 'http://dragonfly-manager:8080/oapi/v1/jobs' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer your_dragonfly_personal_access_token' \
--header 'Authorization: token your_example.com_personal_access_token' \
--data-raw '{
"type": "preheat",
"args": {
"type": "file",
"url": "https://example.com",
"scope": "single_seed_peer",
"scheduler_cluster_ids":[1]
}
}'
The command-line log returns the preheat job id.
{
"id": 1,
"created_at": "2024-12-11T08:30:12Z",
"updated_at": "2024-12-11T08:30:51Z",
"task_id": "group_4dd1da54-96ca-48ff-8f20-4fae665f677f",
"bio": "",
"type": "preheat",
"state": "PENDING",
"args": {
"platform": "",
"scope": "single_seed_peer",
"type": "file",
"url": "https://example.com"
},
"scheduler_clusters": [
{
"id": 1,
"created_at": "2024-12-11T07:57:44Z",
"updated_at": "2024-12-11T07:57:44Z",
"name": "cluster-1"
}
]
}
Polling the preheating status with job id.
curl --request GET 'http://dragonfly-manager:8080/oapi/v1/jobs/1' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer your_dragonfly_personal_access_token'
If the status is SUCCESS
, the preheating is successful.
{
"id": 1,
"created_at": "2024-12-11T08:30:12Z",
"updated_at": "2024-12-11T08:30:51Z",
"task_id": "group_4dd1da54-96ca-48ff-8f20-4fae665f677f",
"bio": "",
"type": "preheat",
"state": "SUCCESS",
"args": {
"platform": "",
"scope": "single_seed_peer",
"type": "file",
"url": "https://example.com"
},
"scheduler_clusters": [
{
"id": 1,
"created_at": "2024-12-11T07:57:44Z",
"updated_at": "2024-12-11T07:57:44Z",
"name": "cluster-1"
}
]
}
Console
Use console for preheating image.
Preheat
Display all of the preheat tasks.
Create Preheat
Click the ADD PREHEAT
button to create preheat task.
Description: Set a description.
Clusters: Used for clusters that need to be preheat.
URL: URL address used to specify the resource to be preheat.
Scope: Select the scope of preheat as needed.
Single Seed Peer: Preheat to a seed peer.
All Seed Peers: Preheat to each seed peer in the P2P cluster.
All Peers: Preheat to each peer in the P2P cluster.
Tag: When the URL of the preheat task are the same but the Tag are different, they will be distinguished based on the tag and the generated preheat task will be different.
Filtered Query Params: By setting the filteredQueryParams parameter, you can specify the file type of the resource that needs to be preheated. The filteredQueryParams is used to generate a unique preheat task and filter unnecessary query parameters in the URL.
Click the SAVE
to generate the preheat task,the generated preheat task will not return results immediately and
you need to wait.
Preheat Success
If the status is SUCCESS
, the preheating is successful.
Preheat Failure
If the status is FAILURE
, the preheating is failure and an error log is displayed.
Harbor
Use harbor for preheating image, please refer to the harbor documentation for details.
Configure self-signed certificates for registry
Notice: If harbor is not configured self-signed certificates, please ignore the following.
To support preheating for harbor with self-signed certificates, the Manager configuration needs to be modified.
Configure manager.yaml
, the default path is /etc/dragonfly/manager.yaml
,
refer to manager config.
Notice:
yourdomain.crt
is Harbor's ca.crt.
job:
# Preheat configuration.
preheat:
tls:
# insecureSkipVerify controls whether a client verifies the server's certificate chain and hostname.
insecureSkipVerify: false
# # caCert is the CA certificate for preheat tls handshake, it can be path or PEM format string.
caCert: /etc/certs/yourdomain.crt
Skip TLS verification, set job.preheat.tls.insecureSkipVerify
to true.
job:
# Preheat configuration.
preheat:
tls:
# insecureSkipVerify controls whether a client verifies the server's certificate chain and hostname.
insecureSkipVerify: true
# # caCert is the CA certificate for preheat tls handshake, it can be path or PEM format string.
# caCert: ''
Create personal access token
Click the ADD PERSONAL ACCESS TOKENS
button to create personal access token.
Name: Set your token a descriptive name.
Description: Set your token a descriptive information.
Expiration: Set your token an expiration.
Scopes: Select the access permissions for the token.
Click SAVE
and copy the token and store it. For your security, it doesn't display again.
Create instance
Open the harbor UI, go to Distributions
item under Administration
and click the NEW INSTANCE
button to create create instance.
Step 1: Enter REST address of the Dragonfly Manager.
Step 2: Auth Mode selects OAuth for authentication.
Step 3: Enter personsal assess token.
Click the TEST CONNECTION
button to test the connectivity of the creating instance.
If the connectivity testing is successful, click the OK
button to save the creating instance.
Notice: Instance status must be
Healthy
.
Create P2P provider policy
Go to Projects
and open your project from the project list, and open the P2P Preheat
tab.
Click the NEW POLICY
button to create P2P provider policy.
Scope: Select the scope of preheat as needed.
Single Seed Peer: Preheat to a seed peer.
All Seed Peers: Preheat to each seed peer in the P2P cluster.
All Peers: Preheat to each peer in the P2P cluster.
Step 2: Enter the cluster id of Dragonfly Manager in Cluster IDs
to specify the preheated cluster.
If Cluster IDs
is empty, it means to preheat all clusters.
Executions Preheat policy
Click the EXECUTE
to execute the preheating task.
If the status is SUCCESS, the preheating is successful.
Click the executions ID
to view the detailed information of the preheating task, and click the Logs icon to view the log.
The expected output is as follows.