-
Notifications
You must be signed in to change notification settings - Fork 82
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
enhancement: extend the p2p preheat policy
Signed-off-by: suhan.zcy <[email protected]>
- Loading branch information
suhan.zcy
committed
Nov 6, 2024
1 parent
235a0c6
commit 8c96752
Showing
2 changed files
with
89 additions
and
0 deletions.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,89 @@ | ||
# Proposal: P2P Preheat Enhancement | ||
|
||
Author: [Chenyu Zhang](https://github.com/chlins) | ||
|
||
## Abstract | ||
|
||
This proposal aims to expand the p2p preheat policy to accommodate a wider range of configurations and scenarios. | ||
To achieve this, two options will be added to the policy: preheat scope and extra attributes. | ||
|
||
## Motivation | ||
|
||
The current Harbor p2p preheat policy offers basic options like filters and triggers. However, these are tailored | ||
from Harbor's perspective, omitting the p2p or preheat viewpoints, particularly in today's AI-driven scenarios. | ||
Users might need to preheat images to p2p clusters with additional p2p related configurations or parameters. | ||
This proposal aims to broaden the p2p preheat policy to accommodate more flexible configurations and scenarios. | ||
|
||
## Solution | ||
|
||
Add the following two options to the p2p preheat policy: | ||
|
||
- scope: The scope of the preheat, which can be set to "single_peer" or "all_peers". The default value is "single_peer". | ||
- extra_attrs: The additional attributes that can be used to configure the preheat for vendor or provider specified arguments. | ||
This is a key-value pair as JSON format, and it's optional. | ||
|
||
## Goal | ||
|
||
1. Some common and abstractable parameters that are not strongly bound to P2P providers can be abstracted as a field in a policy. | ||
2. Also provides an extended parameter for users to specify provider-related or unique configurations. | ||
|
||
## Personas and User Stories | ||
|
||
This section lists the user stories regarding this enhancements for the different personas interacting with the p2p preheat. | ||
|
||
* Personas | ||
|
||
P2P Preheat is a System Administrator and Project Administrator operation in Harbor. | ||
|
||
* User Stories | ||
|
||
1. As a system/project administrator, I can create/update a p2p preheat policy with the scope set to "single_peer" or "all_peers". | ||
2. As a system/project administrator, I can create/update a p2p preheat policy with extra attributes to configure the preheat for vendor or provider specified arguments. | ||
(e.g: I can set the cluster ids for dragonfly provider) | ||
|
||
* Scenario Cases | ||
|
||
1. If the user using the dragonfly as p2p provider, when he sets the scope to "single_peer", the preheat will only preheats the image to one peer in the cluster. | ||
2. If the user using the dragonfly as p2p provider, when he sets the scope to "all_peers", the preheat will preheats the image to all peers in the cluster. | ||
3. If the user using the dragonfly as p2p provider, when he sets the extra_attrs to {"cluster_ids": [1, 2, 3]}, the preheat will only preheats the image to the specified clusters. | ||
|
||
## Scheme Changes | ||
|
||
The schema changes are as follows: | ||
|
||
```sql | ||
ALTER TABLE p2p_preheat_policy ADD COLUMN IF NOT EXISTS scope varchar(255); | ||
ALTER TABLE p2p_preheat_policy ADD COLUMN IF NOT EXISTS extra_attrs json; | ||
``` | ||
|
||
## UI | ||
|
||
The UI changes are as follows: | ||
|
||
1. Add a new field named "Scope" to the p2p preheat policy page, which can be set to "single_peer" or "all_peers". | ||
2. Add a new field named "Extra Attributes" to the p2p preheat policy page, which is a key-value pair as JSON format. | ||
|
||
![p2p preheat policy](../images/p2p/p2p-preheat-policy-extra-attrs.jpg) | ||
|
||
## API | ||
|
||
No any breaking change for preheat policy, and not introduce the new APIs, just add the new fields to payload for existing APIs. | ||
|
||
Payload example: | ||
|
||
```json | ||
{ | ||
"creation_time": "2024-10-30T07:11:36.349Z", | ||
"enabled": true, | ||
"filters": "[{\"type\":\"repository\",\"value\":\"**\"},{\"type\":\"tag\",\"value\":\"**\"}]", | ||
"id": 4, | ||
"name": "test", | ||
"project_id": 1, | ||
"provider_id": 2, | ||
"provider_name": "d7y", | ||
"scope": "single_peer", | ||
"trigger": "{\"type\":\"manual\",\"trigger_setting\":{\"cron\":\"\"}}", | ||
"extra_attrs": "{\"cluster_ids\":[1,2,3]}", | ||
"update_time": "2024-10-30T07:46:14.497Z" | ||
} | ||
``` |