github.com/tompao/docker@v1.9.1/docs/examples/running_ssh_service.md (about)

     1  <!--[metadata]>
     2  +++
     3  title = "Dockerizing an SSH service"
     4  description = "Installing and running an SSHd service on Docker"
     5  keywords = ["docker, example, package installation,  networking"]
     6  [menu.main]
     7  parent = "smn_apps_servs"
     8  +++
     9  <![end-metadata]-->
    10  
    11  # Dockerizing an SSH daemon service
    12  
    13  ## Build an `eg_sshd` image
    14  
    15  The following `Dockerfile` sets up an SSHd service in a container that you
    16  can use to connect to and inspect other container's volumes, or to get
    17  quick access to a test container.
    18  
    19      # sshd
    20      #
    21      # VERSION               0.0.2
    22  
    23      FROM ubuntu:14.04
    24      MAINTAINER Sven Dowideit <SvenDowideit@docker.com>
    25  
    26      RUN apt-get update && apt-get install -y openssh-server
    27      RUN mkdir /var/run/sshd
    28      RUN echo 'root:screencast' | chpasswd
    29      RUN sed -i 's/PermitRootLogin without-password/PermitRootLogin yes/' /etc/ssh/sshd_config
    30  
    31      # SSH login fix. Otherwise user is kicked off after login
    32      RUN sed 's@session\s*required\s*pam_loginuid.so@session optional pam_loginuid.so@g' -i /etc/pam.d/sshd
    33  
    34      ENV NOTVISIBLE "in users profile"
    35      RUN echo "export VISIBLE=now" >> /etc/profile
    36  
    37      EXPOSE 22
    38      CMD ["/usr/sbin/sshd", "-D"]
    39  
    40  Build the image using:
    41  
    42      $ docker build -t eg_sshd .
    43  
    44  ## Run a `test_sshd` container
    45  
    46  Then run it. You can then use `docker port` to find out what host port
    47  the container's port 22 is mapped to:
    48  
    49      $ docker run -d -P --name test_sshd eg_sshd
    50      $ docker port test_sshd 22
    51      0.0.0.0:49154
    52  
    53  And now you can ssh as `root` on the container's IP address (you can find it
    54  with `docker inspect`) or on port `49154` of the Docker daemon's host IP address
    55  (`ip address` or `ifconfig` can tell you that) or `localhost` if on the
    56  Docker daemon host:
    57  
    58      $ ssh root@192.168.1.2 -p 49154
    59      # The password is ``screencast``.
    60      $$
    61  
    62  ## Environment variables
    63  
    64  Using the `sshd` daemon to spawn shells makes it complicated to pass environment
    65  variables to the user's shell via the normal Docker mechanisms, as `sshd` scrubs
    66  the environment before it starts the shell.
    67  
    68  If you're setting values in the `Dockerfile` using `ENV`, you'll need to push them
    69  to a shell initialization file like the `/etc/profile` example in the `Dockerfile`
    70  above.
    71  
    72  If you need to pass`docker run -e ENV=value` values, you will need to write a
    73  short script to do the same before you start `sshd -D` and then replace the
    74  `CMD` with that script.
    75  
    76  ## Clean up
    77  
    78  Finally, clean up after your test by stopping and removing the
    79  container, and then removing the image.
    80  
    81      $ docker stop test_sshd
    82      $ docker rm test_sshd
    83      $ docker rmi eg_sshd
    84