User shall have ROLE_ADMIN to any access to the System jobs.
System jobs allow admins to create and easily launch system scripts for different needs:
- to get some system statistics or system information about the current Platform state (for example, collect information about all storages that have specific size, list all unattached EBS volumes, set some s3 bucket policy to all storages, etc.)
- to create some sort of automation scripts - with help of
Kubectl
,pipe
CLI, Cloud Pipeline API, Cloud CLI
System jobs solution uses the existing Cloud-Pipeline infrastructure, to reduce number of preparation steps to be done to get desire output.
In a nutshell, the approach to perform the System jobs is the following:
- There are:
- prepared system pipeline that contains system jobs scripts. Admin can add new scripts or edit/delete existing ones. Also, pipeline config contains:
Kubernetes
service account to performkubectl
commands from such pipeline during the system job run- special assign policy that allows to assign the pipeline to one of the running system node (
MASTER
node, for example). It is convenient as no additional instances (waiting or initializing ones) are required to perform a job
- prepared special docker image that includes pre-installed packages such as system packages (
curl
,nano
,git
, etc.),kubectl
,pipe
CLI, Cloud CLI (AWS
/Azure
/GCP
),LustreFS
client
- prepared system pipeline that contains system jobs scripts. Admin can add new scripts or edit/delete existing ones. Also, pipeline config contains:
- When admin launches a system job - the system instance according to specified assign policy (
MASTER
instance, by default) is found for the system job pipeline performing - At the selected system instance, the docker-container is launched from the special docker-image for system jobs
- In the launched docker-container, the system job script is being performed
The following System Preferences are currently used to configure the System jobs behaviour:
system.jobs.pipeline.id
- ID of the prepared system pipeline that contains system jobs scriptssystem.jobs.scripts.location
- path to the system scripts directory inside the pipeline repo. Default value issrc/system-jobs
system.jobs.output.pipeline.task
- name of the task at the Run logs page of the system pipeline that is launched for the system job. Task contains system job output results. Default value isSystemJob
To create a new System job, admin shall:
- Open the pipeline defined in the
system.jobs.pipeline.id
System Preference, e.g.:
- Open the CODE tab inside the pipeline:
Navigate to the folder defined as the folder for system jobs scripts (specified viasystem.jobs.scripts.location
System Preference) - In the opened folder, you can view previously created scripts:
- Add a new system script - you can create it manually or upload the existing one from the local workstation.
We will create a new script manually.
Click the "+ NEW FILE" button:
- In the appeared pop-up, specify a new script name and commit message for the pipeline changes (optionally).
For our example, we will create a simple bash script that listss3
object storages using AWS Cloud CLI or outputs storage content if the storage name was specified as a parameter. So, the script will be calledstorages_listing
:
Click the OK button to confirm. - Click the just-created file to edit it:
- In the appeared pop-up, specify the script itself and save changes:
Specify a commit message, e.g.:
- New system script is created:
Entry point for the usage of existing System script jobs is the System jobs subtab of the SYSTEM MANAGEMENT tab in the System settings:
Here, admin can view the whole list of stored system scripts, select any script and launch it or observe script's runs history.
- a - list of all stored scripts. Click any to select it
- b - selected script name
- c - list of selected script's runs history
- d - button to refresh runs history
- e - button to launch the script:
- f - view output logs of the script's specific launch
- g - view run's details that used for the script launch
For our example, we will use a simple bash script created in the section above.
To run a script from the System jobs panel:
- Click the script in the list.
- Click the LAUNCH button to perform a script as is (without parameters), e.g.:
- Just-launched script run will appear in the runs history:
Jobs states are similar to pipelines states. - Once the script is performed, the state will be changed to Success:
- Click the script run's row or the button LOG to view the script performing output:
- Script logs will appear:
- If needed, you may download these logs as a text file by click the corresponding button - DOWNLOAD:
To run a script with parameters:
- Click the script in the list.
- Click the v button near the LAUNCH and select the item Launch with parameters, e.g.:
- In the appeared form, specify parameters for the script separated by spaces (in the format
<parameter_1> <parameter_2> ...
) and click the LAUNCH button:
- Just-launched script will appear in the runs history:
- Script performing logs can be viewed in the same way as was described in the example above.
To view run's details that was used for the script launch:
- Click the DETAILS button in the script run's row:
- The Run logs page will be opened:
- Here you can also view system job results - click the task
SystemJob
(default name, it can be changed via the System Preferencesystem.jobs.output.pipeline.task
):