docker安装ssh
通过命令行安装
1.pull ubuntu镜像
docker pull ubuntu:latest
2.启动并进入bash
docker run -it -d ubuntu:lastest /bin/bash# 查看刚刚运行容器的iddocker ps# 在容器中执行bash命令docker exec -it id /bin/bash
3.安装openssh-server并启动
apt-get updateapt-get install openssh-server# 启动之前需手动创建/var/run/sshd,不然启动sshd的时候会报错mkdir -p /var/run/sshd# sshd以守护进程运行/usr/sbin/sshd -D &# 安装netstat,查看sshd是否监听22端口apt-get install net-toolsnetstat -apn | grep ssh
如果已经监听22端口,说明sshd服务启动成功
4.ssh登陆
# 生成ssh keyssh-keygen -t rsa# 修改sshd-config允许root登陆sed -i 's+PermitRootLogin prohibit-password+PermitRootLogin yes' /etc/ssh/sshd-config
修改完sshd-config之后需要重启sshd服务
// 找到pidps -aux | grep sshkill -9 pid/usr/sbin/sshd -D &
查看容器ip
ifconfig
在主机上进行登陆
ssh root@ip
就可以登录成功了,但是注意这里是docker容器的宿主机才能登陆成功,如果需要其他机器登陆,可以在启动docker的时候进行端口映射
// 11122宿主机端口,22为容器端口docker run -it -p 11122:22 // 在其他机器上可以使用以下命令登陆,假设宿主机ip为192.168.1.101ssh -p 11122 root@192.168.1.101
5.保存容器
// 把id为id的容器保存docker commit id sshd:ubuntu// 停止容器docker stop id
通过dockerfile
# 以最新的Ubuntu镜像为模板FROM ubuntu:latest// 将本目录下的sources.list作为容器的一个文件ADD sources.list /root/sources.list// 使用阿里Ubuntu源,更新快RUN cp /root/sources.list /etc/apt/sources.list.d/aliyun.listRUN apt-get updateRUN apt-get install -y openssh-serverRUN apt-get install -y net-toolsRUN apt-get install -y vimRUN mkdir -p /var/run/sshdRUN mkdir -p mkdir/root/.ssh/// 修改root密码,便于远程登录RUN echo root:123456 | chpasswd// 将key生成在指定文件内RUN ssh-keygen -q -t rsa -b 2048 -f /etc/ssh/ssh_host_rsa_key -P '' -N ''// 配置ssh可以使用root登陆RUN sed -i 's/PermitRootLogin without-password/PermitRootLogin yes/' /etc/ssh/sshd_config// 开放22端口EXPOSE 22CMD /usr/sbin/sshd -D &
根据Dockerfile build镜像
docker build -t nginx:ubuntu .
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持VEVB武林网。
新闻热点
疑难解答
图片精选