Docker实战(七)之为镜像添加SSH服务
1.基于commit命令创建
Docker提供了docker commit命令,支持用户提交自己对制定容器的修改,并生成新的镜像。命令格式为docker commit CONTAINER [REPOSITORY[:TAG]]。
(1)创建一个镜像
docker run -it ubuntu:14.04 /bin/bash
更新apt缓存,并安装openssh-server
apt-get update
apt-get install openssh-server -y
(2)安装配置SSH服务
apt-get install openssh-server -y
如果需要正常启动SSH服务,则目录/var/run/sshd必须存在。手动创建它,并启动SSH服务:
mkdir -p /var/run/sshd
/usr/bin/sshd -D &
netstat -tunlp
(3)保存镜像
docker commit 1b902596b8b9 sshd:ubuntu
(4)使用镜像
启动容器,并添加端口映射10022-->22。其中10022是宿主主机的端口,22是容器的SSH服务监听的端口:
docker run -p 10022:22 -d sshd:ubuntu /run.sh
启动成功后,可以在宿主主机上看到容器运行的详细信息
在宿主主机或其他主机上,可以通过SSH访问10022端口来登录容器
ssh IP -p 10022
2.使用Dockerfile创建
(1)创建工作目录
mkdir sshd_ubuntu
cd ssh_ubuntu
在该目录中创建Dockerfile和run.sh文件
(2)编写run.sh脚本和authorized_keys文件
run.sh脚本内容如下:
#!/bin/bash /usr/sbin/sshd -D
在宿主主机上生成SSH密钥,并创建authorized_keys文件:
ssh-keygen -t rsa
cat authorized_keys.pub > authorized_keys
(3)编写Dockerfile文件
#设置继承镜像 FROM ubuntu:14.04 #提供一些作者信息 MAINTAINER docker_user(user@docer.com) #下面开始运行更新命令 RUN apt-get update #安装ssh服务 RUN apt-get install -y openssh-server RUN mkdir -p /var/run/sshd RUN mkdir -p /root/.ssh #取消pam限制 RUN sed -ri 's/session required pam_loginuid.sh/#session required pam_loginuid.so/g' /etc/pam.d/sshd #复制配置文件到相应位置,并赋予脚本可执行权限 ADD authorized_keys /root/.ssh/authorized_keys ADD run.sh /run.sh RUN chmod 755 /run.sh #开放端口 EXPOSE 22 #设置自启动命令 CMD ["/run.sh"]
(4)创建镜像
执行该命令即可创建镜像
docker build -t sshd:dockerfile .
记得必须要在Dockerfile文件存在的目录执行该命令否则会报找不到目录异常
docker images
(5)测试镜像,运行容器
docker run -d -p 10122:22 sshd:dockerfile
在宿主主机新打开一个终端,连接到新建容器:
ssh 192.168.126.130 -p 10122
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Docker实战(六)之使用Dockerfile创建镜像
Dockervile是一个文本格式的配置文件,用户可以使用Dockerfile来快速创建自定义镜像。 1.基本结构 Dockerfile由一行行命令语句组成,并且支持以#开头的注释行。 一般而言,Dockerfile分为四部分:基础镜像信息、维护者信息、镜像操作指令和容器启动时执行命令。 一开始必须指明所基于的镜像名称,接下来一般是说明维护者信息。后面则是镜像操作指令,例如RUN指令,RUN指令将对镜像执行跟随的命令。每运行一条RUN指令,镜像就添加新的一层,并提交。最后是CMD指令,用来指定运行容器时的操作命令。 2.指令说明 (1)FROM 指定所创建镜像的基础镜像,如果本地不存在,则默认会去Docker Hub下载指定镜像。 格式为FROM<image>,或FROM<image>:<tag>,或FROM<image>@<digest>。 任何Dockerfile中的第一条指令必须为FROM指令。并且,如果在同一个Dockerfile中创建多个镜像,可以使用多个FROM指令(每个镜像一次)。 2.MAINTAINER 指定...
- 下一篇
Docker实战(九)之数据库应用
目前,主流数据库包括关系型和非关系型两种。 关系型数据库是建立在关系模型基础上的数据库,借助于集合代数等数学概念金额方法来处理数据库中的数据,支持复杂的事务处理和结构化查询。代表实现有MySQL 、Oracle、PostGreSQL、MariaDB、SQLServer等。 非关系型数据库是新兴的数据库技术,它放弃了传统关系型数据库的部分强一限制,带来性能上的提升,使其更适用于需要大规模并行处理订单场景。非关系型数据库是关系型数据库的补充,代表产品有MongoDB、Redis、CouchDB等。 1.MySQL 使用官方镜像可与快速启动一个MySQL Server实例,如下所示: docker run --name hi-mysql -e MYSQL_ROOT_PASSWORD=123 -d mysql:latest 当然,还可以使用--link标签将一个应用容器连接到MySQL容器: docker run --name some-app --link some-mysql:mysql -d application-that-uses-mysql (1)系统与日志访问 docker...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
-
Docker使用Oracle官方镜像安装(12C,18C,19C)
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS8编译安装MySQL8.0.19
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- MySQL8.0.19开启GTID主从同步CentOS8
- CentOS7,8上快速安装Gitea,搭建Git服务器
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
推荐阅读
最新文章
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- 设置Eclipse缩进为4个空格,增强代码规范
- Mario游戏-低调大师作品
- MySQL8.0.19开启GTID主从同步CentOS8
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- CentOS8编译安装MySQL8.0.19
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- SpringBoot2整合Redis,开启缓存,提高访问速度