Attention: The EBRAINS drive will be unavailable for most of the weekend starting the 25th October. Although the Lab is availble while the Drive is down, files that are stored in the Drive will not be loaded and you will be unable to save documents directly on the Lab.


Changes for page User documentation

Last modified by alexisdurieux on 2022/01/27 15:00

From version 6.1
edited by alexisdurieux
on 2022/01/27 14:51
Change comment: There is no comment for this version
To version 1.1
edited by evareill
on 2021/04/28 11:57
Change comment: There is no comment for this version

Summary

Details

Page properties
Author
... ... @@ -1,1 +1,1 @@
1 -XWiki.alexisdurieux
1 +XWiki.evareill
Content
... ... @@ -17,6 +17,8 @@
17 17  
18 18  Why does each service provider need a Fenix service account? The reason is that the Principal Investigator who gets the Fenix service account is legally responsible for the jobs being run on the supercomputers and for not enabling the end-user to run unintended executables.
19 19  
20 +[[image:HPC Job Proxy diagram.jpg]]
21 +
20 20  == Use case ==
21 21  
22 22  1. Bob wants to do use an EBRAINS Application that requires supercomputing.
... ... @@ -38,6 +38,7 @@
38 38  1. The HPC Job Proxy logs the job results, and pushes the actual cost of the job run for Bob to the EBRAINS Quota Manager.
39 39  1. The HPC Job Proxy notifies the Application of the results of the job.
40 40  
43 +
41 41  == Sample transaction diagram ==
42 42  
43 43  [[image:ebrains-job-proxy-Job sequence.png]]
... ... @@ -49,7 +49,7 @@
49 49  
50 50  * Submit a job: **POST /api/jobs/**
51 51  
52 -To submit a job to the proxy, you need to provide the following information as part of the POST JSON body:
55 +​​​​​​​To submit a job to the proxy, you need to provide the following information as part of the POST JSON body:
53 53  
54 54  * **job_def** - JSON: The Unicore job definition. For more information, please visit the [[__Unicore documentation__>>url:https://sourceforge.net/p/unicore/wiki/Job_Description/]]
55 55  * **site** - string: The Fenix site on which to run the job.
... ... @@ -69,6 +69,7 @@
69 69  JURON
70 70  )))
71 71  
75 +
72 72  * Fetch a job's details: **GET /api/jobs/<job_id>**
73 73  
74 74  The proxy will query Unicore on-the-fly for the job’s latest details. Fenix sites retain the information of past jobs for a set amount of days (30 days at CSCS). If the request is made after that delay, the information returned is that which has been stored in the HPC Job Proxy. The full information retrieved and stored is the following:
... ... @@ -92,9 +92,9 @@
92 92  {{/code}}
93 93  {{/info}}
94 94  
95 -* Fetch a file present in the job's execution directory: **GET /api/jobs/<job_id>/<filename>**
99 +* Fetch a job's file: **GET /api/jobs/<job_id>/<filename>**
96 96  
97 -​​​​​​​Out of convenience, you can fetch the files that are present in the job's execution directory. The output, error and exit code of a job are placed by Unicore in the job’s working directory. The filenames available are: stdout, stderr, UNICORE_SCRIPT_EXIT_CODE. If the job has pre commands or post commands, the following filenames are also available: stdout and stderr respectively under the folders .UNICORE_POST_0/ or .UNICORE_PRE_0/. If your job is creating files than they are too available to be fetched.
101 +​​​​​​​Out of convenience, you can fetch the output of a job (placed by Unicore in the job’s working directory). The filenames available are: stdout, stderr, UNICORE_SCRIPT_EXIT_CODE. If the job has pre commands or post commands, the following filenames are also available: stdout and stderr respectively under the folders .UNICORE_POST_0/ or .UNICORE_PRE_0/
98 98  
99 99  The proxy will respond with the //raw content// of the requested file. These files are available as long as the site does not delete them (30 days for CSCS PIZ DAINT).
100 100  
... ... @@ -102,7 +102,7 @@
102 102  
103 103  == Sample usage ==
104 104  
105 -[[A Jupyter Notebook provides sample code for the Application’s access to the HPC Job Proxy.>>https://lab.ch.ebrains.eu/user-redirect/lab/tree/shared/EBRAINS%20HPC%20job%20proxy/HPC_job_proxy_usage.ipynb]]
109 +A Jupyter Notebook provides sample code for the Application’s access to the HPC Job Proxy.
106 106  
107 107  == Source code ==
108 108  
... ... @@ -114,13 +114,13 @@
114 114  
115 115  Your application needs an EBRAINS IAM service account. You should contact EBRAINS __support__ to create it. You will need to provide a username and an email address which is not linked to another EBRAINS account. The mapping between the EBRAINS service account and the Fenix service account is done automatically based on the linked email addresses which need to be identical.
116 116  
117 -Your application needs an EBRAINS IAM OIDC client. See the [[__instructions__>>https://wiki.ebrains.eu/bin/view/Collabs/the-collaboratory/Documentation%20IAM/FAQ/OIDC%20Clients%20explained/1.%20Registering%20an%20OIDC%20client/#HCreatingyourOpenIDConnectclient]].
121 +Your application needs an EBRAINS IAM OIDC client. See the __instructions__.
118 118  
119 -Your application needs a Fenix project and a Fenix service account. See the [[__instructions__>>https://fenix-ri.eu/access]] to get a project. Then the Principal Investigator in your lab can request a Fenix service account via EBRAINS [[__support__>>https://ebrains.eu/support/]].
123 +Your application needs a Fenix project and a Fenix service account. See the __instructions__ to get a project. Then the Principal Investigator in your lab can request a Fenix service account via EBRAINS __support__.
120 120  
121 -Then in your app, you should retrieve the access token linked to your service account user. This requires the OIDC client ID, client Secret, EBRAINS service account's username and password. See the [[__instructions__>>https://wiki.ebrains.eu/bin/view/Collabs/the-collaboratory/Documentation%20IAM/FAQ/OIDC%20Clients%20explained/1.%20Registering%20an%20OIDC%20client/#HFetchingyourdeveloperaccesstoken]].
125 +Then in your app, you should retrieve the access token linked to your service account user. This requires the OIDC client ID, client Secret, EBRAINS service account's username and password. See the __instructions__.
122 122  
123 -When requesting a job on behalf of an end-user, your app gives this access token in the field "**user_info**" of the payload alongside the job request. Note that the access token expires (typically after one week), so your application should generate a new token.
127 +When requesting a job on behalf of an end user, your app gives this access token in the field "**user_info**" of the payload alongside the job request. Note that the access token expires (typically after one week), so your application should generate a new token. See the __instructions__.
124 124  
125 125  
126 126  __Example__: