Docker包含三个概念:
(1)远程仓库即远程镜像库所有镜像的聚集地(不可进入操作)。
(2)本地镜像即从远程仓库拉取过来的镜像
(3)运行起来的本地镜像叫做容器(分层的可操作)
Docker使用:
1.首先通过第三方镜像库(c.163.com)拉取相应的信息比如centos,ubuntu,tomcat等作为基础镜像。
Docker pull xxxx
2.运行下载好的镜像。
Docker run -dt -p 宿主机端口:镜像端口 --name起一个名字 镜像id/镜像名字 bash
-d 后台运行
-t 生成一个伪终端
-p 指定端口
--name 为运行的容器起一个名字
3.进入容器有两种方法
(1)docker exec -it容器名字/容器id bash(ctrl+d退出时不会停止该运行的容器)
(2)Docker attach 容器名字/容器id (ctrl+d退出时会停止该运行的容器)
4.开始下载编译环境所需的相应的工具和所需的依赖包
(1)yum安装wget以及编译的工具 yum install -y wget gcc gcc-c++ make openssl-devel
(2)更新国内yum源
Wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/xxx/ Xxx表示你要选择的yum源 -O 下载并以不同的文件名保存 CentOS-Base.repo 表示命名的yum源
(3)下载各个版本的nginx版本
Wget http://nginx.org/download/xxx Xxx表示你要选择的nginx的版本
(4)下载pcre
ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/xxx
Xxx表示选择的版本
(5)更新yum确保最新的
Yum update
(6)下载php7
http://php.net/downloads.php
选择版本,选择国界
(7)把以上下载的东西全部粘贴到/usr/local/src 并且全部解压
(8)编译nginx
(1)创建nginx用户
groupadd -r nginx useradd -r -g nginx nginx
(2)编译安装nginx
cd xxx 切换到您的nginx目录 ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_ssl_module --with-http_stub_status_module --with-pcre=/usr/local/src/pcre-8.37 ./configure参数说明: --prefix=指定文件的安装目录 --user=指定用户 --group指定用户组 --with-使用已有的软件包和库文件 Make && make install 出现问题自行百度 echo "daemon off;" >> /usr/local/nginx/conf/nginx.conf #在nginx的配置文件里加上这一行很关键,这样nginx可以在docker启动的时候在后台运行!
(9)编译php
(1)准备php的依赖包
yum install -y bison bison-devel zlib-devel libmcrypt-devel mcrypt mhash-devel libxml2-devel libcurl-devel bzip2-devel readline-devel libedit-devel sqlite-devel
(2)进入php文件目录
(3)开始编译php
./configure --prefix=/usr/local/php --with-zlib-dir --with-freetype-dir --enable-mbstring --with-libxml-dir=/usr/local/libxml --enable-soap --enable-calendar --with-curl --with-mcrypt --with-zlib --with-gd --disable-rpath --enable-inline-optimization --with-bz2 --with-zlib --enable-sockets --enable-sysvsem --enable-sysvshm --enable-pcntl --enable-mbregex --enable-exif --enable-bcmath --with-mhash --enable-zip --with-pcre-regex --with-mysql --with-pdo-mysql --with-mysqli --with-jpeg-dir=/usr/local/libjpeg --with-png-dir=/usr/local/libpng --enable-gd-native-ttf --with-openssl --with-fpm-user=www --with-fpm-group=www --with-libdir=lib64 --enable-ftp --with-imap --with-imap-ssl --with-kerberos --with-gettext --with-xmlrpc --with-xsl --enable-opcache --enable-fpm --enable-xml --enable-shmop --enable-session --enable-ctype --with-iconv-dir --with-iconv
注:出现问题自行百度。
(4)make && make install
(5)准备php配置文件
cp php.ini-production /etc/php.ini cd /usr/local/php/etc cp php-fpm.conf.default php-fpm.conf
(6)修改配置文件
;daemonize = yes的注释去掉,并把yes改为no
(7)安装yar拓展
(1)安装二进制打包协议msgpack
find / -name phpize 查找phpize是否存在 yum install php-devel pecl install msgpack
注:出现问题自行百度
(2)下载yar wget http://pecl.php.net/get/xxx
Xxx表示版本 确定好与php版本对照这个很重要。
(3)解压编译tar -zxvf yar-2.0.0.tgz
(4)cd cd yar-2.0.0
(5)/usr/bin/phpize
(6)./configure --with-php-config=/usr/bin/php-config7.0*
(7)make && make install
(8)如果出现模块未安装可 php --ini 查看ini路径相对调整
(9)docker commit -m "描述" -a "作者" 容器id 仓库信息mydocker/nginx:版本信息v1
(10)docker save xxx > /home/save.tar
(11)Docker load xxx
PHP 应用容器化以及部署方法本文给大家分享的是如何把PHP应用容器化,以及使用docker在服务器上部署PHP应用,非常的简单实用,有需要的小伙伴
基于PHP7错误处理与异常处理方法(详解)下面小编就为大家分享一篇基于PHP7错误处理与异常处理方法(详解),具有很好的参考价值,希望对大家有所帮助。一
PHP7扩展开发之hello word实现方法详解这篇文章主要介绍了PHP7扩展开发之hello word实现方法,结合实例形式分析了php7扩展开发的具体步骤与相关操作技巧,涉及
PHP7扩展开发之基于函数方式使用lib库的方法详解这篇文章主要介绍了PHP7扩展开发之基于函数方式使用lib库的方法,结合实例形式分析了PHP7中lib库扩展的封装与调用相
PHP7下协程的实现方法详解最近在学习中遇到了协程,发现这类文章介绍的较少,所以下面这篇文章主要给大家介绍了关于PHP7下协程的实现方法
PHP 7.1中AES加解密方法mcrypt_module_open()的替换方案这篇文章主要给大家介绍了关于PHP 7.1中AES加解密方法mcrypt_module_open()替换方案的相关资料,文中通过示例代码介绍的