Centos6.5通过Dockerfile构建Nginx并安装lua-nginx-module模块

商振
2023-12-01

 

一、前言

公司的服务器版本用的是:

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)

 

 类似资料: