当前位置:   article > 正文

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

docker +lua+nginx

 

一、前言

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

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)、下载如下两个文件:

  1. kernel-ml-aufs-3.10.5-3.el6.x86_64.rpm.gz
  2. kernel-ml-aufs-devel-3.10.5-3.el6.x86_64.rpm.gz

(3)、解压:

  1. gunzip kernel-ml-aufs-3.10.5-3.el6.x86_64.rpm.gz
  2. 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

  1. 首先安装epel:
  2. yum install epel-release
  3. 接着就安装docker:
  4. yum install docker-io

四、启动Docker

service docker start

查看进程

ps -ef | grep docker

五、Dockerfile构建Nginx镜像

 在/home/docker/目录下创建Dockerfile文件,内容如下:

  1. # nginx Dockerfile
  2. # Version 1.0
  3. # author fendo
  4. # Base images 基础镜像
  5. FROM centos:centos7
  6. #FROM hub.c.163.com/netease_comb/centos:7
  7. #安装相关依赖
  8. RUN yum -y update
  9. RUN yum -y install gcc gcc-c++ autoconf automake make
  10. RUN yum -y install zlib zlib-devel openssl* pcre* wget lua-devel
  11. #MAINTAINER 维护者信息
  12. MAINTAINER fendo 2312892206@qq.com
  13. #ADD 获取url中的文件,放在当前目录下
  14. ADD http://nginx.org/download/nginx-1.14.0.tar.gz /tmp/
  15. #LuaJIT 2.1
  16. #ADD http://luajit.org/download/LuaJIT-2.0.5.tar.gz /tmp/
  17. ADD https://github.com/LuaJIT/LuaJIT/archive/v2.0.5.tar.gz /tmp/
  18. #ngx_devel_kit(NDK)模块
  19. ADD https://github.com/simpl/ngx_devel_kit/archive/v0.3.0.tar.gz /tmp/
  20. #lua-nginx-module 模块
  21. ADD https://github.com/openresty/lua-nginx-module/archive/v0.10.13.tar.gz /tmp/
  22. #nginx ngx_cache_purge模块
  23. ADD http://labs.frickle.com/files/ngx_cache_purge-2.3.tar.gz /tmp/
  24. #切换目录
  25. WORKDIR /tmp
  26. #安装LuaJIT 2.0.5
  27. #RUN wget http://luajit.org/download/LuaJIT-2.0.5.tar.gz -P /tmp/
  28. RUN tar zxf v2.0.5.tar.gz
  29. WORKDIR /tmp/LuaJIT-2.0.5
  30. #RUN cd LuaJIT-2.0.5
  31. RUN make PREFIX=/usr/local/luajit
  32. RUN make install PREFIX=/usr/local/luajit
  33. #安装ngx_devel_kit(NDK)
  34. WORKDIR /tmp
  35. RUN tar -xzvf v0.3.0.tar.gz
  36. RUN cp -r ngx_devel_kit-0.3.0/ /usr/local/src/
  37. #安装lua-nginx-module模块
  38. RUN tar -xzvf v0.10.13.tar.gz
  39. RUN cp -r lua-nginx-module-0.10.13/ /usr/local/src/
  40. #安装nginx ngx_cache_purge模块
  41. RUN tar -xzvf ngx_cache_purge-2.3.tar.gz
  42. RUN cp -r ngx_cache_purge-2.3/ /usr/local/src/
  43. #设置环境变量
  44. RUN export LUAJIT_LIB=/usr/local/lib
  45. RUN export LUAJIT_INC=/usr/local/include/luajit-2.0
  46. RUN mkdir -p {/usr/local/nginx/logs,/var/lock}
  47. #编译安装Nginx
  48. RUN useradd -M -s /sbin/nologin nginx
  49. RUN tar -zxvf nginx-1.14.0.tar.gz
  50. RUN mkdir -p /usr/local/nginx
  51. RUN cd /tmp/nginx-1.14.0 \
  52. && ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx \
  53. --error-log-path=/usr/local/nginx/logs/error.log \
  54. --http-log-path=/usr/local/nginx/logs/access.log \
  55. --pid-path=/usr/local/nginx/logs/nginx.pid \
  56. --lock-path=/var/lock/nginx.lock \
  57. --with-ld-opt="-Wl,-rpath,/usr/local/luajit/lib" \
  58. --with-http_stub_status_module \
  59. --with-http_ssl_module \
  60. --with-http_sub_module \
  61. --add-module=/usr/local/src/lua-nginx-module-0.10.13 \
  62. --add-module=/usr/local/src/ngx_devel_kit-0.3.0 \
  63. --add-module=/usr/local/src/ngx_cache_purge-2.3 \
  64. && make && make install
  65. #参数说明
  66. #--prefix 用于指定nginx编译后的安装目录
  67. #--add-module 为添加的第三方模块,此次添加了fdfs的nginx模块
  68. #--with..._module 表示启用的nginx模块,如此处启用了http_ssl_module模块
  69. RUN /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
  70. RUN ln -s /usr/local/nginx/sbin/* /usr/local/sbin/
  71. #EXPOSE 映射端口
  72. EXPOSE 80 443
  73. #CMD 运行以下命令
  74. #CMD ["nginx"]
  75. CMD ["/usr/local/nginx/sbin/nginx","-g","daemon off;"]

在该目录下执行以下命令进行构建镜像:

docker build -t centos/nginx:1.14 .

然后查看容器:

docker images

六、启动镜像

可通过以下两种方式启动镜像:

  1. docker run -itd -p 192.168.1.100:80:80 centos_nginx:1.14 /bin/bash
  2. 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)

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/197573
推荐阅读
相关标签
  

闽ICP备14008679号