diff --git a/Dockerfile b/Dockerfile index d38c1f26..404b8fa2 100644 --- a/Dockerfile +++ b/Dockerfile @@ -47,20 +47,29 @@ RUN ldconfig # clean up RUN pip cache purge -# switch to the rapidtide user -RUN useradd -m -s /bin/bash -G users rapidtide -RUN chown -R rapidtide /src/rapidtide -WORKDIR /home/rapidtide +# Create a shared $HOME directory +ENV USER=rapidtide +RUN useradd \ + --create-home \ + --shell /bin/bash \ + --groups users \ + --home /home/$USER \ + $USER +RUN chown -R $USER /src/$USER +WORKDIR /home/$USER ENV HOME="/home/rapidtide" + RUN /opt/miniforge3/bin/mamba init RUN echo "mamba activate science" >> /home/rapidtide/.bashrc RUN echo "/opt/miniforge3/bin/mamba activate science" >> /home/rapidtide/.bashrc + +# switch to the rapidtide user USER rapidtide # set up variable for non-interactive shell ENV PATH=/opt/miniforge3/envs/science/bin:/opt/miniforge3/condabin:.:/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin -ENV IS_DOCKER_8395080871=1 +ENV IN_DOCKER_CONTAINER=1 WORKDIR /tmp/ ENTRYPOINT ["/cloud/mount-and-run"] diff --git a/rapidtide/util.py b/rapidtide/util.py index de6d8bf7..3eb25f92 100644 --- a/rapidtide/util.py +++ b/rapidtide/util.py @@ -453,7 +453,7 @@ def version(): """ try: - dummy = os.environ["IS_DOCKER_8395080871"] + dummy = os.environ["IN_DOCKER_CONTAINER"] except KeyError: isdocker = False else: diff --git a/rapidtide/workflows/happy.py b/rapidtide/workflows/happy.py index 24f21a99..acbd998e 100644 --- a/rapidtide/workflows/happy.py +++ b/rapidtide/workflows/happy.py @@ -80,7 +80,7 @@ def happy_main(argparsingfunc): # if we are running in a Docker container, make sure we enforce memory limits properly try: - testval = os.environ["IS_DOCKER_8395080871"] + testval = os.environ["IN_DOCKER_CONTAINER"] except KeyError: args.runningindocker = False else: diff --git a/rapidtide/workflows/rapidtide.py b/rapidtide/workflows/rapidtide.py index 98e2301b..94397a10 100755 --- a/rapidtide/workflows/rapidtide.py +++ b/rapidtide/workflows/rapidtide.py @@ -268,7 +268,7 @@ def rapidtide_main(argparsingfunc): print("turning on garbage collection") # if we are running in a Docker container, make sure we enforce memory limits properly - if "IS_DOCKER_8395080871" in os.environ: + if "IN_DOCKER_CONTAINER" in os.environ: optiondict["runningindocker"] = True optiondict["dockermemfree"], optiondict["dockermemswap"] = tide_util.findavailablemem() if optiondict["dockermemfix"]: