Centos6.5通过Dockerfile构建Nginx并安装lua-nginx-module模块
一、前言公司的服务器版本用的是:centos6.5 2.6.32-431.el6.x86_64通过命令安装dockeryum -y install docker-io安装成功之后,启动Docker,提示:docker: unrecognized service在网上找了一圈,发现如下说明:Docker容器最早受到RHEL完善的支持是从最近的CentOS ...
一、前言
公司的服务器版本用的是:
centos6.5 2.6.32-431.el6.x86_64
通过命令安装docker
yum -y install docker-io
安装成功之后,启动Docker,提示:
docker: unrecognized service
在网上找了一圈,发现如下说明:
Docker容器最早受到RHEL完善的支持是从最近的CentOS 7.0开始的,官方说明是只能运行于64位架构平台,内核版本为2.6.32-431及以上(即 >= CentOS 6.5,运行docker时实际提示3.10.0及以上)。 需要注意的是CentOS 6.5与7.0的安装是有一点点不同的,CentOS 6.x上Docker的安装包叫docker-io,并且来源于Fedora epel库,这个仓库维护了大量的没有包含在发行版中的软件,所以先要安装EPEL,而CentOS 7.x的Docker直接包含在官方镜像源的Extras仓库(CentOS-Base.repo下的[extras]节enable=1启用)。
内核版本过低。。。所以需要升级内核。
安装的nginx版本如下:
nginx-1.14.0.tar.gz
LuaJIT-2.0.5.tar.gz
ngx_devel_kit-0.3.0.tar.gz
lua-nginx-module-0.10.13.tar.gz
ngx_cache_purge-2.3.tar.gz
所用docker版本如下:
Docker version 1.7.1, build 786b29d/1.7.1
二、升级内核
(1)、查看内核版本
$ uname -r
# 结果:2.6.32-431.el6.x86_64,不满足上文的需求,故此需要升级内核。
(2)、下载如下两个文件:
kernel-ml-aufs-3.10.5-3.el6.x86_64.rpm.gz
kernel-ml-aufs-devel-3.10.5-3.el6.x86_64.rpm.gz
(3)、解压:
gunzip kernel-ml-aufs-3.10.5-3.el6.x86_64.rpm.gz
gunzip kernel-ml-aufs-devel-3.10.5-3.el6.x86_64.rpm.gz
(4)、安装:
rpm -ivh kernel-ml-aufs-3.10.5-3.el6.x86_64.rpm kernel-ml-aufs-devel-3.10.5-3.el6.x86_64.rpm
(5)、修改配置:
vi /etc/grub.conf
把default=1改为default=0,然后重启电脑(reboot),然后uname -r进行查看
三、安装docker
首先安装epel:
yum install epel-release
接着就安装docker:
yum install docker-io
四、启动Docker
service docker start
查看进程
ps -ef | grep docker
五、Dockerfile构建Nginx镜像
在/home/docker/目录下创建Dockerfile文件,内容如下:
# nginx Dockerfile
# Version 1.0
# author fendo
# Base images 基础镜像
FROM centos:centos7
#FROM hub.c.163.com/netease_comb/centos:7
#安装相关依赖
RUN yum -y update
RUN yum -y install gcc gcc-c++ autoconf automake make
RUN yum -y install zlib zlib-devel openssl* pcre* wget lua-devel
#MAINTAINER 维护者信息
MAINTAINER fendo 2312892206@qq.com
#ADD 获取url中的文件,放在当前目录下
ADD http://nginx.org/download/nginx-1.14.0.tar.gz /tmp/
#LuaJIT 2.1
#ADD http://luajit.org/download/LuaJIT-2.0.5.tar.gz /tmp/
ADD https://github.com/LuaJIT/LuaJIT/archive/v2.0.5.tar.gz /tmp/
#ngx_devel_kit(NDK)模块
ADD https://github.com/simpl/ngx_devel_kit/archive/v0.3.0.tar.gz /tmp/
#lua-nginx-module 模块
ADD https://github.com/openresty/lua-nginx-module/archive/v0.10.13.tar.gz /tmp/
#nginx ngx_cache_purge模块
ADD http://labs.frickle.com/files/ngx_cache_purge-2.3.tar.gz /tmp/
#切换目录
WORKDIR /tmp
#安装LuaJIT 2.0.5
#RUN wget http://luajit.org/download/LuaJIT-2.0.5.tar.gz -P /tmp/
RUN tar zxf v2.0.5.tar.gz
WORKDIR /tmp/LuaJIT-2.0.5
#RUN cd LuaJIT-2.0.5
RUN make PREFIX=/usr/local/luajit
RUN make install PREFIX=/usr/local/luajit
#安装ngx_devel_kit(NDK)
WORKDIR /tmp
RUN tar -xzvf v0.3.0.tar.gz
RUN cp -r ngx_devel_kit-0.3.0/ /usr/local/src/
#安装lua-nginx-module模块
RUN tar -xzvf v0.10.13.tar.gz
RUN cp -r lua-nginx-module-0.10.13/ /usr/local/src/
#安装nginx ngx_cache_purge模块
RUN tar -xzvf ngx_cache_purge-2.3.tar.gz
RUN cp -r ngx_cache_purge-2.3/ /usr/local/src/
#设置环境变量
RUN export LUAJIT_LIB=/usr/local/lib
RUN export LUAJIT_INC=/usr/local/include/luajit-2.0
RUN mkdir -p {/usr/local/nginx/logs,/var/lock}
#编译安装Nginx
RUN useradd -M -s /sbin/nologin nginx
RUN tar -zxvf nginx-1.14.0.tar.gz
RUN mkdir -p /usr/local/nginx
RUN cd /tmp/nginx-1.14.0 \
&& ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx \
--error-log-path=/usr/local/nginx/logs/error.log \
--http-log-path=/usr/local/nginx/logs/access.log \
--pid-path=/usr/local/nginx/logs/nginx.pid \
--lock-path=/var/lock/nginx.lock \
--with-ld-opt="-Wl,-rpath,/usr/local/luajit/lib" \
--with-http_stub_status_module \
--with-http_ssl_module \
--with-http_sub_module \
--add-module=/usr/local/src/lua-nginx-module-0.10.13 \
--add-module=/usr/local/src/ngx_devel_kit-0.3.0 \
--add-module=/usr/local/src/ngx_cache_purge-2.3 \
&& make && make install
#参数说明
#--prefix 用于指定nginx编译后的安装目录
#--add-module 为添加的第三方模块,此次添加了fdfs的nginx模块
#--with..._module 表示启用的nginx模块,如此处启用了http_ssl_module模块
RUN /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
RUN ln -s /usr/local/nginx/sbin/* /usr/local/sbin/
#EXPOSE 映射端口
EXPOSE 80 443
#CMD 运行以下命令
#CMD ["nginx"]
CMD ["/usr/local/nginx/sbin/nginx","-g","daemon off;"]
在该目录下执行以下命令进行构建镜像:
docker build -t centos/nginx:1.14 .
然后查看容器:
docker images
六、启动镜像
可通过以下两种方式启动镜像:
docker run -itd -p 192.168.1.100:80:80 centos_nginx:1.14 /bin/bash
docker run -itd -p 192.168.1.100:80:80 -p 192.168.1.100:443:443 centos_nginx:1.14 /usr/local/nginx/sbin/nginx -g "daemon off;"
如果启动失败,可进入到镜像中去,通过命令/usr/local/nginx/sbin/nginx启动nginx。
七、进入镜像
启动镜像之后,可通过如下命令进入镜像:
docker attach 容器ID
在镜像中,如果想退出的话,通过ctrl+d的话,退出去,会直接把镜像给停了,所以需要按Ctrl+P+Q来退出控制台,通过docker ps进行查看。
八、访问Nginx
通过上面绑定的端口进行访问:
192.168.1.100:80:80
九、常用命令
1.停止所有的container,这样才能够删除其中的images:
docker stop $(docker ps -a -q)
如果想要删除所有container的话再加一个指令:
docker rm $(docker ps -a -q)
2.查看当前有些什么images
docker images
3.删除images,通过image的id来指定删除谁
docker rmi <image id>
想要删除untagged images,也就是那些id为<None>的image的话可以用
docker rmi $(docker images | grep "^<none>" | awk "{print $3}")
要删除全部image的话
docker rmi $(docker images -q)
更多推荐
所有评论(0)