Dockerfile之nginx(六)

1、Dokcerfile的基本指令
 
1)From 指定构建镜像的基础镜像
2)MAINTAINER 指定镜像的做者
3)RUN 使用前一条指令建立的镜像生产容器,并在容器中执行命令,执行结束后会自动提交成为新的镜像
4)CMD 为容器提供运行时的默认值,做为容器启动的默认第一条指令,在Dockerfile只有一条,有多条的话以最后一条为准
5)LABEL 为生成的镜像添加描述信息,可使用inspect查看
6)EXPOSE 申明容器在运行时将会监听的特定端口,即对外暴露的端口,但要真正暴露仍是要在run时使用-p或-P指定,不能使用EXPOSE作端口映射
7)ENV 设置环境变量,做用于Docker后续的全部指令,并且还会做用于生成镜像所建立出来的容器中
8)ADD 从复制文件到镜像中,能够是文件、目录、甚至是url;也能够是绝对路径,也能够是相对路径
9)COPY 从复制文件到镜像中,比起ADD,只能复制本地文件
10)ENTRYPOINT 为容器提供运行时的默认值,不一样于cmd的是ENTRYPOINT只能传入指令,而CMD还能够传入参数
11)VOLUME 创建挂载点
12)USER 设置用户名会uid
13)WORKDIR 指定工做目录,该目录能够用于RUN,CMD,ENTRYPOINT,COPY和ADD指令,能够是绝对目录,也能够是相对目录
14)ONBUILD 为镜像添加触发器,可使用inspect查看。当该镜像被做为其余Dokcer中From指令的参数时,ONEBUILD注册的指令会按顺序执行,构建完成后,触发器指定被删除。注意ONEBUILD不能被嵌套
 
2、实战
 
1:在我本身的虚拟机上登陆我在阿里云搭建的docker镜像仓库 (帐号密码有须要的话私聊,哈哈)
 
docker login www.lereun.com:5000 
 
 
 
2:查看远端仓库的私有镜像有哪些
 
curl -u 帐号:密码 https://www.lereun.com:5000/v2/_catalog
 
 
 
3:下载centos基础镜像
 
docker pull www.lereun.com:5000/centos
 
 
 
4:下载完成后,docker images 查看镜像
 
 
 
5:建立一个目录,用于存放须要用到的包和Dockerfile文件
 
mkdir /root/Docker
 
把nginx的压缩包放在此目录下,并在这目录下编写Dockefile文件
 
 
 
Dockerfile的内容以下:
 
#基础镜像
FROM www.lereun.com:5000/centos
 
#维护者
MAINTAINER 836217653@qq.com
 
#把nginx的压缩包拷贝至/usr/local/docker下并解压
ADD nginx-1.12.2.tar.gz /usr/local/docker
 
#安装依赖包
RUN yum install -y gcc gcc-c++ glibc make autoconf openssl openssl-devel
RUN yum install -y libxslt-devel -y gd gd-devel GeoIP GeoIP-devel pcre pcre-devel
RUN useradd nginx
 
#改变当前路径,至关于cd进去了
WORKDIR /usr/local/docker/nginx-1.12.2
 
#编译安装
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
 
#添加环境变量
ENV PATH /usr/local/nginx/sbin:$PATH
 
#运行nginx,这样在启动容器的时候就不须要再带nginx启动
CMD /bin/sh -c 'nginx -g "daemon off;"'
 
EXPOSE 80
 
 
6:构建镜像
 
docker build -t centos_nginx .
 
查看镜像时能够看到:
 
 
 
7:启动基于该镜像的容器,测试访问nginx是否能成功
 
先建立将挂载的目录
 mkdir -p /docker/nginx
 
启动容器:
docker run -d -p 8070:80 -v /docker/nginx/conf.d:/usr/local/nginx/conf/conf.d -v /docker/nginx/nginx.conf:/usr/local/nginx/conf/nginx.conf -v /docker/nginx/log:/usr/local/nginx/logs centos_nginx
 
这里会报错:
 
 
意思是不能将nginx.conf文件映射到一个目录,因此这里还需作的一个操做就是在宿主机上拷贝一份nginx.conf到/docker/nginx目录下;这里得特别注意nginx的配置文件的一些路径,不然启动不起来,启动不起来能够查看docker的日志文件/var/log/message里
 
nginx的配置文件:
user nginx nginx;
 
worker_processes 8;
error_log logs/error.log info;
pid logs/nginx.pid;
worker_rlimit_nofile 65535;
 
events {
use epoll;
worker_connections 65535;
}
 
http {
include mime.types;
default_type application/octet-stream;
 
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
 
server_tokens off;
sendfile on;
tcp_nopush on;
keepalive_timeout 65;
gzip on;
 
include /usr/local/nginx/conf/conf.d/*;
 
server {
listen 80;
server_name localhost;
 
location /{
index index.php index.html index.htm;
}
 
}
 
}
 
docker正常启动以下:
 
注:
-p 8070: 80 表示将容器的80端口映射到宿主机的8070端口
-v /docker/nginx/conf.d: /usr/local/nginx/conf/conf.d   左边为宿主机目录,右边为docker下目录
-v /docker/nginx/nginx.conf:/usr/local/nginx/conf/nginx.conf
-v /docker/nginx/log:/usr/local/nginx/logs
这里个人理解就是:把docker里的nginx的配置文件和日志目录等挂载出来,能够直接在宿主机上更改
 
查看是否启动:docker ps -l
 
docker container ls
 
八、测试
 
测试一:访问本机的8070端口
 
 
测试二:修改挂载目录下的nginx配置文件,看是否生效
 
在server里添加一段:
location /testdocker{
    return 520;
}
 
重启该容器:
docker container restart 0177578edf39
 
 
测试访问:能够看到是访问成功的,说明在docker容器使用的nginx配置文件就是宿主机的这一个
 
 
也能够进入到挂载的日志目录,访问日志与错误日志都是在的
 
 
测试三:删除该容器后,挂载在容器的目录是否还在存在
 
 
查看挂载的目录仍是存在的
 
 
 
九、将此docker镜像上传到本身的仓库
 
1)修改docker的配置文件: vim /etc/docker/daemon.json 添加我本身的私有仓库地址
{
    "insecure-registries": [
        "www.lereun.com:5000"
    ]
}
 
2)重启docker
systemctl restart docker
 
3)将centos_nginx tag一下
docker tag centos_nginx www.lereun.com:5000/centos_nginx
 
4)push到私有仓库
 
 
在本身的私有仓库端查看镜像,或者使用curl查看
 

 

 
十、Docker里nginx为什么不在后台运行
 
在Dockerfile里能够看到,运行nginx的时候是这样的: nginx -g "daemon off;“
 
缘由:
docker容器会把容器内第一个进程,也就是pid=1的程序做为容器是否正在运行的一句,若是docker容器pid挂了,那么docker容器变回直接退出;docker run的时候把command做为容器的内部命令,若是使用nginx,nginx将在后台运行,这个时候nginx并非pid为1的程序,而是执行的bash;bash执行完nginx启动命令后就关了,因此容器也就退出了
 
在上面的例子中,nginx在后台启动时,能够查看挂载出来的日志目录,看到nginx的pid为1
 
 
 
nginx配置文件、Dockerfile、及nginx的安装包: https://gitee.com/lemon_le/docker_nginx
相关文章
相关标签/搜索