文章目录
- 构建SSH镜像
- 推荐步骤
- 构建systemctl镜像
- 推荐步骤
- 构建nginx镜像
- 推荐步骤
- 构建tomcat镜像
- 推荐步骤:
- 创建mysqld镜像
- 推荐步骤
构建SSH镜像
推荐步骤
1.现在虚拟机的/opt目录下创建一个文件夹
[root@localhost opt]# mkdir ssh ##创建ssh目录
2.创建dockerfile
[root@localhost opt]# cd ssh/
[root@localhost ssh]# vim Dockerfile ##创建Dockerfile
FROM centos:7 ##基于基础镜像
MAINTAINER This is ssh ##作为描述信息
RUN yum -y update ##更新yum源
RUN yum -y install openssh* net-tools lsof telnet passwd ##安装ssh服务;网络管理工具;lsof:查看端口命令;telnet:远程访问 ;passwd:密码
RUN echo '123456' | passwd --stdin root ##设置密码
RUN sed -i 's/UsePAM yes/UsePAM no/g' /etc/ssh/sshd_config ##关闭PAM模块
RUN ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key ##非对称密钥生成
RUN sed -i '/^session\s\+required\s\+pam_loginuid.so/s/^/#/' /etc/pam.d/sshd ##关闭PAM认证
RUN mkdir -p /root/.ssh && chown root.root /root && chmod 700 /root/.ssh ##创建目录用于放私钥
EXPOSE 22 ##端口号为22
CMD ["/usr/sbin/sshd","-D"] ##执行命令
3.dockerfile配置完后,生成镜像
[root@localhost ssh]# docker build -t sshd:new .
4.启动容器并修改root密码
[root@localhost ssh]# docker run -d -P sshd:new ##指定随机端口映射ssh:new容器
5.验证容器
[root@localhost ssh]# ssh localhost -p 32770 ##远程连接容器;指定外部端口
构建systemctl镜像
推荐步骤
1.现在虚拟机的/opt目录下创建一个文件夹
[root@localhost opt]# mkdir systemctl ##创建systemctl目录
2.配置Dockerfile
[root@localhost opt]# cd systemctl/
[root@localhost systemctl]# vim Dockerfile
FROM sshd:new
ENV container docker
RUN (cd /lib/systemd/system/sysinit.target.wants/; for i in *;do [ $i == \systemd-tmpfiles-setup.service ] || rm -f $i;done);\ ##设置变量,进行遍历;当条件匹配上就保留;要是不成立就删除
rm -f /lib/systemd/system/multi-user.target.wants/*;\ ##以下是将缓存全部清空
rm -f /etc/systemd/system/*.wants/*;\
rm -f /lib/systemd/system/local-fs.target.wants/*;\
rm -f /lib/systemd/system/sockets.target.wants/*udev*;\
rm -f /lib/systemd/system/sockets.target.wants/*initctl*;\
rm -f /lib/systemd/system/basic.target.wants/*;\
rm -f /lib/systemd/system/anaconda.target.wants/*;
VOLUME [ "/sys/fs/cgroup" ] ##配置数据卷,当缓存文件删除后,从宿主机中加载文件
CMD ["/usr/sbin/init"] ##配置初始化
3.dockerfile配置完后,生成镜像
[root@localhost systemctl]# docker build -t systemd:new .
4.配置不降权处理,并放在后台运行(不放在后台运行终端会卡住)
[root@localhost systemctl]# docker run --privileged -it -v /sys/fs/cgroup:/sys/fs/cgroup:ro systemd:new /sbin/init & ##配置不降权(privateged container内的root拥有真正的root权限。否则,container内的root只是外部的一个普通用户权限),和数据卷
5.验证容器
[root@localhost systemctl]# docker exec -it 80db5529a26b /bin/bash ##进入容器
[root@80db5529a26b /]# systemctl start sshd ##开启sshd服务
发现可以使用systemctl的命令
构建nginx镜像
推荐步骤
1.现在虚拟机的/opt目录下创建一个文件夹
[root@localhost opt]# mkdir nginx/ ##创建一个nginx的目录
2.创建dockerfile
[root@localhost opt]# cd nginx/
[root@localhost nginx]# vim Dockerfile
##基于基础镜像
FROM centos:7
##用户信息
MAINTAINER this is nginx image <cai>
##添加环境包
RUN yum -y update
RUN yum -y install pcre-devel zlib-devel gcc gcc-c++ make
RUN useradd -M -s /sbin/nologin nginx
##下载nginx环境包
ADD nginx-1.12.2.tar.gz /usr/local/src
WORKDIR /usr/local/src
##指定工作目录
WORKDIR nginx-1.12.2
RUN ./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx \
--with-http_stub_status_module
RUN make && make install
ENV PATH /usr/local/nginx/sbin:$PATH
##指定http和https端口
EXPOSE 80 ##80端口号
EXPOSE 443 ##https端口号
RUN echo "daemon off;">>/usr/local/nginx/conf/nginx.conf
##添加宿主机中run.sh到容器中
ADD run.sh /run.sh
RUN chmod 755 /run.sh
CMD ["/run.sh"]
3.配置启动脚本
[root@localhost nginx]# vim run.sh
#!/bin/bash
/usr/local/nginx/sbin/nginx ##只放一条启动命令
4.将nginx工具包也放到目录下,这样配置nginx容器的工具都准备好了
5.创建新的镜像
[root@localhost nginx]# docker build -t nginx:new .
6.运行容器
[root@localhost nginx]# docker run -d -P nginx:new ##随机指定端口
7.验证容器,打开浏览器输入IP地址加端口好访问
构建tomcat镜像
推荐步骤:
1.先创建tomcat目录
[root@localhost opt]# mkdir tomcat
2.配置Dockerfile
[root@localhost opt]# cd tomcat/
[root@localhost tomcat]# vim Dockerfile
FROM centos:7
MAINTAINER this is tomcat image <cai>
EXPOSE 8080 ##端口号
ADD jdk-8u201-linux-x64.rpm /usr/local/src
WORKDIR /usr/local/src
RUN rpm -ivh jdk-8u201-linux-x64.rpm
ENV JAVA_HOME /usr/java/jdk1.8.0_201-amd64
ENV CLASSPATH $JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar
ENV PATH $JAVA_HOME/bin:$PATH
ADD apache-tomcat-9.0.16.tar.gz /usr/local/src
RUN mv apache-tomcat-9.0.16/ /usr/local/tomcat9
ENV PATH /usr/local/tomcat9/bin/:$PATH
ADD tomcat9.run.sh /usr/local/src
RUN chmod 755 /usr/local/src/tomcat9.run.sh
CMD ["/usr/local/src/tomcat9.run.sh"]
3.编写启动脚本
[root@localhost tomcat]# vim tomcat9.run.sh
#!/bin/bash
/usr/local/tomcat9/bin/catalina.sh run
4.将tomcat的两个工具包放到tomcat目录下
5.创建tomcat的镜像
[root@localhost tomcat]# docker build -t tomcat:centos .
6.创建完镜像后创建容器,指定映射端口为1216
[root@localhost tomcat]# docker run -d --name tomcat01 -p 1216:8080 tomcat:centos
7.打开浏览器输入地址加端口号验证
创建mysqld镜像
推荐步骤
1.先创建mysql的目录
[root@localhost opt]# mkdir mysqld/
2.进入mysql目录,创建dockerfile
[root@localhost opt]# cd mysqld/
[root@localhost mysqld]# vim Dockerfile
FROM centos:7
MAINTAINER build image mysql
EXPOSE 3306
ADD mysql-boost-5.7.20.tar.gz /usr/local/src
WORKDIR /usr/local/src/mysql-5.7.20
RUN useradd mysql -M -s /sbin/nologin
RUN yum -y install gcc \ ##安装软件包
gcc-c++ \
make \
ncurses \
ncurses-devel \
bison \
cmake
RUN cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
-DSYSCONFDIR=/etc \
-DSYSTEMD_PID_DIR=/usr/local/mysql \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DWITH_BOOST=boost \
-DWITH_SYSTEMD=1
RUN make && make install
RUN chown -R mysql:mysql /usr/local/mysql/
RUN rm -rf /etc/my.cnf
ADD my.cnf /etc/
RUN chown mysql:mysql /etc/my.cnf
ENV PATH $PATH:/usr/local/mysql/bin:/usr/local/mysql/lib
RUN /usr/local/mysql/bin/mysqld \
--initialize-insecure \
--user=mysql \
--basedir=/usr/local/mysql \
--datadir=/usr/local/mysql/data
RUN cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/
RUN echo -e "#!/bin/sh \nsystemctl enable mysqld" > /run.sh ##创建启动脚本
RUN chmod 755 /run.sh ##启动脚本增加权限
RUN sh /run.sh ##执行启动脚本
CMD ["init"] ##初始化
3.将mysql的工具包和创建的my.cnf文件放到mysqld目录下
4.生成镜像
[root@localhost mysqld]# docker build -t mysql:centos .
5.创建容器
[root@localhost mysqld]# docker run -d -P --privileged mysql:centos ##随机映射端口
6.进入容器,登录mysql数据库,设置权限
[root@localhost mysqld]# docker exec -it 09d105058df9 /bin/bash ##进入容器
[root@09d105058df9 mysql-5.7.20]# mysql -uroot -p ##登录数据库
mysql> grant all privileges on *.* to 'root'@'%' identified by '123456';
mysql> grant all privileges on *.* to 'root'@'localhost' identified by '123456';
7.这时重新打开一个终端,验证宿主机连接容器的mysql
[root@localhost ~]# yum -y install mariadb* ##安装mariadb软件
[root@localhost ~]# systemctl start mariadb ##开启服务
[root@localhost ~]# mysql -h 192.168.148.139 -uroot -P 32768 -p ##连接数据库
8.这时创建一个school库
容器里的数据库也会有school库