赞
踩
公司的服务器版本用的是:
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进行查看
- 首先安装epel:
- yum install epel-release
- 接着就安装docker:
- yum install docker-io
service docker start
查看进程
ps -ef | grep docker
在/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进行查看。
通过上面绑定的端口进行访问:
192.168.1.100:80:80
docker stop $(docker ps -a -q)
如果想要删除所有container的话再加一个指令:
docker rm $(docker ps -a -q)
docker images
docker rmi <image id>
想要删除untagged images,也就是那些id为<None>的image的话可以用
docker rmi $(docker images | grep "^<none>" | awk "{print $3}")
要删除全部image的话
docker rmi $(docker images -q)
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。