参考文章:https://www.jianshu.com/p/dc4cd0547d1e

   

镜像的制作方式有两种,一种是下载别人的镜像之后再制作成自己的镜像,一种是从头开始制作自己的镜像

第一种,下载别人的镜像来修改。

安全起见下载官方的centos系统镜像,在该系统内安装nginx之后,在封装成镜像

下载centos系统镜像

docker pull centos

docker nginx 启动 镜像 docker制作nginx镜像_docker nginx 启动 镜像

使用镜像启动容器并进入容器

docker run -it --name centos.nginx centos /bin/bash

docker nginx 启动 镜像 docker制作nginx镜像_nginx_02

安装epel源和nginx

yum install epel-release -y

yum install nginx -y

docker nginx 启动 镜像 docker制作nginx镜像_nginx_03

   

docker nginx 启动 镜像 docker制作nginx镜像_centos_04

   

配置nginx为前台启动模式

在nginx的配置文件中加入如下参数

vi /etc/nginx/nginx.conf

daemon off;

使用exit退出容器,然后使用docker commit命令制作镜像

查看容器

docker ps -a

docker nginx 启动 镜像 docker制作nginx镜像_centos_05

制作镜像

docker commit -m "nginx" -a "centos-nginx" -c 'CMD ["/usr/sbin/nginx"]' 86ae1d7284e3 centos-nginx

-m 来指定提交的说明信息,跟我们使用的版本控制工具一样;

-a 可以指定更新的用户信息;之后是用来创建镜像的容器的 ID;最后指定目标镜像的仓库名和 tag 信息。创建成功后会返回这个镜像的 ID 信息;

-c 制作镜像之后执行的命令

86ae1d7284e3 容器ID,就是希望将哪个容器重新制作

centos-nginx 制作之后的镜像名称

docker nginx 启动 镜像 docker制作nginx镜像_docker nginx 启动 镜像_06

使用新镜像启动容器

先查看镜像

docker images

docker nginx 启动 镜像 docker制作nginx镜像_nginx_07

使用新镜像启动容器

docker run --name nginx -p 8888:80 -d centos-nginx

docker nginx 启动 镜像 docker制作nginx镜像_docker nginx 启动 镜像_08

--name nginx 为容器定义名称,名称为nginx

-p 8888:80 将宿主机的8888端口映射到容器内的80端口

-d 指定该容器在后天运行

cetnos-nginx 指定使用centos-nginx镜像来创建容器

使用浏览器访问容器内的nginx

docker nginx 启动 镜像 docker制作nginx镜像_docker_09

第二种,全新制作自己的容器使用Dockerfile文件

Dockerfile是使用源代码构建docker的镜像,编辑一个Dockerfile,而后根据此文件制作;

docker可以自动通过读取Dockerfile中的指令,自动构建镜像。

Dockerfile是一个文本文档包含所有用户的命令,可以在命令行上调用组建一个镜像。

使用docker build命令的用户可以读取docker file中的连续指令,自动构建一个镜像。

   

示例使用dockerfile文件制作nginx的镜像:

#创建工作目录
mkdir nginx

#进入nginx目录,创建nginx测试页,创建dockerfile文件

cd nginx/

vim index.html
<h1> nginx test page </h1>

vim dockerfile

#dockerfile 文件内容开始

FROM centos:latest #基准镜像
MAINTAINER "Withdocker" #作者信息
WORKDIR /usr/local/src/ #工作目录
ENV NG_VERSION nginx-1.16.0 #定义环境变量
RUN yum -y install epel-release #安装epel仓库
RUN yum -y install wget && wget http://nginx.org/download/$NG_VERSION.tar.gz && tar xzvf $NG_VERSION.tar.gz #下载nginx文件并解压
#安装编译依赖包
RUN yum install -y gcc gcc-c++ glibc make autoconf openssl openssl-devel && yum install -y pcre-devel libxslt-devel gd-devel GeoIP GeoIP-devel GeoIP-data
RUN yum clean all #清理仓库
RUN useradd -M -s /sbin/nologin nginx #创建nginx用户
WORKDIR /usr/local/src/$NG_VERSION #切换工作目录
#编译安装nginx
RUN ./configure --user=nginx --group=nginx --prefix=/usr/local/nginx --with-file-aio --with-http_ssl_module --with-http_realip_module --with-http_addition_module --with-http_xslt_module --with-http_image_filter_module --with-http_geoip_module --with-http_sub_module --with-http_dav_module --with-http_flv_module --with-http_mp4_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_auth_request_module --with-http_random_index_module --with-http_secure_link_module --with-http_degradation_module --with-http_stub_status_module && make && make install
ADD index.html /usr/local/nginx/html #复制测试页面到容器中
VOLUME /usr/local/nginx/html #设置容器中要挂在到宿主机的目录
ENV PATH /usr/local/nginx/sbin:$PATH #设置sbin环境变量
EXPOSE 80/tcp #暴露80端口
ENTRYPOINT ["nginx"]
CMD ["-g","daemon off;"]
#当ENTRYPOINT和CMD连用时,CMD的命令是ENTRYPOINT命令的参数,两者连用相当于nginx -g "daemon off;"而当一起连用的时候命令格式最好一致(这里选择的都是json格式的是成功的,如果都是sh模式可以试一下)

#dockerfile 文件内容结束

#构建镜像
docker build ./ -t mynginx

#指明构建的根目录,有dockerfile的就是构建根目录,-t指明tag标签,执行该命令后程序会读取并执行dockerfile文件内的所有命令。下图为执行成功的结果截图。

docker nginx 启动 镜像 docker制作nginx镜像_nginx_10

查看镜像

docker images

docker nginx 启动 镜像 docker制作nginx镜像_docker nginx 启动 镜像_11

#根据构建的镜像运行容器
docker run --name mynginx -d -p 8123:80 mynginx

docker nginx 启动 镜像 docker制作nginx镜像_nginx_12

#查看容器
docker ps

docker nginx 启动 镜像 docker制作nginx镜像_nginx_13

#访问nginx

docker nginx 启动 镜像 docker制作nginx镜像_centos_14