Tutorial or Teaching Labs HowTo: Difference between revisions

From Grid5000
Jump to navigation Jump to search
 
(117 intermediate revisions by 23 users not shown)
Line 5: Line 5:
= Forewords about organizing a tutorial or a teaching lab in Grid5000 =
= Forewords about organizing a tutorial or a teaching lab in Grid5000 =


{{Note|text=Although the Grid5000 charter does not explicitly mention tutorials or labs, the use Grid5000 for educational purposes is allowed.<br/>
{{Note|text=Although the Grid5000 charter does not explicitly mention tutorials or labs, the use of Grid'5000 for educational purposes is allowed.<br/>
However, some rules applies, and some steps must be carefully followed.}}
However, some rules apply, and some steps must be carefully followed.}}


First of all, '''using a single account shared between the multiple trainees is not allowed'''. Every trainee must have her own account.
First of all, '''using a single account shared between the multiple trainees is not allowed'''. Every trainee must have her own account.
Line 14: Line 14:
To that purpose, to ease the account creation phase for a large group of trainees, Grid'5000 provides a '''special procedure for a mass account creation'''.
To that purpose, to ease the account creation phase for a large group of trainees, Grid'5000 provides a '''special procedure for a mass account creation'''.


Second, the teacher may consider reserving resources in the platform to insure trainees will be able to have access to some of them during the lab.
Second, the teacher may consider reserving resources in the platform to ensure trainees will be able to have access to some of them during the lab.


Third, the teacher may consider helping trainees with their first access to the platform, as a basic technical knowledge is required for the access setup.
Third, the teacher may consider helping trainees with their first access to the platform, as basic technical knowledge is required for the access setup.


= Trainees accounts creation =
= Trainees accounts creation =


The workflow for the trainees accounts creation is the following:
The workflow for the trainees accounts creation is the following:
# Send an email to the Grid'5000 technical team at [mailto:support-staff@lists.grid5000.fr support-staff@lists.grid5000.fr], with the subject ''Tutorial Accounts Creation: ...'', to inform about your wish to create a group of accounts for trainees. In this email, some information have to be provided, '''see the next section'''.
# Send an email to the Grid'5000 technical team at [mailto:support-staff@lists.grid5000.fr support-staff@lists.grid5000.fr], with the subject ''Tutorial Accounts Creation: ...'', to inform about your wish to create a group of accounts for trainees. In this email, some information has to be provided, '''see the next section'''.
# Prepare a file containing the list of your trainees first names, last names and e-mail address. See below for an example of such a CSV file.
# Prepare a file containing the list of your trainees' first names, last names, and e-mail addresses. See below for an example of such a CSV file.
# Wait for the answer from the Grid'5000 technical team (support staff), that will provide an ''group''/''engine'' name. Connect to a Grid'5000 frontend and use the <code class=command>g5k-create-tutorial-accounts</code> to launch the actual creation of the accounts, using as parameters the provided ''engine'' name and the trainees CSV file your prepared.
# Wait for the answer from the Grid'5000 technical team (support staff), that will provide an ''group''/''engine'' name. Connect to a Grid'5000 frontend and use the <code class=command>g5k-create-tutorial-accounts</code> to launch the actual creation of the accounts, using as parameters the provided ''engine'' name and the trainees CSV file your prepared.
Upon the execution of the script, each trainee will receive an email containing the instructions to setup her password and ssh keys.
Upon the execution of the script, each trainee will receive an email containing the instructions to set up their password and ssh keys.


Once a trainee will have set her password and ssh key, her account will be immediately active (only a few minutes may be required for the passwords and the ssh keys to be synchronized to all Grid'5000 sites and servers). No other action will be required from you.  
You may provide to your trainees the following page of instruction: https://www.grid5000.fr/w/Tutorial_or_Teaching_Labs_Trainee_HowTo
 
Once a trainee will have set their passwords and SSH public keys, their account will be immediately active (only a few minutes may be required for the passwords and the ssh keys to be synchronized to all Grid'5000 sites and servers). No other action will be required of you.  


{{Note|text=Since this workflow create active accounts for your students, you must have their agreement before proceeding. They must accept [https://www.grid5000.fr/w/Grid5000:General_Conditions_of_Use Grid'5000 General condition of use] which details [https://www.grid5000.fr/w/Grid5000:General_Conditions_of_Use#Personal_information how their personal information are used].}}
{{Note|text=Since this workflow create active accounts for your students, you must have their agreement before proceeding. They must accept [https://www.grid5000.fr/w/Grid5000:General_Conditions_of_Use Grid'5000 General condition of use] which details [https://www.grid5000.fr/w/Grid5000:General_Conditions_of_Use#Personal_information how their personal information are used].}}
Line 32: Line 34:
== Expected information in the e-mail to send to the technical team (support staff) ==
== Expected information in the e-mail to send to the technical team (support staff) ==


The mass creation of accounts requires a first manual step by the technical team, to setup in the User Management Service of Grid'5000 an account creation automation '''engine''' as well as a '''dedicated group of users''' for the tutorial trainees.  
The mass creation of accounts requires a first manual step by the technical team, to set up in the User Management Service of Grid'5000 an account creation automation '''engine''' as well as a '''dedicated group of users''' for the tutorial trainees.  


To that purpose, the technical team needs some information from you. Please send an e-mail to [mailto:support-staff@lists.grid5000.fr?subject=Tutorial... support-staff@lists.grid5000.fr] with the following content :
For that purpose, the technical team needs some information from you. Please send an e-mail to [mailto:support-staff@lists.grid5000.fr?subject=Tutorial... support-staff@lists.grid5000.fr] including the following content:


{{Tutorial_Lab_creation_form}}
{{Tutorial_Lab_creation_form}}
'''The information will be handled by one of the engineers of the technical team. Please ask nicely, because it will be ''parsed'' by real human eyes. Thank you.'''


== Format of the trainees list CSV file ==
== Format of the trainees list CSV file ==
Line 49: Line 53:
  Carrie, Mathison, carrie.mathison@trainees.univ-lambda.fr
  Carrie, Mathison, carrie.mathison@trainees.univ-lambda.fr


We remind that '''the use of academic e-mail addresses is to be strongly preferred''' to ''gmail'' or any other non-professional services.  
We remind you that '''the use of academic e-mail addresses is to be strongly preferred''' to ''gmail'' or any other non-professional services.
 
That CSV file has to be uploaded (scp) to a Grid'5000 frontend for the next step.


That CSV file will have to be uploaded (scp) to a Grid'5000 frontend for the next step.
{{Note|text=Some of the trainees may already have a Grid'5000 account: this is handled by the script. Please list all trainees in the CVS, even if some of them already have a Grid'5000 account, because all must be added to the tutorial group.}}


== Use g5k-create-tutorial-accounts on the frontend to create accounts ==
== Use g5k-create-tutorial-accounts on the frontend to create accounts ==


Assuming your are connected to Grenoble's frontend and where you uploaded the CSV file named ''list.csv''.
Assuming you are connected to Grenoble's frontend and where you uploaded the CSV file named ''list.csv''.


To create the trainees user accounts, do the following:
To create the trainees' user accounts, do the following:


{{Term|location=fgrenoble|cmd=<code class="command">g5k-create-tutorial-accounts</code> <code>-f list.csv</code> <code>-e myEngineName</code>}}
{{Term|location=fgrenoble|cmd=<code class="command">g5k-create-tutorial-accounts</code> <code>-f list.csv</code> <code>-e myEngineName</code>}}


{{Warning|text=<code class="command">g5k-create-tutorial-accounts</code> automatically creates active accounts. The operation cannot be undone: accounts cannot be deleted and any modification has to be done manually on every account individually. Therefore, before executing the script, be sure that all the information contained in the CSV file is correct.}}
{{Warning|text=<code class="command">g5k-create-tutorial-accounts</code> automatically creates active accounts and add them to the lab's user group. The operation cannot be undone: accounts cannot be deleted and any modification has to be done manually on every account individually. Therefore, before executing the script, be sure that all the information contained in the CSV file is correct.}}
 
{{Note|text=You may run this script several times, it is idempotent. You may add more trainees to the CSV and rerun the script.}}


= Resource reservation =
= Resource reservation =
Line 67: Line 75:
Depending on your needs, you can reserve Grid'5000 resources in advance.
Depending on your needs, you can reserve Grid'5000 resources in advance.


You probably don't need to reserve resources if:
However, note that you probably don't need to reserve resources in advance if your tutorial occurs during the usage policy restriction period (daytime in Paris timezone) and:
* Your tutorial occurs during the usage policy restriction period (daytime in Paris timezone)
* it does not require many resources  
* and/or it does not require many resources  
* it does not require very specific or rare resources
* and/or it does not have many participants
* it does not have many participants
 
Still, if you want to reserve resources in advance, one strategy is to [[Getting_Started#Advanced_job_management_topics|reserve them as usual in Grid'5000]], and delete your jobs (e.g. using <code class=command>oardel</code>) just before your tutorial begins (if the tutorial duration is long, split by 2, and delete the second reservations later). Another strategy is to use a job of type container for your advance reservation and let students use jobs of type inner (see [[Advanced_OAR#Container_jobs]]).


If you still want to reserve resources in advance, the best strategy is to [[Getting_Started#Advanced_job_management_topics|reserve them as usual in Grid'5000]], and kill your reservation just before the beginning of your tutorial. If the tutorial duration is important, you can use several reservations and kill them as the tutorial progress.
Please note that you should use your tutorial lab project name when you submit your advance reservations for your tutorial (e.g <code>oarsub --project LAB-20XX-NAME ... </code>) in order to preserve your ability to use your advance reservation rights for your normal usage of Grid'5000 (see [[Grid5000:UsagePolicy#Privilege_levels_table|Privilege levels table]]).


{{Warning|text=If you plan to use more resources than allowed by the [[Grid5000:UsagePolicy|Grid'5000 usage policy]], you have to  make a request for a special usage permission. The procedure is detailed in [[Grid5000:SpecialUsage]].}}
{{Warning|text=If however your advance reservation(s) for your tutorial would absolutely require more resources than allowed by the [[Grid5000:UsagePolicy|Grid'5000 usage policy]], you must request a special usage permission, as described by the procedure detailed in [[Grid5000:SpecialUsage]].}}


= Access to Grid'5000, connection using SSH =
= Access to Grid'5000, connection using SSH =
Line 80: Line 90:
Past experiences show that many problems are related to some difficulties with the connection to Grid'5000 with SSH keys.
Past experiences show that many problems are related to some difficulties with the connection to Grid'5000 with SSH keys.


To use Grid'5000, trainees '''must''' have basic knowledge of SSH, and especially know how to generate SSH private and public keys and use them to connect to a remote machines. Don't hesitate to spend time at the beginning of the tutorial to explain it. More information on this topic is available at [[SSH]] and [[Getting_Started#Connect_to_a_Grid.275000_access_machine]].
To use Grid'5000, trainees '''must''' have basic knowledge of SSH, and especially know how to generate SSH private and public keys and use them to connect to a remote machine. Don't hesitate to spend time at the beginning of the tutorial to explain it. More information on this topic is available at [[SSH]] and [[Getting_Started#Connect_to_a_Grid.275000_access_machine]].


= FAQ =
= FAQ =
Line 92: Line 102:
== What do the trainees need to do to get their account ready to use? ==
== What do the trainees need to do to get their account ready to use? ==


Created accounts are active right away after the initial procedure, but '''the trainees have to create their password and SSH keys''' before being able to connect for the first time.  
Created accounts are active right away after the initial procedure, but '''trainees have to create their passwords and provide their SSH public keys''' before being able to connect for the first time.  
Otherwise, they are not able to connect to any of the grid5000 services.
Otherwise, they are not able to connect to any of the grid5000 services.


To do so, they received by email an URL that they must open in a web browser. Every trainee must fill the form in the web browser, with a personal password and SSH public key.
To do so, they received by email an URL that they must open in a web browser. Every trainee must fill the form in the web browser, with a personal password and SSH public key.


== My trainees told me they did not received any email ==
== How does the email sent to students look like? ==
Here is a sample of such an email:
'''Subject:''' [Grid5000-account] Your Grid5000 account was created by ...
Dear <code class=replace>Firstname Lastname</code> (<code class=replace>username</code>),
You receive this email because your manager (...) requested a Grid5000
account for you in the context of a tutorial. To get more information about
Grid5000, see the website: http://www.grid5000.fr.
Your login on the Grid5000 platform is: <code class=replace>username</code>.
The next two steps for you are now to:
1/ Finish setting up your access to the platform by creating a password and an SSH key.
    To do so, open the following URL:
    https://public-api.grid5000.fr/stable/users/setup_password?password_token=<code class=replace>XXXXXXXXXXXXXXXXXXXXXX</code>#special.
2/ Read carefully the two following pages:
    The Grid5000 getting started documentation (https://www.grid5000.fr/w/Getting_Started),
    which gives important information on how to use the platform.
    The Grid5000 usage policy (https://www.grid5000.fr/w/Grid5000:UsagePolicy),
    which gives the rules that MUST be followed when using the platform. Note that any
    abuse will automatically be detected and reported to your manager.
 
== How does the form the students open to set their passwords and SSH keys look like? ==
Opening https://public-api.grid5000.fr/stable/users/setup_password?password_token=XXXXXXXXXXXXXXXXXXXXXX#special shows:
[[File:UMS tutorial password and ssh key form.png|800px|frameless]]
 
== My trainees told me they did not receive any email ==


Do the following:
Do the following:
* Check that the email addresses you put in the CSV file are the correct.
* Check that the email addresses you put in the CSV file are correct.
* Ask the trainees to check their spam box.
* Ask the trainees to check their spam box.
* Ask the trainees to reset their password using [[Special:G5KChangePassword]]. This will send a new email to them, with the instruction to reset their password.
* Ask the trainees to reset their password using [[Special:G5KChangePassword]]. This will send a new email to them, with the instruction to reset their password.


== One of my trainee is not able to log in ==
== One of my trainees is not able to log in ==


Some possible causes:
Some possible causes:
Line 111: Line 153:
* The trainee does not remember the password. In that case, the password can reset using [[Special:G5KChangePassword]].
* The trainee does not remember the password. In that case, the password can reset using [[Special:G5KChangePassword]].


== One of my trainee is not able to ssh the frontend ==
== One of my trainees is not able to ssh the frontend ==


Possible causes:
Possible causes:
* The trainee is not using a correct login. The Grid'5000 login may differ from their usual login when using a workstation or another platform. In that case, the trainee can use the <code class="command">-l </code><code class="replace">G5K_USERNAME</code> option in the SSH command.
* The trainee is not using a correct login. The Grid'5000 login may differ from their usual login when using a workstation or another platform. In that case, the trainee can use the <code class="command">-l </code><code class="replace">G5K_USERNAME</code> option in the SSH command.
* The trainee did not set their SSH private key in the machine (workstation) where the connection to Grid'5000 is made from.
* The trainee did not set their SSH private key in the machine (workstation) where the connection to Grid'5000 is made from.
* The trainee did not set up any SSH key when they used the URL to set up their password. To fix this, the trainee can connect to [https://api.grid5000.fr/stable/users/ UMS], click on the left panel ''SSH keys'', and then copy/past their '''public SSH key'''.
* The trainee did not set up an SSH key when they used the URL to set up their password. To fix this, the trainee can connect to [https://api.grid5000.fr/stable/users/ UMS], click on the left panel ''SSH keys'', and then copy/paste their '''public SSH key'''.


Note that one cannot connect to the Grid'5000 frontends directly (e.g. <code class="host">fgrenoble.grenoble.grid5000.fr</code>). One first needs first to connect to the access machine: <code class="host">access.grid5000.fr</code>.
Note that one cannot connect to the Grid'5000 frontends directly (e.g. <code class="host">fgrenoble.grenoble.grid5000.fr</code>). One first needs first to connect to the access machine: <code class="host">access.grid5000.fr</code>.
Line 148: Line 190:
* However, if the existing account is locked, it needs an intervention from support-staff. For the record, an account can be locked for one of these two reasons: its email address bounces (mostly because invalid), or the user was sanctioned for a misuse of the platform.
* However, if the existing account is locked, it needs an intervention from support-staff. For the record, an account can be locked for one of these two reasons: its email address bounces (mostly because invalid), or the user was sanctioned for a misuse of the platform.


* Last, by running the script it may happen that you create a new account for a trainee that already had one, that because the email address you provided for a trainee differs from the one of the trainee's existing account. The trainee may want to use their existing account rather than the new one you created. In that case, you can just run again the script with a CSV containing only one line with the information about that trainee, but changing the email address to the one of the previously existing account of the trainee.
* Last, by running the script it may happen that you create a new account for a trainee that already had one, that because the email address you provided for a trainee differs from the one of the trainee's existing account. The trainee may want to use their existing account rather than the new one you created. In that case, you can just run again the script with a CSV containing only one line with the information about that trainee, but changing the email address to that of the previously existing account of the trainee.


== The g5k-create-tutorial-accounts script returned an error for one of trainee ==
== The g5k-create-tutorial-accounts script returned an error for one of trainee ==


If you get an error, please contact [mailto:support-staff@lists.grid5000.fr support-staff].
If you get an error, please contact [mailto:support-staff@lists.grid5000.fr support-staff].
== How does the email sent to students look like? ==
Here is a sample of such an email:
'''Subject:''' [Grid5000-account] Your Grid5000 account was created by ...
Dear <code class=replace>Firstname Lastname</code> (<code class=replace>username</code>),
You receive this email because your manager (...) requested a Grid5000
account for you in the context of a tutorial. To get more information about
Grid5000, see the website: http://www.grid5000.fr.
Your login on the Grid5000 platform is: <code class=replace>username</code>.
The next two steps for you are now to:
1/ Finish setting up your access to the platform by creating a password and an SSH key.
    To do so, open the following URL:
    https://public-api.grid5000.fr/stable/users/setup_password?password_token=<code class=replace>XXXXXXXXXXXXXXXXXXXXXX</code>#special.
2/ Read carefully the two following pages:
    The Grid5000 getting started documentation (https://www.grid5000.fr/w/Getting_Started),
    which gives important information on how to use the platform.
    The Grid5000 usage policy (https://www.grid5000.fr/w/Grid5000:UsagePolicy),
    which gives the rules that MUST be followed when using the platform. Note that any
    abuse will automatically be detected and reported to your manager.


= List of the tutorials/labs using Grid5000 =
= List of the tutorials/labs using Grid5000 =
Line 187: Line 201:


; The following list contains the tutorials already organized on Grid'5000
; The following list contains the tutorials already organized on Grid'5000
* Un module de formation Scikit-Learn à Inria Academy, Hands-on scikit-learn, 2025
* Un TP en Master 1 TAL à l'Université de Lorraine / IDMC. Introduction à Grid5000, en 2020-2021-2022-2023.
* Un TP en Master 1 Informatique à l'Université de Lille, depuis 2010. Initiation à un environnement et des paradigmes de calcul distribué: réservation de machines et déploiement (oar/kadeploy), traitement d'applications Embarrassingly parallel en mode batch, programmation MPI, expérimentation, scalabilité et mesure de performance. Un groupe d'une vingtaine d'étudiants environ. 3 séances de TP environ.
* Un TP en Master 1 Informatique à l'Université de Lille, depuis 2010. Initiation à un environnement et des paradigmes de calcul distribué: réservation de machines et déploiement (oar/kadeploy), traitement d'applications Embarrassingly parallel en mode batch, programmation MPI, expérimentation, scalabilité et mesure de performance. Un groupe d'une vingtaine d'étudiants environ. 3 séances de TP environ.
* Un TP à Rennes, avec Nikos Parlavantzas et une intervention dans le master MRI (1 cours, 2 TP par D. Margery, années 2013-2014, 2014-2015 et 2015-2016. Repris par Matthieu Simonin depuis))
* Un TP à Rennes, avec Nikos Parlavantzas et une intervention dans le master MRI (1 cours, 2 TP par D. Margery, années 2013-2014, 2014-2015 et 2015-2016. Repris par Matthieu Simonin depuis))
Line 200: Line 217:
* Un projet de Master 1 informatique à l'Université de Montpellier, de janvier à juin 2019 (groupe de 3 étudiants). Résumé "Nous disposons d'un algorithme d'apprentissage de relations sémantiques basé sur les relations existantes dans le réseau lexical du JeuxDeMots (http:www.jeuxdemots.org). La table générée est de grande taille, de l'ordre de plusieurs centaines de millions de lignes. L'objectif du projet est de distribuer cette table et de mettre en ouvre un algorithme d'apprentissage et d'exploitation de manière distribuée et parallèle.". Projet encadré par Hinde Bouziane et Mathieu Lafourcade.
* Un projet de Master 1 informatique à l'Université de Montpellier, de janvier à juin 2019 (groupe de 3 étudiants). Résumé "Nous disposons d'un algorithme d'apprentissage de relations sémantiques basé sur les relations existantes dans le réseau lexical du JeuxDeMots (http:www.jeuxdemots.org). La table générée est de grande taille, de l'ordre de plusieurs centaines de millions de lignes. L'objectif du projet est de distribuer cette table et de mettre en ouvre un algorithme d'apprentissage et d'exploitation de manière distribuée et parallèle.". Projet encadré par Hinde Bouziane et Mathieu Lafourcade.
* Un projet de Master 1 informatique à l'Université de Montpellier, de janvier à juin 2019 (groupe de 2 étudiants). Le projet porte sur la programmation d'un traitement parallèle et distribué d'images (photogrammétrie). Projet encadré par Hinde Lilia Bouziane.
* Un projet de Master 1 informatique à l'Université de Montpellier, de janvier à juin 2019 (groupe de 2 étudiants). Le projet porte sur la programmation d'un traitement parallèle et distribué d'images (photogrammétrie). Projet encadré par Hinde Lilia Bouziane.
* Un projet "deep learning" en [http://formations.univ-grenoble-alpes.fr/fr/catalogue/master-XB/sciences-technologies-sante-STS/master-informatique-program-master-informatique/parcours-genie-informatique-alternance-2e-annee-subprogram-parcours-genie-informatique-m2-alternance/ue-documents-multimedia-description-et-recherche-automatique-IFQV03ZG.html M2 GI] et [http://formations.univ-grenoble-alpes.fr/fr/catalogue/cycle-preparatoire-et-diplome-d-ingenieur-XC/sciences-technologies-sante-STS/ingenieur-de-polytech-grenoble-specialite-informatique-reseaux-informatiques-et-communication-multimedia-program-ingenieur-de-polytech-grenoble-specialite-reseaux-informatiques-et-communication-multimedia/ue-texte-et-donnees-text-and-data-IH1TB9TW/acces-et-recherche-d-information-information-retrieval-IH1TD4T4.html Polytech INFO4] à l'université de Grenoble, de février à avril 2019, puis 2020. Projet encadré par Georges Quénot.
* Un projet "deep learning" en [http://formations.univ-grenoble-alpes.fr/fr/catalogue/master-XB/sciences-technologies-sante-STS/master-informatique-program-master-informatique/parcours-genie-informatique-alternance-2e-annee-subprogram-parcours-genie-informatique-m2-alternance/ue-documents-multimedia-description-et-recherche-automatique-IFQV03ZG.html M2 GI] et [http://formations.univ-grenoble-alpes.fr/fr/catalogue/cycle-preparatoire-et-diplome-d-ingenieur-XC/sciences-technologies-sante-STS/ingenieur-de-polytech-grenoble-specialite-informatique-reseaux-informatiques-et-communication-multimedia-program-ingenieur-de-polytech-grenoble-specialite-reseaux-informatiques-et-communication-multimedia/ue-texte-et-donnees-text-and-data-IH1TB9TW/acces-et-recherche-d-information-information-retrieval-IH1TD4T4.html Polytech INFO4] à l'université de Grenoble, de février à avril de 2019 à 2023 inclus. Projet encadré par Georges Quénot.
* TP de l'UE Parallélisme, du M1 de l'UCBL (Simon Delamare), 2019-2020
* TP de l'UE Parallélisme, du M1 de l'UCBL (Simon Delamare), 2019-2020
* TP de l'Université de Lille, M2 Data Science, MPI & GPU (Pierre Fortin), 2020-2021
* TP de l'Université de Lille, M2 Data Science, MPI & GPU (Pierre Fortin), 2020-2021
Line 208: Line 225:
* TP pour le Groupe Calcul, introduction à Grid'5000 (Simon Delamarre), 2020
* TP pour le Groupe Calcul, introduction à Grid'5000 (Simon Delamarre), 2020
* TP de l'Université de Lille, 5ème année de la spécialité Informatique et statistiques (IS5) à Polytech Lille. Teaching labs on GPU programming. Module CHP (Calcul Haute Performance). 2 sessions de 2 heures (Pierre Fortin), 2020-2021
* TP de l'Université de Lille, 5ème année de la spécialité Informatique et statistiques (IS5) à Polytech Lille. Teaching labs on GPU programming. Module CHP (Calcul Haute Performance). 2 sessions de 2 heures (Pierre Fortin), 2020-2021
* TP de Sorbonne Université, UFR d'ingénierie, Master d'informatique M1, parcours SFPN, Introduction au Calcul Haute-Performance, Charles Bouillaguet, 2020-2021
* TP de ENS de Rennes, Master informatique, Module Cloud and Big Data, Anne-Cécile Orgerie et Shadi Ibrahim, 2015-2021
* TP de l'UCBL, Master 1 Informatique, UE Parallélisme, Simon Delamare, 2020-2021
* Tutorial "Installation, deployment and execution of Melissa; Understanding how to port an existing application into the Melissa framework", Bruno Raffin INRIA-DATAMOVE/LIG, 16 septembre 2021.
* TP d'introduction à Grid5000 de l'Université de Lorraine (IDMC), Chuyuan Li, 22 septembre et 1er octobre 2021
* Hackathon pour [https://rsd-ecole.cnrs.fr/ l'école automnale RESCOM de recherche du GDR RSD] (Bruno De moura Donassolo, Arnaud Legrand, Matthieu Simonin), 4-8 octobre 2021.
* TP de l'Université de Lille, 5ème année de la spécialité Informatique et statistiques (IS5) à Polytech Lille. Teaching labs on GPU programming. Module CHP (Calcul Haute Performance), Pierre Fortin, 2020-2021
* TP de l'Université Grenoble-Alpes, INPG/Master Recherche MOSIG, Calcul Parallèle, Bruno Raffin & Frédéric Wagner, 2020-2021.
* TP de l'université Aix Marseille, L3 Informatique, Impact du numérique, Julien Lefevre, 2021-2022
* TP de Sorbonne Université, UFR d'ingénierie, Master d'informatique M1, parcours SFPN, Introduction au Calcul Haute-Performance, Charles Bouillaguet, 2021-2022
* TP de LS2N, Membre de LS2N UMR à Nantes, Teaching the fundamentals of Grid'5000 platform for beginner users only for internal members of LS2N, Richard RANDRIATOAMANANA & Remous Aris KOUTSIAMANIS, 26-Jan 2022
* TP de CY Paris Université, Master2 student, Heterogeneous programming on GPU (CUDA), Thierry Garcia, 22-Mar 2022
* Tutoriel sur l'utilisation de la plateforme Grid'5000 dans le cadre du groupe de travail "plateformes" du GDR RSD, Simon Delamare et Pierre Jacquot, Mars 2022
* TP de l'UCBL, Master 1 Informatique, UE Parallélisme, Simon Delamare, 2022
* TP et petits projets de Sorbonne Université, Master’s in High Performance Computing (HPC), Parallel programming (PPAR), Charles Bouillaguet, 2022-2023
* Un projet d'ingénierie sur le thème Lab on energy consumption - ANF User Support Tools for HPC 2023 organisé en juin 2023 par Mathilde Jay
* Un TP à l'UCBL (Lyon 1) pour le Master informatique "TP développement d'applications parallèles hybrides, évaluation et analyse de leurs performances", d'avril à juin 2023.
* Un projet à CY Tech Campus de Pau intitulé Project and simulation on GPU using CUDA facilities en M2 organisé de janvier à mars 2023 par Thierry Garcia
* Un TP à UGA pour le Master Recherche MOSIG en 'Advanced Parallel System' de janvier à mars 2023 organisé par Bruno Raffin
* TP et petits projets de Sorbonne Université, Master’s in High Performance Computing (HPC), Parallel programming (PPAR), Charles Bouillaguet, 2023-2024
* TP Virtualisation Système et Réseau, FSI Master Informatique parcours SECIL spécialité Réseaux et Systèmes Distribués, Virtualisation Système et Réseau, Millian Poquet, 2023
* TP de l'Université Grenoble-Alpes, Master2 MIAGE, "EcoWeb : Study the energy consumption of the various components of a host", Mathilde Jay, Octobre 2023
* Projet et test de performance pour le cours de systèmes distribués, Ensimag 3A filière ISI (niveau M2), Université Grenoble-Alpes, Gregory Mounie, 2023-2024
* Projet de développement NLP software, M2 IDMC - Institut des sciences du digital, du management et de la Cognition, software project, Maxime Amblard, 2023-2024
* Un TP de l'Université de Lille, Master FST/Mathématiques, Practical works on usage of Grid'5000, OpenMP, MPI and Cuda, Jan Gmys et Nouredine Melab, 2023-2024
* Un tutoriel d'utilisation de la chaîne de compilation Syfala (Audio to FPGA) sur des machines de Grid'5000, à destination du laboratoire CCRMA de l'université de Stanford, organisé par l'Equipe Emeraude le 24 octobre 2023
* Un TP à UGA pour le Master Recherche MOSIG en 'Advanced Parallel System' jusqu'à mars 2024 organisé par Bruno Raffin
* Module Systèmes embarqués, FSI, Master Informatique parcours SECIL, spécialité SIAME, à Univ. Toulouse III, Millian Poquet, 2023
* Tutoriel Mesurer et comprendre la consommation d’un nœud de calcul - Eco-concevoir un code, ANF 8R EcoInfo Energie, Laurent Lefevre, 2023
* Tutoriel Mesurer et comprendre la consommation d’un nœud de calcul - Eco-concevoir un code, ANF ENVOL, Laurent Lefevre, 2023
* TP OpenStack, Master FIL A3 Back, IMT Atlantique, Baptiste Jonglez, 2023
* Un TP pour le Master d'Informatique de l'Université de Franche Comté "Introduction à un environnement de type grille de calcul et prise en main d'outils de mesures de consommation énergétique", 2023
* Un TP (deux sessions) pour l'ISTIC de l'Université de Rennes "Lab sessions in the context of the Cloud, Network and Infrastructure course (getting started + scripting)", 2023
* Un tutoriel d'utilisation de la chaîne de compilation Syfala (Audio to FPGA) sur des machines de Grid'5000, à destination du laboratoire CCRMA de l'université de Stanford, organisé par l'Equipe Emeraude le 5 décembre 2023
* Un TP pour la Faculté d'Informatique et de mathématiques appliquées, Master Informatique co-habilité UT3 et UFAR, "Programm Cuda algorithm and evaluate their power consumption", organisé par Georges Da Costa
* Un TD pour le Master 2 ISFA, Université de Lyon, Grid’5000 introduction and Data Management Introduction, organisé par Eddy Caron, 2023-2024
* TP de l'université Aix Marseille, L3 Informatique, Impact du numérique, Julien Lefevre, 2023-2024
* TP pour l'école Aivancity (Cachan) : Practical work on energy measurement and software eco-design, par Laurent Lefevre du 5/2/2024 au 6/2/2024
* TP pour le Bachelor in Applied Mathematics and Informatics, University of Sofia, "Familiarizing students with parallel computing runtimes and speedup studies", par Vania Marangozova (LIG/Erods) au premier trimestre 2024
* Projet "système de classification d'images par apprentissage profond" (sur GPU) - Univ. Grenoble Alpes, Ingénieur de Polytech Grenoble et Master 2 spécialité Informatique, UE Documents multimédia : Accès et Recherche d'Information, Georges Quénot <Georges.Quenot@imag.fr>, 2024
* Projet "Few-shot Learning"  Master 2 IAFA de Paul Sabatier Toulouse, University Toulouse 3, Sandrine Mouysset, Millian Poquet <millian.poquet@univ-tlse3.fr>, 2024
* TP pour Project and simulation on GPU using CUDA facilities, master2, module  Heterogeneous programming on GPU (CUDA) CY Tech Campus de Pau,Thierry GARCIA <thierry.garcia@irit.fr> , 2024
* Un TP à l'Observatoire Midi Pyrénées intitulé "Mesurer et comprendre la consommation d’un nœud de calcul - Eco-concevoir un code", organisé les 26 mars 2024 par Laurent Lefevre (ENS/LIP/Avalon).
* Un Tutotechno co-organisé par le SED Inria-Université de Lorraine et le Loria/SISR (Nancy) intitulé "Deep Learning on Grid 5000"
* Un TP à l'Ecole Aivancity (Cachan) intitulé "Mesurer et comprendre la consommation d’un nœud de calcul - Eco-concevoir un code", organisé les 5 et 6 février 2024 par Laurent Lefevre (ENS/LIP/Avalon).
* Un TP à l'IMT Atlantique (FISE A3 TAF LOGIN), UE nuage, sur le déploiement d'Openstack, pour des étudiants de master, organisé en mars 2024 par Baptiste Jonglez et Daniel Balouek.
* Un TP à l'IMT Atlantique (FIL A3 Back), UE Cloud, sur le déploiement d'Openstack, pour des étudiants de master, organisé en novembre 2023 par Baptiste Jonglez et Daniel Balouek.
* Un TP à l'IMT Atlantique (FIL A3 Back), UE Cloud, sur le déploiement d'Openstack, pour des étudiants de master, organisé en octobre 2022 par Baptiste Jonglez et Adrien Lebre.
* Un TP pour le GDS CNRS EcoInfo. Un après midi de mesures énergétiques sur le site de Lyn et éco-conception logicielle, organisé en octobre 2022 par Laurent Lefevre (ENS/LIP/Avalon).
* Un TP en master 1 TAL à l'Université de Lorraine / IDMC. Training deeplearning models on speech and MRI data, en 2023.
* Projet pour classes préparatoires Lycée Champollion, Université Grenoble Alpes, Préparation TIPE sur le HPC, en 2024
* Un TP "Benchmarks with energy consumption measurements" pour l'ANF "ImpactNum", en 2024 par Guillaume Raffin
* Un TP "Green I.T." pour la Summer school Green I.T., 2024 par Remous-Aris Koutsiamanis
* Tutorial on how to use EnOSlib on G5k in the context of ACM REP 2024, Matthieu Simonin et Baptiste Jonglez, 2024.
* Un TP pour le Master 2 de Data Science à l'Université de Lille, Teaching labs with MPI, then GPU and possibly MPI+GPU, organisé par Pierre Fortin, 2024-2025
* Un tutoriel pour le Master 2 d'Informatique, en Informatique Responsable à l'UFR ST, introduction à un environnement de type grille de calcul
et prise en main d'outils de mesures de consommation énergétique, organisé par Louis-Claude Canon, 2024
* Un TP pour le Master 2 ALMA (Architecture Logicielles), à l'Université de Nantes, Daniel Balouek, 2024
* Un TP pour le Master 1 d'Informatique, parcours HPC / CCA / QI à Sorbonne Université, travaux pratique et réalisation de petits projets de HPC, organisé par Charles Bouillaguet, 2024-2025
* Un TP pour la conférence e-Science 2024, The tutorial learn about edge-cloud management policies in the context of urgent applications.
* Un TP pour le Master 1 IDMC (Institut des sciences du Digital, Management Cognition) sur "the basic usages of grid’5000 and let students practice", 2024-2025
* Un TP pour le Master 2 IDMC (Institut des sciences du Digital, Management Cognition) sur "the basic usages of grid’5000 and let students practice", 2024-2025
* Un TP pour le Master FSI, Master Informatique parcours SECIL sur la "Virtualisation Système et Réseau", 2024
* Un TD pour le Master 2 ISFA, Université de Lyon, Grid’5000 introduction and Data Management Introduction, organisé par Eddy Caron, 2024-2025
* Un TP pour le Master M2 Calcul Scientifique, Université de Lille, Practical works on usage of OpenMP, MPI and Cuda, organisé par Jan Gmys et Nouredine Melab; 2024-2025
* Un Projet pour le Master Grenoble-INP/Ensimag, module "Systèmes distribués", Université de Grenoble Alpes, écriture d'un make distribué avec diverses plateforme. Mesures de performance à l'échelle. Organisé par Grégory Mounié, 2024-2025
* Un TP pour le Master 2 FSI, Master Informatique parcours SECIL, spécialité SIAME : "Program algorithms with multiple langages and measure performance and energy with RAPL", module "Systèmes embarqués", Univ. Toulouse III, organisé par Georges Da Costa, 2024
* Un tutoriel pour le séminaire en santé numérique à PariSanté Campus, pour savoir comment utiliser Armored Node, CompuVault, Nipype/Pydra, etc.. sur Abaca, organisé par Yao Chi, 2024
* TP OpenStack, Master FIL A3 Back, IMT Atlantique, Baptiste Jonglez, 2024
* Un TP pour le Master ALMA, Université de Nantes, Capstone, Orchestration of services on sensor-edge-cloud resources using Kubernetes. Consist of deployment of Kubernetes and placement algorithms on heterogeneous resources, Daniel Balouek, 2024-2025
* Un TP à UGA pour le Master Recherche MOSIG en 'Advanced Parallel System' jusqu'à mars 2025 organisé par Bruno Raffin
* TP Pour le Master ISTIC en Cloud and Network Infrastructure par Matthieu Simonin
* TP pour la Licence 3, parallélisme et performance par Pierre Fortin, 2024-2025
* Un TP de Master Informatique parcours SECIL : Systèmes embarqués et connectés jusqu'à fin juin 2025, Performance/energy evaluation of software on various hardware, organisé par Millian Poquet à l'Université de Toulouse
* Un tutoriel dans le cadre du PEPR NumPEX : "How to use Guix and Spack for Application Deployment Across Supercomputers", organisé par Pierre Neyron, 2025
* Un TP pour le master Informatique SIRAV/IL, Université de Lorraine, Traitement de données massives, organisé par Thomas Lambert, 2025
* Un TP pour le cursus ingénieur généraliste spécialisation Software Engineering, IMT Atlantique, Déploiement d'Openstack, organisé par Baptiste Jonglez , 2025
* Un TP pour l'UE Parallélisme, Université Claude Bernard Lyon1, organisé par Simon Delamare, 2025
* Une formation "usages de l'IA : enjeux sociétaux, environnementaux et organisationnels", Université de Grenoble, organisé par Guillaume Raffin, 2025
* Un TP dans le carde du PEPR Numpex: Spack for Beginners, organisé par Fernando Ayats Llamas, 2025
* Un TP dans le cadre de la conférence francophone COMPAS: Environnements distribués reproductibles avec NixOS-Compose, organisé par Quentin Guilloteau, Olivier Richard et Millian Poquet, 2025
* Evaluation - Short bookings to evaluate the artifacts of the accepted papers of the SOSP'25 conference, Baptiste Lepers, août 2025
* Un TP pour le master 2 Data Science, HPC (utilisation de MPI et combinaison GPU+MPI) par Pierre Fortin, 2025
* Un TP pour le master informatique, Informatique responsable : introduction à un environnement de type grille de calcul et prise en main d'outils de mesures de consommation énergétique, organisé par Louis-Claude Canon, 2025
* Un TP pour le Master ALMA, Université de Nantes, Orchestration of services on sensor-edge-cloud resources using Kubernetes. Consist of deployment of Kubernetes and placement algorithms on heterogeneous resources, Daniel Balouek, 2025
* Un tutoriel dans le cadre de la RSECon 2025 sur la reproductivité avec Guix, Julien Castelneau - Ghislain Vaillant, 2025
* Un TP pour le cursus Administration Système Avancée de Polytech Nantes, Université Nantes : Prise en main G5K et expérimentation Openstack, Baptiste jonglez - Daniel Balouek-Thomert, 2025
* Un tutoriel dans le cadre d'un Workshop Informatique Durable à LISN , Université Paris-Saclay, Simon Delamare- Laurent Lefevre, 2025
* Un tutoriel dans le cadre de travaux pratiques sur l'utilisation de OpenMP, MPI et Cuda, Université de Lille, Jan Gmys - Nouredine Melab, 2025
* Un TP "Benchmarks with energy consumption measurements" pour "IA2 autumn school", Univ. Grenoble Alpes, Guillaume Raffin, 2025
* Un tutoriel NumPEX : "Introduction to Guix", organisé par Romain Garbage, Bruno Raffin et Pierre Neyron, 2025
* Un tutoriel pour le Master SECIL, University of Toulouse, "Program algorithms with multiple langages and measure performance and energy with RAPL", par Georges Da Costa, 2025

Latest revision as of 12:35, 16 October 2025

This page explains how to use Grid'5000 for tutorials/labs, for instance in a teaching course or project at the university, or in thematic schools.

Forewords about organizing a tutorial or a teaching lab in Grid5000

Note.png Note

Although the Grid5000 charter does not explicitly mention tutorials or labs, the use of Grid'5000 for educational purposes is allowed.
However, some rules apply, and some steps must be carefully followed.

First of all, using a single account shared between the multiple trainees is not allowed. Every trainee must have her own account.

Also, accounts have to be nominative (see below for the required information). Generic accounts are not allowed.

To that purpose, to ease the account creation phase for a large group of trainees, Grid'5000 provides a special procedure for a mass account creation.

Second, the teacher may consider reserving resources in the platform to ensure trainees will be able to have access to some of them during the lab.

Third, the teacher may consider helping trainees with their first access to the platform, as basic technical knowledge is required for the access setup.

Trainees accounts creation

The workflow for the trainees accounts creation is the following:

  1. Send an email to the Grid'5000 technical team at support-staff@lists.grid5000.fr, with the subject Tutorial Accounts Creation: ..., to inform about your wish to create a group of accounts for trainees. In this email, some information has to be provided, see the next section.
  2. Prepare a file containing the list of your trainees' first names, last names, and e-mail addresses. See below for an example of such a CSV file.
  3. Wait for the answer from the Grid'5000 technical team (support staff), that will provide an group/engine name. Connect to a Grid'5000 frontend and use the g5k-create-tutorial-accounts to launch the actual creation of the accounts, using as parameters the provided engine name and the trainees CSV file your prepared.

Upon the execution of the script, each trainee will receive an email containing the instructions to set up their password and ssh keys.

You may provide to your trainees the following page of instruction: https://www.grid5000.fr/w/Tutorial_or_Teaching_Labs_Trainee_HowTo

Once a trainee will have set their passwords and SSH public keys, their account will be immediately active (only a few minutes may be required for the passwords and the ssh keys to be synchronized to all Grid'5000 sites and servers). No other action will be required of you.

Note.png Note

Since this workflow create active accounts for your students, you must have their agreement before proceeding. They must accept Grid'5000 General condition of use which details how their personal information are used.

Expected information in the e-mail to send to the technical team (support staff)

The mass creation of accounts requires a first manual step by the technical team, to set up in the User Management Service of Grid'5000 an account creation automation engine as well as a dedicated group of users for the tutorial trainees.

For that purpose, the technical team needs some information from you. Please send an e-mail to support-staff@lists.grid5000.fr including the following content:

Participants/students affiliation information
---------------------------------------------
- COUNTRY: → <Country of residence of the participants in case of a lab of a university course (i.e. country of the university). Can be 'n/a' or 'various' for an international workshop tutorial, because the nationality or residence of the participants is unknown.>
- UNIVERSITY: → <Name of the university of the students in case of a lab of a university course, e.g. Univ. Grenoble Alpes. Can be 'n/a' or 'various' for participants of a workshop tutorial for instance, because anything more precise would not be relevant.>
- ACADEMIC DEPARTMENT/FACULTY: → <Name of the university department of the students in case of a lab of a university course, e.g. Grenoble INP/Ensimag, Master Recherche MOSIG. Can be 'n/a' or 'various' for participants of a workshop tutorial for instance, because anything more precise would not be relevant.>
- TEACHING UNIT/MODULE: → <Name of the teaching unit or module of the students in case of a lab of a university course, e.g. Distributed System, Parallel Computing. Can be 'n/a' for participants of a workshop tutorial for instance, because anything more precise would not be relevant.>
- EMPLOYEE TYPE: → <One of 'bachelor/master student' or 'PhD student' or 'post-doc', 'research/professor', 'engineer'. Can be 'n/a' or 'various' if the employee type is either not the same or not known for all participants.>

Tutorial/lab information
------------------------
- YEAR: → <Year the tutorial/lab takes place in, e.g. the current year.>
- NAME: → <Short name for tutorial/lab, e.g. 'uga-mosig-cp'. That name should be composed of the acronyms of the university, the academic department and the teaching unit/module. It will be prefixed by 'lab' and the year to compose the engine/group name, e.g. lab-2020-uga-mosig-cp. >
- DESCRIPTION: → <One sentence describing the expected usage of the platform for the tutorial/lab.>
- MANAGERS: → <Grid'5000 username(s) of the person(s) in charge for the tutorial (e.g. you). Beware that only the first username will be allowed to use the engine with the g5k-create-tutorial-accounts script to create the students accounts.>
- END DATE: → <Date of the end of validity of the student access to Grid'5000, as granted thanks to the tutorial/lab. This is typically the end date of the tutorial/lab.>
- EXTRA GROUPS: → <Optionally any extra Grid'5000 group(s) that the students have to be member of, e.g. to get access to some group storage (sto-*).>

The information will be handled by one of the engineers of the technical team. Please ask nicely, because it will be parsed by real human eyes. Thank you.

Format of the trainees list CSV file

You have to create a CSV file containing the information about the trainees. Such a file must be structured as follows:

  • one line per trainee
  • lines formatted as first name, last name, email address

For example, if you want to create two trainee accounts for John Doe and Carrie Mathison, a valid CSV file list.csv should contain:

John, Doe, john.doe@trainee.unix-lambda.fr
Carrie, Mathison, carrie.mathison@trainees.univ-lambda.fr

We remind you that the use of academic e-mail addresses is to be strongly preferred to gmail or any other non-professional services.

That CSV file has to be uploaded (scp) to a Grid'5000 frontend for the next step.

Note.png Note

Some of the trainees may already have a Grid'5000 account: this is handled by the script. Please list all trainees in the CVS, even if some of them already have a Grid'5000 account, because all must be added to the tutorial group.

Use g5k-create-tutorial-accounts on the frontend to create accounts

Assuming you are connected to Grenoble's frontend and where you uploaded the CSV file named list.csv.

To create the trainees' user accounts, do the following:

Terminal.png fgrenoble:
g5k-create-tutorial-accounts -f list.csv -e myEngineName
Warning.png Warning

g5k-create-tutorial-accounts automatically creates active accounts and add them to the lab's user group. The operation cannot be undone: accounts cannot be deleted and any modification has to be done manually on every account individually. Therefore, before executing the script, be sure that all the information contained in the CSV file is correct.

Note.png Note

You may run this script several times, it is idempotent. You may add more trainees to the CSV and rerun the script.

Resource reservation

Depending on your needs, you can reserve Grid'5000 resources in advance.

However, note that you probably don't need to reserve resources in advance if your tutorial occurs during the usage policy restriction period (daytime in Paris timezone) and:

  • it does not require many resources
  • it does not require very specific or rare resources
  • it does not have many participants

Still, if you want to reserve resources in advance, one strategy is to reserve them as usual in Grid'5000, and delete your jobs (e.g. using oardel) just before your tutorial begins (if the tutorial duration is long, split by 2, and delete the second reservations later). Another strategy is to use a job of type container for your advance reservation and let students use jobs of type inner (see Advanced_OAR#Container_jobs).

Please note that you should use your tutorial lab project name when you submit your advance reservations for your tutorial (e.g oarsub --project LAB-20XX-NAME ... ) in order to preserve your ability to use your advance reservation rights for your normal usage of Grid'5000 (see Privilege levels table).

Warning.png Warning

If however your advance reservation(s) for your tutorial would absolutely require more resources than allowed by the Grid'5000 usage policy, you must request a special usage permission, as described by the procedure detailed in Grid5000:SpecialUsage.

Access to Grid'5000, connection using SSH

Past experiences show that many problems are related to some difficulties with the connection to Grid'5000 with SSH keys.

To use Grid'5000, trainees must have basic knowledge of SSH, and especially know how to generate SSH private and public keys and use them to connect to a remote machine. Don't hesitate to spend time at the beginning of the tutorial to explain it. More information on this topic is available at SSH and Getting_Started#Connect_to_a_Grid.275000_access_machine.

FAQ

If this FAQ does not cover one of your questions, do not hesitate to question by mail [1].

Does every trainee account need to be validated before the trainee can use the platform?

Contrary to what is done with the normal workflow using the account creation form, no validation is required when the engine is used. The script g5k-create-tutorial-accounts creates active accounts.

What do the trainees need to do to get their account ready to use?

Created accounts are active right away after the initial procedure, but trainees have to create their passwords and provide their SSH public keys before being able to connect for the first time. Otherwise, they are not able to connect to any of the grid5000 services.

To do so, they received by email an URL that they must open in a web browser. Every trainee must fill the form in the web browser, with a personal password and SSH public key.

How does the email sent to students look like?

Here is a sample of such an email:

Subject: [Grid5000-account] Your Grid5000 account was created by ...

Dear Firstname Lastname (username), 

You receive this email because your manager (...) requested a Grid5000
account for you in the context of a tutorial. To get more information about
Grid5000, see the website: http://www.grid5000.fr.

Your login on the Grid5000 platform is: username.

The next two steps for you are now to:

1/ Finish setting up your access to the platform by creating a password and an SSH key.

   To do so, open the following URL:
   https://public-api.grid5000.fr/stable/users/setup_password?password_token=XXXXXXXXXXXXXXXXXXXXXX#special.

2/ Read carefully the two following pages:

   The Grid5000 getting started documentation (https://www.grid5000.fr/w/Getting_Started),
   which gives important information on how to use the platform.

   The Grid5000 usage policy (https://www.grid5000.fr/w/Grid5000:UsagePolicy),
   which gives the rules that MUST be followed when using the platform. Note that any
   abuse will automatically be detected and reported to your manager.

How does the form the students open to set their passwords and SSH keys look like?

Opening https://public-api.grid5000.fr/stable/users/setup_password?password_token=XXXXXXXXXXXXXXXXXXXXXX#special shows: UMS tutorial password and ssh key form.png

My trainees told me they did not receive any email

Do the following:

  • Check that the email addresses you put in the CSV file are correct.
  • Ask the trainees to check their spam box.
  • Ask the trainees to reset their password using Special:G5KChangePassword. This will send a new email to them, with the instruction to reset their password.

One of my trainees is not able to log in

Some possible causes:

  • The trainee is not using the correct login. The login is not an email address. He should have received it by email.
  • The trainee did not set up the password using the URL received by email.
  • The trainee does not remember the password. In that case, the password can reset using Special:G5KChangePassword.

One of my trainees is not able to ssh the frontend

Possible causes:

  • The trainee is not using a correct login. The Grid'5000 login may differ from their usual login when using a workstation or another platform. In that case, the trainee can use the -l G5K_USERNAME option in the SSH command.
  • The trainee did not set their SSH private key in the machine (workstation) where the connection to Grid'5000 is made from.
  • The trainee did not set up an SSH key when they used the URL to set up their password. To fix this, the trainee can connect to UMS, click on the left panel SSH keys, and then copy/paste their public SSH key.

Note that one cannot connect to the Grid'5000 frontends directly (e.g. fgrenoble.grenoble.grid5000.fr). One first needs first to connect to the access machine: access.grid5000.fr.

To avoid the two-steps connection (access machine, then frontend) and connect directly to frontends, one can configure the SSH config file ~/.ssh/config as follows:

Host g5k
  User G5K_USERNAME
  Hostname access.grid5000.fr
  ForwardAgent no
Host *.g5k
  User G5K_USERNAME
  ProxyCommand ssh g5k -W "$(basename %h .g5k):%p"
  ForwardAgent no

Then,

  • Accessing the frontend (here, of Grenoble) can be done with:
ssh grenoble.g5k

From there, resources access is managed with the Grid'5000 tools (OAR commands and so on). See the Getting Started tutorial.

What happens if one of my trainees already has a Grid5000 account?

This case is covered by the procedure: the CSV file can and must contain the email addresses of trainees that already have an account.

Several cases then
  • If the existing account is active, the account is just added in the group of the tutorial/lab.
  • If the existing account is retired, the account is re-activated before being added to the groups of the tutorial/lab as above.
  • However, if the existing account is locked, it needs an intervention from support-staff. For the record, an account can be locked for one of these two reasons: its email address bounces (mostly because invalid), or the user was sanctioned for a misuse of the platform.
  • Last, by running the script it may happen that you create a new account for a trainee that already had one, that because the email address you provided for a trainee differs from the one of the trainee's existing account. The trainee may want to use their existing account rather than the new one you created. In that case, you can just run again the script with a CSV containing only one line with the information about that trainee, but changing the email address to that of the previously existing account of the trainee.

The g5k-create-tutorial-accounts script returned an error for one of trainee

If you get an error, please contact support-staff.

List of the tutorials/labs using Grid5000

Note.png Note

If you indeed organize a tutorial which uses Grid5000, we kindly ask it to be recorded in the list below.

The following list contains the tutorials already organized on Grid'5000
  • Un module de formation Scikit-Learn à Inria Academy, Hands-on scikit-learn, 2025
  • Un TP en Master 1 TAL à l'Université de Lorraine / IDMC. Introduction à Grid5000, en 2020-2021-2022-2023.
  • Un TP en Master 1 Informatique à l'Université de Lille, depuis 2010. Initiation à un environnement et des paradigmes de calcul distribué: réservation de machines et déploiement (oar/kadeploy), traitement d'applications Embarrassingly parallel en mode batch, programmation MPI, expérimentation, scalabilité et mesure de performance. Un groupe d'une vingtaine d'étudiants environ. 3 séances de TP environ.
  • Un TP à Rennes, avec Nikos Parlavantzas et une intervention dans le master MRI (1 cours, 2 TP par D. Margery, années 2013-2014, 2014-2015 et 2015-2016. Repris par Matthieu Simonin depuis))
  • Un TP au cours de http://sc-camp, en 2011
  • Un TP à l'ENS Lyon (TP OpenStack aux master 2)
  • Un TP à l'ENS Lyon (12/2013) sur OpenCL (Sujet [2])
  • TP à l'ENS Lyon (2014-2015) "Distributed Systems" M1 course
  • Un projet, sur 8 semaines, à l'Ensimag (Grenoble-INP) (automne 2015, automne 2016) "Systèmes distribués et Cloud Avancé" (enseignant: Grégory Mounié), une cinquantaine d'élèves de niveau M2, groupés en 12 équipes
  • Un projet de Licence 3 informatique à l'Université de Montpellier (semestre pair 2016) "Prise en main d’OpenStack et mise en oeuvre d'un outil de déploiement d'applications simples sur des VMs" ) groupe de 4 étudiants, encadré par Hinde Lilia Bouziane.
  • Un TP en Master 2 à l'Université de Montpellier, décembre 2016, octobre et novembre 2017, novembre 2018 dans le cadre d'un cours "E-applications". Il s'agit d'un TP d'initiation à l'utilisation d'une plateforme distribuée : réservation de machines, exécution d'une application à distance et importation des résultats. Une trentaine d'étudiants répartis en deux groupes en 2016, une cinquantaine d'étudiants en 2017 et une quarantaine en 2018. TP encadré par Hinde Lilia Bouziane.
  • Un projet de Licence 3 informatique à l'Université de Montpellier, de novembre 2017 à juin 2018 (groupe de 2 étudiants). Le projet porte sur la programmation d'un traitement parallèle et distribué d'images. Projet encadré par Hinde Lilia Bouziane.
  • Un TP à l'IMT Atlantique (campus de Nantes) de 4 étudiants encadré par Mario Südholt de octobre 2018 à janvier 2019.
  • Un projet de Master 1 informatique à l'Université de Montpellier, de janvier à juin 2019 (groupe de 3 étudiants). Résumé "Nous disposons d'un algorithme d'apprentissage de relations sémantiques basé sur les relations existantes dans le réseau lexical du JeuxDeMots (http:www.jeuxdemots.org). La table générée est de grande taille, de l'ordre de plusieurs centaines de millions de lignes. L'objectif du projet est de distribuer cette table et de mettre en ouvre un algorithme d'apprentissage et d'exploitation de manière distribuée et parallèle.". Projet encadré par Hinde Bouziane et Mathieu Lafourcade.
  • Un projet de Master 1 informatique à l'Université de Montpellier, de janvier à juin 2019 (groupe de 2 étudiants). Le projet porte sur la programmation d'un traitement parallèle et distribué d'images (photogrammétrie). Projet encadré par Hinde Lilia Bouziane.
  • Un projet "deep learning" en M2 GI et Polytech INFO4 à l'université de Grenoble, de février à avril de 2019 à 2023 inclus. Projet encadré par Georges Quénot.
  • TP de l'UE Parallélisme, du M1 de l'UCBL (Simon Delamare), 2019-2020
  • TP de l'Université de Lille, M2 Data Science, MPI & GPU (Pierre Fortin), 2020-2021
  • TP Ensimag 3A ISI, systèmes distribués (Grégory Mounié), 2020-2021
  • TP de la filière MOSIG de l'UGA, calcul parallèle (Arnaud Legrand, Bruno Raffin, Frédéric Wagner), 2020-2021.
  • TP de l'Université de Montpellier : dans le cadre d'un cours "E-applications" de Master 2, initiation à l'utilisation d'une plateforme distribuée partagée : réservation de machines, exécution d'une application à distance et importation des résultats. Deux groupes de 25 étudiants (Hinde Bouziane), 2020
  • TP pour le Groupe Calcul, introduction à Grid'5000 (Simon Delamarre), 2020
  • TP de l'Université de Lille, 5ème année de la spécialité Informatique et statistiques (IS5) à Polytech Lille. Teaching labs on GPU programming. Module CHP (Calcul Haute Performance). 2 sessions de 2 heures (Pierre Fortin), 2020-2021
  • TP de Sorbonne Université, UFR d'ingénierie, Master d'informatique M1, parcours SFPN, Introduction au Calcul Haute-Performance, Charles Bouillaguet, 2020-2021
  • TP de ENS de Rennes, Master informatique, Module Cloud and Big Data, Anne-Cécile Orgerie et Shadi Ibrahim, 2015-2021
  • TP de l'UCBL, Master 1 Informatique, UE Parallélisme, Simon Delamare, 2020-2021
  • Tutorial "Installation, deployment and execution of Melissa; Understanding how to port an existing application into the Melissa framework", Bruno Raffin INRIA-DATAMOVE/LIG, 16 septembre 2021.
  • TP d'introduction à Grid5000 de l'Université de Lorraine (IDMC), Chuyuan Li, 22 septembre et 1er octobre 2021
  • Hackathon pour l'école automnale RESCOM de recherche du GDR RSD (Bruno De moura Donassolo, Arnaud Legrand, Matthieu Simonin), 4-8 octobre 2021.
  • TP de l'Université de Lille, 5ème année de la spécialité Informatique et statistiques (IS5) à Polytech Lille. Teaching labs on GPU programming. Module CHP (Calcul Haute Performance), Pierre Fortin, 2020-2021
  • TP de l'Université Grenoble-Alpes, INPG/Master Recherche MOSIG, Calcul Parallèle, Bruno Raffin & Frédéric Wagner, 2020-2021.
  • TP de l'université Aix Marseille, L3 Informatique, Impact du numérique, Julien Lefevre, 2021-2022
  • TP de Sorbonne Université, UFR d'ingénierie, Master d'informatique M1, parcours SFPN, Introduction au Calcul Haute-Performance, Charles Bouillaguet, 2021-2022
  • TP de LS2N, Membre de LS2N UMR à Nantes, Teaching the fundamentals of Grid'5000 platform for beginner users only for internal members of LS2N, Richard RANDRIATOAMANANA & Remous Aris KOUTSIAMANIS, 26-Jan 2022
  • TP de CY Paris Université, Master2 student, Heterogeneous programming on GPU (CUDA), Thierry Garcia, 22-Mar 2022
  • Tutoriel sur l'utilisation de la plateforme Grid'5000 dans le cadre du groupe de travail "plateformes" du GDR RSD, Simon Delamare et Pierre Jacquot, Mars 2022
  • TP de l'UCBL, Master 1 Informatique, UE Parallélisme, Simon Delamare, 2022
  • TP et petits projets de Sorbonne Université, Master’s in High Performance Computing (HPC), Parallel programming (PPAR), Charles Bouillaguet, 2022-2023
  • Un projet d'ingénierie sur le thème Lab on energy consumption - ANF User Support Tools for HPC 2023 organisé en juin 2023 par Mathilde Jay
  • Un TP à l'UCBL (Lyon 1) pour le Master informatique "TP développement d'applications parallèles hybrides, évaluation et analyse de leurs performances", d'avril à juin 2023.
  • Un projet à CY Tech Campus de Pau intitulé Project and simulation on GPU using CUDA facilities en M2 organisé de janvier à mars 2023 par Thierry Garcia
  • Un TP à UGA pour le Master Recherche MOSIG en 'Advanced Parallel System' de janvier à mars 2023 organisé par Bruno Raffin
  • TP et petits projets de Sorbonne Université, Master’s in High Performance Computing (HPC), Parallel programming (PPAR), Charles Bouillaguet, 2023-2024
  • TP Virtualisation Système et Réseau, FSI Master Informatique parcours SECIL spécialité Réseaux et Systèmes Distribués, Virtualisation Système et Réseau, Millian Poquet, 2023
  • TP de l'Université Grenoble-Alpes, Master2 MIAGE, "EcoWeb : Study the energy consumption of the various components of a host", Mathilde Jay, Octobre 2023
  • Projet et test de performance pour le cours de systèmes distribués, Ensimag 3A filière ISI (niveau M2), Université Grenoble-Alpes, Gregory Mounie, 2023-2024
  • Projet de développement NLP software, M2 IDMC - Institut des sciences du digital, du management et de la Cognition, software project, Maxime Amblard, 2023-2024
  • Un TP de l'Université de Lille, Master FST/Mathématiques, Practical works on usage of Grid'5000, OpenMP, MPI and Cuda, Jan Gmys et Nouredine Melab, 2023-2024
  • Un tutoriel d'utilisation de la chaîne de compilation Syfala (Audio to FPGA) sur des machines de Grid'5000, à destination du laboratoire CCRMA de l'université de Stanford, organisé par l'Equipe Emeraude le 24 octobre 2023
  • Un TP à UGA pour le Master Recherche MOSIG en 'Advanced Parallel System' jusqu'à mars 2024 organisé par Bruno Raffin
  • Module Systèmes embarqués, FSI, Master Informatique parcours SECIL, spécialité SIAME, à Univ. Toulouse III, Millian Poquet, 2023
  • Tutoriel Mesurer et comprendre la consommation d’un nœud de calcul - Eco-concevoir un code, ANF 8R EcoInfo Energie, Laurent Lefevre, 2023
  • Tutoriel Mesurer et comprendre la consommation d’un nœud de calcul - Eco-concevoir un code, ANF ENVOL, Laurent Lefevre, 2023
  • TP OpenStack, Master FIL A3 Back, IMT Atlantique, Baptiste Jonglez, 2023
  • Un TP pour le Master d'Informatique de l'Université de Franche Comté "Introduction à un environnement de type grille de calcul et prise en main d'outils de mesures de consommation énergétique", 2023
  • Un TP (deux sessions) pour l'ISTIC de l'Université de Rennes "Lab sessions in the context of the Cloud, Network and Infrastructure course (getting started + scripting)", 2023
  • Un tutoriel d'utilisation de la chaîne de compilation Syfala (Audio to FPGA) sur des machines de Grid'5000, à destination du laboratoire CCRMA de l'université de Stanford, organisé par l'Equipe Emeraude le 5 décembre 2023
  • Un TP pour la Faculté d'Informatique et de mathématiques appliquées, Master Informatique co-habilité UT3 et UFAR, "Programm Cuda algorithm and evaluate their power consumption", organisé par Georges Da Costa
  • Un TD pour le Master 2 ISFA, Université de Lyon, Grid’5000 introduction and Data Management Introduction, organisé par Eddy Caron, 2023-2024
  • TP de l'université Aix Marseille, L3 Informatique, Impact du numérique, Julien Lefevre, 2023-2024
  • TP pour l'école Aivancity (Cachan) : Practical work on energy measurement and software eco-design, par Laurent Lefevre du 5/2/2024 au 6/2/2024
  • TP pour le Bachelor in Applied Mathematics and Informatics, University of Sofia, "Familiarizing students with parallel computing runtimes and speedup studies", par Vania Marangozova (LIG/Erods) au premier trimestre 2024
  • Projet "système de classification d'images par apprentissage profond" (sur GPU) - Univ. Grenoble Alpes, Ingénieur de Polytech Grenoble et Master 2 spécialité Informatique, UE Documents multimédia : Accès et Recherche d'Information, Georges Quénot <Georges.Quenot@imag.fr>, 2024
  • Projet "Few-shot Learning" Master 2 IAFA de Paul Sabatier Toulouse, University Toulouse 3, Sandrine Mouysset, Millian Poquet <millian.poquet@univ-tlse3.fr>, 2024
  • TP pour Project and simulation on GPU using CUDA facilities, master2, module Heterogeneous programming on GPU (CUDA) CY Tech Campus de Pau,Thierry GARCIA <thierry.garcia@irit.fr> , 2024
  • Un TP à l'Observatoire Midi Pyrénées intitulé "Mesurer et comprendre la consommation d’un nœud de calcul - Eco-concevoir un code", organisé les 26 mars 2024 par Laurent Lefevre (ENS/LIP/Avalon).
  • Un Tutotechno co-organisé par le SED Inria-Université de Lorraine et le Loria/SISR (Nancy) intitulé "Deep Learning on Grid 5000"
  • Un TP à l'Ecole Aivancity (Cachan) intitulé "Mesurer et comprendre la consommation d’un nœud de calcul - Eco-concevoir un code", organisé les 5 et 6 février 2024 par Laurent Lefevre (ENS/LIP/Avalon).
  • Un TP à l'IMT Atlantique (FISE A3 TAF LOGIN), UE nuage, sur le déploiement d'Openstack, pour des étudiants de master, organisé en mars 2024 par Baptiste Jonglez et Daniel Balouek.
  • Un TP à l'IMT Atlantique (FIL A3 Back), UE Cloud, sur le déploiement d'Openstack, pour des étudiants de master, organisé en novembre 2023 par Baptiste Jonglez et Daniel Balouek.
  • Un TP à l'IMT Atlantique (FIL A3 Back), UE Cloud, sur le déploiement d'Openstack, pour des étudiants de master, organisé en octobre 2022 par Baptiste Jonglez et Adrien Lebre.
  • Un TP pour le GDS CNRS EcoInfo. Un après midi de mesures énergétiques sur le site de Lyn et éco-conception logicielle, organisé en octobre 2022 par Laurent Lefevre (ENS/LIP/Avalon).
  • Un TP en master 1 TAL à l'Université de Lorraine / IDMC. Training deeplearning models on speech and MRI data, en 2023.
  • Projet pour classes préparatoires Lycée Champollion, Université Grenoble Alpes, Préparation TIPE sur le HPC, en 2024
  • Un TP "Benchmarks with energy consumption measurements" pour l'ANF "ImpactNum", en 2024 par Guillaume Raffin
  • Un TP "Green I.T." pour la Summer school Green I.T., 2024 par Remous-Aris Koutsiamanis
  • Tutorial on how to use EnOSlib on G5k in the context of ACM REP 2024, Matthieu Simonin et Baptiste Jonglez, 2024.
  • Un TP pour le Master 2 de Data Science à l'Université de Lille, Teaching labs with MPI, then GPU and possibly MPI+GPU, organisé par Pierre Fortin, 2024-2025
  • Un tutoriel pour le Master 2 d'Informatique, en Informatique Responsable à l'UFR ST, introduction à un environnement de type grille de calcul

et prise en main d'outils de mesures de consommation énergétique, organisé par Louis-Claude Canon, 2024

  • Un TP pour le Master 2 ALMA (Architecture Logicielles), à l'Université de Nantes, Daniel Balouek, 2024
  • Un TP pour le Master 1 d'Informatique, parcours HPC / CCA / QI à Sorbonne Université, travaux pratique et réalisation de petits projets de HPC, organisé par Charles Bouillaguet, 2024-2025
  • Un TP pour la conférence e-Science 2024, The tutorial learn about edge-cloud management policies in the context of urgent applications.
  • Un TP pour le Master 1 IDMC (Institut des sciences du Digital, Management Cognition) sur "the basic usages of grid’5000 and let students practice", 2024-2025
  • Un TP pour le Master 2 IDMC (Institut des sciences du Digital, Management Cognition) sur "the basic usages of grid’5000 and let students practice", 2024-2025
  • Un TP pour le Master FSI, Master Informatique parcours SECIL sur la "Virtualisation Système et Réseau", 2024
  • Un TD pour le Master 2 ISFA, Université de Lyon, Grid’5000 introduction and Data Management Introduction, organisé par Eddy Caron, 2024-2025
  • Un TP pour le Master M2 Calcul Scientifique, Université de Lille, Practical works on usage of OpenMP, MPI and Cuda, organisé par Jan Gmys et Nouredine Melab; 2024-2025
  • Un Projet pour le Master Grenoble-INP/Ensimag, module "Systèmes distribués", Université de Grenoble Alpes, écriture d'un make distribué avec diverses plateforme. Mesures de performance à l'échelle. Organisé par Grégory Mounié, 2024-2025
  • Un TP pour le Master 2 FSI, Master Informatique parcours SECIL, spécialité SIAME : "Program algorithms with multiple langages and measure performance and energy with RAPL", module "Systèmes embarqués", Univ. Toulouse III, organisé par Georges Da Costa, 2024
  • Un tutoriel pour le séminaire en santé numérique à PariSanté Campus, pour savoir comment utiliser Armored Node, CompuVault, Nipype/Pydra, etc.. sur Abaca, organisé par Yao Chi, 2024
  • TP OpenStack, Master FIL A3 Back, IMT Atlantique, Baptiste Jonglez, 2024
  • Un TP pour le Master ALMA, Université de Nantes, Capstone, Orchestration of services on sensor-edge-cloud resources using Kubernetes. Consist of deployment of Kubernetes and placement algorithms on heterogeneous resources, Daniel Balouek, 2024-2025
  • Un TP à UGA pour le Master Recherche MOSIG en 'Advanced Parallel System' jusqu'à mars 2025 organisé par Bruno Raffin
  • TP Pour le Master ISTIC en Cloud and Network Infrastructure par Matthieu Simonin
  • TP pour la Licence 3, parallélisme et performance par Pierre Fortin, 2024-2025
  • Un TP de Master Informatique parcours SECIL : Systèmes embarqués et connectés jusqu'à fin juin 2025, Performance/energy evaluation of software on various hardware, organisé par Millian Poquet à l'Université de Toulouse
  • Un tutoriel dans le cadre du PEPR NumPEX : "How to use Guix and Spack for Application Deployment Across Supercomputers", organisé par Pierre Neyron, 2025
  • Un TP pour le master Informatique SIRAV/IL, Université de Lorraine, Traitement de données massives, organisé par Thomas Lambert, 2025
  • Un TP pour le cursus ingénieur généraliste spécialisation Software Engineering, IMT Atlantique, Déploiement d'Openstack, organisé par Baptiste Jonglez , 2025
  • Un TP pour l'UE Parallélisme, Université Claude Bernard Lyon1, organisé par Simon Delamare, 2025
  • Une formation "usages de l'IA : enjeux sociétaux, environnementaux et organisationnels", Université de Grenoble, organisé par Guillaume Raffin, 2025
  • Un TP dans le carde du PEPR Numpex: Spack for Beginners, organisé par Fernando Ayats Llamas, 2025
  • Un TP dans le cadre de la conférence francophone COMPAS: Environnements distribués reproductibles avec NixOS-Compose, organisé par Quentin Guilloteau, Olivier Richard et Millian Poquet, 2025
  • Evaluation - Short bookings to evaluate the artifacts of the accepted papers of the SOSP'25 conference, Baptiste Lepers, août 2025
  • Un TP pour le master 2 Data Science, HPC (utilisation de MPI et combinaison GPU+MPI) par Pierre Fortin, 2025
  • Un TP pour le master informatique, Informatique responsable : introduction à un environnement de type grille de calcul et prise en main d'outils de mesures de consommation énergétique, organisé par Louis-Claude Canon, 2025
  • Un TP pour le Master ALMA, Université de Nantes, Orchestration of services on sensor-edge-cloud resources using Kubernetes. Consist of deployment of Kubernetes and placement algorithms on heterogeneous resources, Daniel Balouek, 2025
  • Un tutoriel dans le cadre de la RSECon 2025 sur la reproductivité avec Guix, Julien Castelneau - Ghislain Vaillant, 2025
  • Un TP pour le cursus Administration Système Avancée de Polytech Nantes, Université Nantes : Prise en main G5K et expérimentation Openstack, Baptiste jonglez - Daniel Balouek-Thomert, 2025
  • Un tutoriel dans le cadre d'un Workshop Informatique Durable à LISN , Université Paris-Saclay, Simon Delamare- Laurent Lefevre, 2025
  • Un tutoriel dans le cadre de travaux pratiques sur l'utilisation de OpenMP, MPI et Cuda, Université de Lille, Jan Gmys - Nouredine Melab, 2025
  • Un TP "Benchmarks with energy consumption measurements" pour "IA2 autumn school", Univ. Grenoble Alpes, Guillaume Raffin, 2025
  • Un tutoriel NumPEX : "Introduction to Guix", organisé par Romain Garbage, Bruno Raffin et Pierre Neyron, 2025
  • Un tutoriel pour le Master SECIL, University of Toulouse, "Program algorithms with multiple langages and measure performance and energy with RAPL", par Georges Da Costa, 2025