From df863db7fcd085d8d93e9b19ddd918a8e2d4f8a4 Mon Sep 17 00:00:00 2001 From: SamueleSoraggi Date: Tue, 25 Jun 2024 14:22:08 +0200 Subject: [PATCH] updates --- access/genomedk.qmd | 98 +++++++++++++++++++++---------------- images/nodeAndUsername.png | Bin 0 -> 11732 bytes 2 files changed, 55 insertions(+), 43 deletions(-) create mode 100644 images/nodeAndUsername.png diff --git a/access/genomedk.qmd b/access/genomedk.qmd index f3ca176..1b54931 100644 --- a/access/genomedk.qmd +++ b/access/genomedk.qmd @@ -11,6 +11,16 @@ hide: If you are using GenomeDK, you have two options. One is to use a pre-packaged Docker container, which contains jupyterlab and the necessary packages you need to run all the notebooks. GenomeDK comes with `singularity`, which can import and execute Docker containers (with some perks, such as not showing system folders in the container, but we are going to take care about it by running a simple script) and is able to ensure full reproducibility of the analysis. The second option is to download the github repository of the course and create your own conda environment: this solution works also on any computing cluster where you can have `conda` installed and is shown [in the page dedicate to the access with any computing cluster](./otherHPC.qmd). +:::{.callout-warning title="Technical prerequisites"} + +- if you do not yet have an account on GenomeDK, please get one [Click on this link to get to the account request.](https://console.genome.au.dk/user-requests/create/) and follow the instructions for the 2-factor authentication. + +- you need to have (or be part of) an active project on GenomeDK. This ensures you can get some computing resources to run the course material. [Follow these instructions to request a project.](https://genome.au.dk/docs/projects-and-accounting/#requesting-a-project). + +- In Windows and the Powershell command line, commands might need `.exe` at the end, such as `ssh.exe` instead of `ssh`. Newer versions of Windows do not require that, though. + +::: + ## Singularity container **1.** Log into the cluster using the command line, and substituting `USERNAME` with your actual user name: @@ -19,15 +29,14 @@ If you are using GenomeDK, you have two options. One is to use a pre-packaged Do ssh USERNAME@login.genome.au.dk ``` -:::{.callout-warning title="Technical prerequisites"} - -- if you do not yet have an account on GenomeDK, please get one [Click on this link to get to the account request.](https://console.genome.au.dk/user-requests/create/) and follow the instructions for the 2-factor authentication. +and be sure to run those two commands to remove space-filling cache data -- you need to have (or be part of) an active project on GenomeDK. This ensures you can get some computing resources to run the course material. [Follow these instructions to request a project.](https://genome.au.dk/docs/projects-and-accounting/#requesting-a-project). +```{.bash} -- In Windows and the Powershell command line, commands might need `.exe` at the end, such as `ssh.exe` instead of `ssh`. Newer versions of Windows do not require that, though. +rm -rf ~/.apptainer/cache/* +rm -rf ~/.singularity/cache/* -::: +``` **2.** Get into a folder inside your project, for example @@ -39,16 +48,15 @@ cd MYPROJECT/ngsSummerSchool :::{.callout-warning title="NGS summer school 2024"} -Get instead into the folder for the course: +If you are at the NGS summer school 2024, run the following commands to create your own work folder inside the course project folder. Always go back to that in your future sessions: ```{.bash} -cd NGS_summer_school/USERNAME +mkdir -p ngssummer2024/`whoami` +cd ngssummer2024/`whoami` ``` -where you substitute `USERNAME` with your own user id. - ::: **3.** Use `singularity` to download the container of the course. This will take some time and show a lot of text, and at the end a file called `course.sif` is created into the folder. @@ -59,28 +67,41 @@ singularity pull course.sif docker://hdssandbox/ngssummerschool:2024.07 ``` -**4.** Now it's time to get a few resources to run all the material. We suggest one CPU and 32GB of RAM for the first three modules, and 2 CPUs and 64GB of RAM for the single-cell analysis. For the first configuration suggested, you get resources using +:::{.callout-warning} + +You need to do this step only once! + +::: + +**4.** Now it's time to get a few resources to run all the material. We suggest one CPU and 32GB of RAM for the first three modules, and 2 CPUs and 64GB of RAM for the single-cell analysis. For the first configuration suggested, for example, you get resources using ```{.bash} -srun --mem=32g --cores=1 --time=8:0:0 --account=MYPROJECT --pty /bin/bash +srun --mem=32g --cores=1 --time=4:0:0 --account=MYPROJECT --pty /bin/bash ``` -and very similarly for the second configuration, when you want instead to work on the single cell analysis. +:::{.callout-warning title="NGS summer school 2024"} -:::{.callout-warning} +If you are at the NGS summer school 2024, use `ngssummer2024` instead of `MYPROJECT` + +```{.bash} + +srun --mem=32g --cores=1 --time=4:0:0 --account=ngssummer2024 --pty /bin/bash -Note you need your project name, and you can also choose for how long you want the resources to be available to you. **Asking for resources means waiting for some time in a queue before they are assigned.** +``` ::: -**5.** Once resources are assigned, note down the node name. This is on the left side of the command line: for example, in the figure below, the node is `s21n33` +:::{.callout-note} -![](../images/genomedkNode.png){fig-align="center" width="400px"} +Note you always need your project name, and you can also choose for how long you want the resources to be available to you. **Asking for resources means waiting for some time in a queue before they are assigned.** +In the example above `time` is 4 hours. After this time, whatever you are doing will be closed, so be sure to save your work in progress. -**6.** execute the container with +::: + +**5.** execute the container with ```{.bash} singularity exec course.sif /bin/bash @@ -88,41 +109,41 @@ singularity exec course.sif /bin/bash Note that the command line shows now `Apptainer>` on its left. We are *inside* the container and the tools we need are now available into it. -**7.** Now we need to run a configuration script, which will setup jupyterlab so that the packages are detected correctly. This is downloaded from the internet and runs immediately, downloading also the necessary data. If a folder called `Data` exists, it will not download the data again (also meaning that you can use our container with your own data folder for your own analysis in future) +**6.** Now we need to run a configuration script, which will setup jupyterlab so that the packages are detected correctly. This is downloaded from the internet and runs immediately, downloading also the necessary data. If a folder called `Data` exists, it will not download the data again (also meaning that you can use our container with your own data folder for your own analysis in future) ```{.bash} - +git config --global http.sslVerify false wget -qO- https://raw.githubusercontent.com/hds-sandbox/NGS_summer_course_Aarhus/docker/scripts/courseMaterial.sh | bash ``` -:::{.callout-warning} - -You need to create the file `course.dif` only once. Next time, you only need the configuration script. - -::: - -**8.** We are ready to go. Activate the environment and start jupyterLab with the following: +**6.** We are ready to go. Activate the environment and start jupyterLab with the following: ```{.bash} +unset XDG_RUNTIME_DIR conda activate /opt/conda/envs/NGS_aarhus_py -jupyter-lab --no-browser --port=$UID --ip=0.0.0.0 +jupyter-lab --no-browser --port=$UID --ip=0.0.0.0 --NotebookApp.token='' --NotebookApp.password='' ``` -you will see a lot of messages, which is normal. You need also to create a tunnel between your computer and genomeDK to be able to see jupyterlab in your browser. Now you need to use the node name you wrote down before! **Open a new terminal window** and write +you will see a lot of messages, which is normal. At the end of the messages, you are provided two links looking as in the image below. Write down the node name and the user id highlighted in the circles. You need them in the following steps. + +![](../images/nodeAndUsername.png){width=600px} + + +**7.** You need also to create a tunnel between your computer and genomeDK to be able to see jupyterlab in your browser. Now you need to use the node name and the user id you wrote down before! **Open a new terminal window** and write ```{.bash} -ssh -L6835:NODENAME:6835 USERNAME@login.genome.au.dk +ssh -L USERID:NODENAME:USERID USERNAME@login.genome.au.dk ``` -where you substitute `NODENAME` with the correct depiction,and USERNAME with your own user id. +where you substitute `USERID` and `NODENAME` as you wrote down before, and then USERNAME is your account name on GenomeDK. For example `ssh -L 6835:s21n81:6835 samuele@login.genome.au.dk` according to the figure above for a user with name `samuele`. -**9.** Open your browser and go to the address [http://127.0.0.1:6835/lab](http://127.0.0.1:6835/lab). Jupyterlab opens +**8.** Open your browser and go to the address http://127.0.0.1:USERID/lab, where you need your user id again instead of USERID. For example `http://127.0.0.1:6835/lab` from the figure above. Jupyterlab opens in your browser. -**10.** Now you are ready to use JupyterLab for coding. Use the file browser (on the left-side) to find the folder `Notebooks`. Select one of the four tutorials of the course. You will see that the notebook opens on the right-side pane. Read the text of the tutorial and execute each code cell starting from the first. You will see results showing up directly on the notebook! +**9.** Now you are ready to use JupyterLab for coding. Use the file browser (on the left-side) to find the folder `Notebooks`. Select one of the four tutorials of the course. You will see that the notebook opens on the right-side pane. Read the text of the tutorial and execute each code cell starting from the first. You will see results showing up directly on the notebook! ![](../images/startNotebook.gif) @@ -132,18 +153,9 @@ Right click on a notebook or a saved results file, and use the download option t ::: -**11.** At the end of your session, it is a good idea to empty the cache of `singularity`. This will fill up your home folder very quickly (size limit is 100GB). Simply run these two commands: - -```{.bash} - -rm -rf /home/samuele/.apptainer/cache/* -rm -rf ~/.singularity/cache/* - -``` - ### Recovering the material from your previous session -Everything is saved in the folder you are working in. Next time, follow the whole procedure again - the download script will only link the packages to jupyterlab and avoid downloading new data, notebooks and scripts, because the folders will be detected as existing! +Everything is saved in the folder you are working in. Next time, follow the whole procedure again (without step number **3.**) - the download script will only link the packages to jupyterlab and avoid downloading new data, notebooks and scripts, because the folders will be detected as existing! diff --git a/images/nodeAndUsername.png b/images/nodeAndUsername.png new file mode 100644 index 0000000000000000000000000000000000000000..0bfbcf88eb03eab3876f7099e278bea9e64f3c65 GIT binary patch literal 11732 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