码迷,mamicode.com
首页 > 其他好文 > 详细

Docker 制作Nginx镜像

时间:2019-10-14 12:55:23      阅读:202      评论:0      收藏:0      [点我收藏+]

标签:mic   install   add   exit   pcr   容器   ima   load   auth   

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

   

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

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

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

下载centos系统镜像

docker pull centos

技术图片

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

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

技术图片

安装epel源和nginx

yum install epel-release -y

yum install nginx -y

技术图片

   

技术图片

   

配置nginx为前台启动模式

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

vi /etc/nginx/nginx.conf

daemon off;

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

查看容器

docker ps -a

技术图片

制作镜像

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 images

技术图片

使用新镜像启动容器

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

技术图片

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

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

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

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

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

技术图片

第二种,全新制作自己的容器使用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;"]
#ENTRYPOINTCMD连用时,CMD的命令是ENTRYPOINT命令的参数,两者连用相当于nginx -g "daemon off;"而当一起连用的时候命令格式最好一致(这里选择的都是json格式的是成功的,如果都是sh模式可以试一下)

#dockerfile 文件内容结束

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

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

技术图片

查看镜像

docker images

技术图片

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

技术图片

#查看容器
docker ps

技术图片

#访问nginx

技术图片

Docker 制作Nginx镜像

标签:mic   install   add   exit   pcr   容器   ima   load   auth   

原文地址:https://www.cnblogs.com/withfeel/p/11670687.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!