From 365763796b3a41e6b91d4375a4d63f4ae718ada6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Adam=20Fory=C5=9B?= Date: Wed, 4 Oct 2023 19:31:52 +0200 Subject: [PATCH] Initial container usage documentation. (#8) * Add containers documentation. * Update spawning the docker image with docker run. --- .github/CONTRIBUTING.md | 89 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 89 insertions(+) diff --git a/.github/CONTRIBUTING.md b/.github/CONTRIBUTING.md index 677d0521..df42b284 100644 --- a/.github/CONTRIBUTING.md +++ b/.github/CONTRIBUTING.md @@ -54,4 +54,93 @@ as possible to discuss further details. See [Contribution to {admiral}](https://pharmaverse.github.io/admiral/cran-release/articles/contribution_model.html) for additional details. +# Containers guideline +This guideline will walk you through the process of setting up and using the Oak image in both GitHub Codespaces and Visual Studio Code's devcontainer functionality. + +## Use GitHub Codespaces + +1. **Prerequisites** : + +* Have a GitHub account. +* The repository you want to open in Codespaces must be under your account or you must have appropriate permissions. + +2. **Open the Repository** : + +* Navigate to the desired GitHub repository on GitHub's website. + +3. **Start Codespaces** : + +* Click on the "Code" button (it has a green color most of the times). +* In the dropdown, you'll find an option named "Open with Codespaces". Click on it. + +4. **Choose or Create a Codespace** : + +* If you've already created a Codespace for this repository, you'll see it listed. You can click on it to open. +* If not, click on the "+ New codespace" button. + +5. **Configure the Environment (If needed)** : + +* Depending on the repository, you might have a `.devcontainer` folder which will define the environment. GitHub Codespaces will use the settings defined here to set up the environment. +* If you need to customize or install additional tools, you can do so once the Codespace is launched. + +6. **Use Codespaces** : + +* Once your environment is set up, you'll have an instance of Visual Studio Code running in your browser, connected to the repository. +* You can now edit, run, and debug your code just like you would in a local environment. + +7. **Close the Codespace** : + +* When you're done, you can close the browser tab/window. +* Remember, you'll be billed (if you're on a paid plan) for the time your Codespace is running, so it's a good idea to stop or delete it if you're not using it. You can do this from the Codespaces tab in your GitHub repository. + +## Use Visual Code devcontainer + +1. **Prerequisites** : + +* Have a Docker and VS Code installed +* linux/arm64 is supported only for R 4.3 + +2. **Install devcontainer extension** : + +* In the left sidebar, click on the extensions icon (it looks like square blocks or a Lego piece). +* In the search bar, type "Dev Containers" to search for the extension. +* From the search results, locate the "Dev Containers" extension provided by Microsoft and click the 'Install' button. + +3. **Open in Container** : + +* In VS Code, use the command palette (`Ctrl+Shift+P` or `Cmd+Shift+P` on macOS) and run the "Dev Containers: Rebuild and Reopen in Container" command. VS Code will then set up the devcontainer using the Oak image. + +4. **Using the Devcontainer** : + +* Once the environment is set up, you can start coding in VS Code as if you were in a local environment, but with the capabilities and tools provided by the Oak image. + +## Use docker run + +1. **Prerequisites** : + +* Have a docker installed + +2. **Example command** : + +``` +docker run --rm -d \ + --name oak-dev \ + -p 127.0.0.1:8888:8787 \ + -e ROOT=true -e DISABLE_AUTH=true \ + -v "$(pwd):/home/rstudio/oak" \ + ghcr.io/pharmaverse/sdtm.oak-4.3:latest +``` + +This command is used to start a new container from a Docker image. Here's a breakdown of the parameters used: + +* docker run: This is the basic command to start a new container from a Docker image. +* --rm: This option ensures that the container is removed automatically when it's stopped. This is useful if you don’t want to keep the container around once you're done with it, helping to save storage space. +* -d: This option runs the container in detached mode, which means the container runs in the background and doesn't attach to your command line session. +* --name oak-dev: This assigns the name oak-dev to the container. Naming your containers makes them easier to identify and manage. +* -p 127.0.0.1:8888:8787: This maps port 8787 inside the container to port 8888 on the host machine, and binds it to the localhost IP (127.0.0.1). The format is -p ::. This means any traffic directed at port 8888 on your host machine will be forwarded to port 8787 in the container. +* -e ROOT=true -e DISABLE_AUTH=true: These are environment variables being passed into the container. -e denotes that an environment variable is being set. In this case, two environment variables are being set: + * ROOT=true: This likely grants root permissions inside the container. + * DISABLE_AUTH=true: This likely disables authentication when opening RStudio. +* -v "$(pwd):/home/rstudio/oak": This maps a volume (essentially a directory) from the host machine into the container. The $(pwd) is a command that returns the current directory you're in on the host machine. This current directory is then mapped to /home/rstudio/oak inside the container. This is useful for sharing files between your host machine and the container. +* ghcr.io/pharmaverse/sdtm.oak-4.3:latest: This is the name of the Docker image that the container will be created from. It's pulled from the GitHub Container Registry (ghcr.io) and the image belongs to the pharmaverse repository. The image name is sdtm.oak-4.3 and the tag being used is latest. There are image for three versions available.