1.使用febootstrap制作base image



  • 制作镜像目录


           在Docker入门()中,我们讲到base image,现在要使



      用febootstrap工具制作base image:



      febootstrap -i bash -i wget -i yum -i iputils -i iproute -i man -i vim -i openssh-server -i openssh-clients -i tar -i     



      gzip centos7 centos7-image http://mirrors.aliyun.com/centos/7/os/x86_64/  



  1. -i 表示需要安装的package,例如上面的语句:想要base image中安装:bash、wget、yum、iputils、iproute 、man、vim 、openssh-server、openssh-clients、tar 、gzip 


     这个可以根据自己的需要进行安装,其中openssh-server、openssh-clients这2个包是为了后面ssh登录准备的。



     2.  centos7 是操作系统版本



  1. centos7-image 是目录(base image想放在服务器的位置)


     4.源地址,我选择的是阿里云的,也可以使用其他源地址



     执行完上面的语句会生成centos7-image文件目录,包含以下文件:






cd centos6-image && cp etc/skel/.bash* root/语句,将.bash_logout  .bash_profile  .bashrc这三个文件拷贝至root文件夹下。



  • 生成base image


         执行: cd centos7-image && tar -c .|docker import - centos7-base 语句,将centos7-image目录下内容打包并将打包内容创建为一个docker镜像。



查看镜像,发现镜像中有一个名为:centos7-base的镜像






     此时,我们已经可以将centos7-base镜像运行在docker的container中了。









2.使用Dockfile制作可以使用ssh登录的image



  • dockfile


名为:Dockfile的文件,内容如下:



#Dockerfile



FROM centos7-base  #将centos7-base作为base image,类似继承的概念,制作出的新的image具有base image的功能



MAINTAINER ahuo    



RUN ssh-keygen -q -N "" -t dsa -f /etc/ssh/ssh_host_dsa_key



RUN ssh-keygen -q -N "" -t rsa -f /etc/ssh/ssh_host_rsh_key



RUN sed -ri 's/session    required     pam_loginuid.so/#session    required     pam_loginuid.so/g' /etc/pam.d/sshd



RUN mkdir -p /root/.ssh && chown root.root /root && chmod 700 /root/.ssh



#上面几行都是配置ssh登录目录和登录验证的,而ssh的安装时在base image centos7-base中完成的(-i openssh-server -i openssh-client)



EXPOSE 22 #开端口



RUN echo 'root:redhat' | chpasswd #重置root密码为redhat



RUN yum install tar gzip gcc vim wget -y



ENV LANG en_US.UTF-8



ENV LC_ALL en_US.UTF-8



CMD /usr/sbin/sshd -D



#End






在centos7-image目录下,执行build命令,centos7-ssh 是生成的image名字,后面跟Dockfile所在目录。



此时,我们可以看到image多了一个centos7-ssh的镜像。






  • 验证ssh登录


     1. docker run -d centos-ssh:latest /bin/bash



          运行centos-ssh镜像生成一个容器,-d表示在后台运行。



       2.此时,使用docker ps -a 命令可以看到启动的容器。






      3.使用docker inspect CONTAINER ID查看容器的信息









     找到IP地址



     4.使用ssh root@172.17.0.2登录容器,密码是dockfile中修改的redhat



具有其他功能的image也是同样的方法制作,验证。





3.用容器快速制作镜像   



     为了更好的理解和使用docker镜像、容器,决定使用base image 安装oracle后,打包容器制作为oracle镜像。使用容器制作镜像的好处有:



     第一就是可以步步为营。当你制作一个比较复杂点的镜像时,不可能一步就能做成功,所以当你觉得下面一步可能要出错时(不可逆的错误),可以先把该镜像打个包,如果接下来失误了,删掉这个容器,再用刚才打包好的镜像做个容器,继续前面的步骤。



        第二就是不管你在容器中怎么折腾都没关系,大不了删除掉这个容器,如果你在物理服务器上就要相当注意了,要不然duang的一下,整个服务器就瘫痪了。



        第三好处和第一个差不多,因为有些数据库不能测试的,你一测试就会产生很大的数据(日志,还有些默认的数据)(我做mongodb镜像时,测试了下打包后的镜像竟然达到4个多G,而没测试的就几百MB,相差太大了),因为docker镜像不能太大,否则不好上传。所以一般是做好了,先打个包成镜像,然后接着测试下,如果成功。那就可以了。



     理想很丰满,显示很骨干,在安装oracle过程中,报错啦。






     这个报错是因为,oracle安装对hostname有要求,要求hostname中不能包含数字,但是docker在运行镜像为容器的过程中会自动为容器分配一个id,这个id是由数字和字母组成的。无法使用一般修改hostname的办法修改容器的hostname,看到网上有使用docker-compose工具修改容器hostname的,我没有尝试(恩,是因为懒,如果尝试了再来更新)。ps:docker run —add-host这个并不是修改hostname啊~



     虽然没有成功使用容器制作oracle镜像,但是理论上使用容器制作镜像的语句为:



     docker commit  xxx(容器的id)   xxxx(要制作成的镜像名)



     最后使用docker search oracle查找了下oracle镜像,






     然后 docker pull docker.io/wnameless/oracle-xe-11g,下载完成后可以看到镜像列表中添加了一个oracle-xe-11g的镜像。






     运行该镜像为容器,进入容器后,su - oracle 切换到oracle用户,可以看到oracle的安装目录,可以运行sqlplus / as sysdba命令进入到数据库中。