# Build this image: docker build -t mpi . # FROM paddledev/paddle:0.10.0rc3 ENV DEBIAN_FRONTEND noninteractive RUN apt-get update -y && \ apt-get upgrade -y && \ apt-get install -y openssh-server zip unzip vim sudo \ gcc gfortran openmpi-checkpoint binutils wget curl git openmpi-bin openmpi-common libopenmpi-dev && \ pip install mpi4py numpy virtualenv scipy matplotlib lxml sqlalchemy suds ipython obspy && \ mkdir /var/run/sshd && \ echo 'root:tutorial' | chpasswd && \ sed -i 's/PermitRootLogin without-password/PermitRootLogin yes/' /etc/ssh/sshd_config && \ # SSH login fix. Otherwise user is kicked off after login sed 's@session\s*required\s*pam_loginuid.so@session optional pam_loginuid.so@g' -i /etc/pam.d/sshd && \ echo "export VISIBLE=now" >> /etc/profile && \ adduser --disabled-password --gecos "" tutorial && \ echo "tutorial ALL=(ALL) NOPASSWD:ALL" >> /etc/sudoers && \ mkdir /home/tutorial/.ssh/ ENV HOME /home/tutorial ENV NOTVISIBLE "in users profile" # ------------------------------------------------------------ # Set-Up SSH with our Github deploy key # ------------------------------------------------------------ ADD ssh/config /home/tutorial/.ssh/config ADD ssh/id_rsa.mpi /home/tutorial/.ssh/id_rsa ADD ssh/id_rsa.mpi.pub /home/tutorial/.ssh/id_rsa.pub ADD ssh/id_rsa.mpi.pub /home/tutorial/.ssh/authorized_keys #--------------------------------------------------------------- #LD_LIBRARY_PATH #--------------------------------------------------------------- RUN export LD_LIBRARY_PATH=/usr/lib/openmpi/lib/ WORKDIR /home/tutorial EXPOSE 22 CMD ["/usr/sbin/sshd", "-D"]