Docker 是一種可以在容器中運行應用程序的平臺,其強大的隔離性和便攜性使其被廣泛應用于軟件開發和部署。在使用 Docker 時,我們常常需要與容器進行交互, SSH 是一種常見的可以連接到容器終端的方式。
在 Docker 中,我們可以通過將 SSH 服務安裝在容器中來使容器具有 SSH 功能。下面是一個示例 Dockerfile,它可以構建一個具有 SSH 功能的 Ubuntu 鏡像。
FROM ubuntu:latest
RUN apt-get update && apt-get install -y openssh-server sudo
RUN mkdir /var/run/sshd
RUN echo 'root:password' | chpasswd
RUN sed -i 's/^PermitRootLogin.*/PermitRootLogin yes/' /etc/ssh/sshd_config
RUN sed 's@session\s*required\s*pam_loginuid.so@session optional pam_loginuid.so@g' -i /etc/pam.d/sshd
ENV NOTVISIBLE "in users profile"
RUN echo "export VISIBLE=now" >>/etc/profile
EXPOSE 22
CMD ["/usr/sbin/sshd", "-D"]
在 Dockerfile 中,我們首先從最新的 Ubuntu 鏡像開始構建我們的鏡像。然后我們使用 apt-get 安裝了 openssh-server,sudo 和其他必要的軟件。我們創建了一個名為 /var/run/sshd 的目錄,并通過 echo 命令將 root 用戶名和密碼設置為 password,以便我們可以通過 SSH 登錄到容器中。接下來,我們對 /etc/ssh/sshd_config 文件進行了修改,以允許 root 用戶身份登錄。最后,我們替換了 /etc/pam.d/sshd 文件中的 session required pam_loginuid.so 行,以避免在使用 sudo 命令時出現“stdin:是交互式的”錯誤。
在成功構建 Docker 鏡像后,我們可以通過以下命令在容器中啟動 SSH 服務:
$ docker run -d -p 22:22 <image_name>
其中 -d 參數意味著容器將在后臺運行,-p 參數將容器的 22 端口映射到主機的 22 端口。
現在,我們可以使用 SSH 客戶端在容器中連接到 SSH 服務。對于 Linux 和 macOS 用戶,可以使用以下命令連接:
$ ssh root@localhost
對于 Windows 用戶,我們可以使用 PuTTY 來連接。在 PuTTY 中,我們需要在主機名框中輸入主機 IP 地址和端口號,然后選擇 SSH 連接類型,并在用戶名框中輸入 root。然后我們可以在彈出的窗口中輸入密碼,就可以連接到我們的容器終端了。