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 1.1
edited by evareill
on 2021/04/28 11:57
Change comment: There is no comment for this version
To version 6.1
edited by alexisdurieux
on 2022/01/27 14:51
Change comment: There is no comment for this version

Summary

Details

Page properties
Author
... ... @@ -1,1 +1,1 @@
1 -XWiki.evareill
1 +XWiki.alexisdurieux
Content
... ... @@ -17,8 +17,6 @@
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 -
22 22  == Use case ==
23 23  
24 24  1. Bob wants to do use an EBRAINS Application that requires supercomputing.
... ... @@ -40,7 +40,6 @@
40 40  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.
41 41  1. The HPC Job Proxy notifies the Application of the results of the job.
42 42  
43 -
44 44  == Sample transaction diagram ==
45 45  
46 46  [[image:ebrains-job-proxy-Job sequence.png]]
... ... @@ -52,7 +52,7 @@
52 52  
53 53  * Submit a job: **POST /api/jobs/**
54 54  
55 -​​​​​​​To submit a job to the proxy, you need to provide the following information as part of the POST JSON body:
52 +To submit a job to the proxy, you need to provide the following information as part of the POST JSON body:
56 56  
57 57  * **job_def** - JSON: The Unicore job definition. For more information, please visit the [[__Unicore documentation__>>url:https://sourceforge.net/p/unicore/wiki/Job_Description/]]
58 58  * **site** - string: The Fenix site on which to run the job.
... ... @@ -72,7 +72,6 @@
72 72  JURON
73 73  )))
74 74  
75 -
76 76  * Fetch a job's details: **GET /api/jobs/<job_id>**
77 77  
78 78  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:
... ... @@ -96,9 +96,9 @@
96 96  {{/code}}
97 97  {{/info}}
98 98  
99 -* Fetch a job's file: **GET /api/jobs/<job_id>/<filename>**
95 +* Fetch a file present in the job's execution directory: **GET /api/jobs/<job_id>/<filename>**
100 100  
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/
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.
102 102  
103 103  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).
104 104  
... ... @@ -106,7 +106,7 @@
106 106  
107 107  == Sample usage ==
108 108  
109 -A Jupyter Notebook provides sample code for the Application’s access to the HPC Job Proxy.
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]]
110 110  
111 111  == Source code ==
112 112  
... ... @@ -118,13 +118,13 @@
118 118  
119 119  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.
120 120  
121 -Your application needs an EBRAINS IAM OIDC client. See the __instructions__.
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]].
122 122  
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__.
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/]].
124 124  
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__.
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]].
126 126  
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__.
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.
128 128  
129 129  
130 130  __Example__: