Docker:centos6增加ssh服务Dockerfile脚本

# This is a comment

FROM index.alauda.cn/linzhiqiang/centos6:latest 

MAINTAINER Docker lawsonduan <[email protected]>

RUN yum install -y openssh-server

RUN sed -i 's/UsePAM yes/UsePAM no/g' /etc/ssh/sshd_config

RUN ssh-keygen -t dsa -f /etc/ssh/ssh_host_dsa_key

RUN ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key

RUN mkdir -p /var/run/sshd

RUN echo 'root:futong-jw' |chpasswd

EXPOSE 22

ENTRYPOINT /usr/sbin/sshd -D

挂载文件系统:

#docker run -it -v /root/software/:/mnt/software/ 镜像 /bin/bash

docker run <相关参数> <镜像ID> <初始命令>

其中,相关参数包括:

  • -i:表示以“交互模式”运行容器

  • -t:表示容器启动后会进入其命令行

  • -v:表示需要将本地哪个目录挂载到容器中,格式:-v <宿主机目录>:<容器目录>

初始命令表示一旦容器启动,需要运行的命令,此时使用“/bin/bash”,表示启动后直接进入bash shell。

1:在测试机启动容器,安装ssh

docker run -i -t ubuntu:14.04 /bin/bash

更换阿里云mirror  /etc/apt/sorce.list

apt update


apt-get install openssh-server

#需要修改/etc/sshd/sshd_config文件中内容

PermitRootLogin yes

UsePAM no

passwd root

退出容器

2: 启动ssh,容器以后台方式运行

docker commit contain_id p_w_picpath:tag

docker run -d -p 50001:22 id> /usr/sbin/sshd -D


3: 通过ssh连接到容器安装软件

ssh [email protected] -p 50001

#连上后想装什么就装什么,可使用exit退出容器,但后台还会运行


4:服务安装完成后,停止容器。

docker stop  <容器id>     #停止运行的容器


5:把容器提交生成最新的镜像.

docker commit <容器id>  debian02 #把这个容器提交生成新的debian02镜像(该镜像是原始镜像与容器的整合)

commit使用:

   docker commit  <容器id>  <新镜像名称>

打包镜像

docker save debian02 >/root/debian02.tar   #debian02镜像打包


在另外的机器上导入镜像

docker load < debian02.tar   #导入镜像

docker p_w_picpaths   #查看存在的镜像

启动容器

docker run -h="redis-test"  --name redis-test -d -p 51000:22 -p 51001:3306 -p 51003:6379 -p 51004:6381 -p 51005:80 -p 51006:8000 -p 51007:8888  debian02 /etc/rc.local

#此处是我测试机器启动命令,指定主机名与端口映射。

#启动后,后面又装了程序,开机自启动命令可放在/etc/rc.local文件中。

 

docker容器迁移简单方便,可以任意的拷贝部署,以后再也不怕新部署环境了,一堆依赖装的想死有木有。


docker常用命令总结

docker pull  <镜像名:tag>  #从官网拉取镜像

docker search <镜像名>  #搜索在线可用镜像名

8.1查询容器、镜像、日志

 docker top #显示容器内运行的进程

docker p_w_picpaths  #查询所有的镜像,默认是最近创建的排在最上。

 docker ps #查看正在运行的容器

 docker ps -l #查看最后退出的容器的ID

 docker ps -a #查看所有的容器,包括退出的。

docker logs  {容器ID|容器名称}  #查询某个容器的所有操作记录。

 docker logs -f  {容器ID|容器名称}  #实时查看容易的操作记录。


8.2删除容器与镜像

docker rm$(docker ps -a -q)  #删除所有容器

docker rm <容器名or ID>    #删除单个容器

 

docker rmi    #删除单个镜像

docker rmi$(docker p_w_picpaths | grep none | awk '{print $3}' | sort -r) #删除所有镜像

8.3启动停止容器

docker stop  <容器名or ID>   #停止某个容器

docker start  <容器名or ID>  #启动某个容器

docker kill    <容器名or ID>  #杀掉某个容器

 

8.4容器迁器

docker export > /home/export.tar  #导出

cat /home/export.tar | sudo docker import  -  busybox-1-export:latest  # 导入export.tar文件

 

docker save debian> /home/save.tar   #debian容器打包

docker load< /home/save.tar    #在另一台服务器上加载打包文件