使用docker快速搭建nginx+php环境
在朋友的强烈推荐下,走上了docker之路。经过了繁琐的docker环境安装,看了下镜像/容器的简单使用,开始进行nginx+php环境的搭建,本文记录一下在安装过程中的笔记。
原文地址:代码汇个人博客 http://www.codehui.net/info/56.html
测试环境:centos7.6
,docker 18.09.1
首先要确保docker
环境已经安装成功
[root@localhost ~]# docker --version
Docker version 18.09.2, build 6247962
Docker 安装 Nginx
- 我们可以使用
docker search nginx
命令查找Docker Hub
上的 nginx 镜像,这里直接拉取官方的镜像
[root@localhost ~]# docker pull nginx
- 等待下载完成后,我们就可以在本地镜像列表里查到
REPOSITORY
为nginx
的镜像。
[root@localhost ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
nginx latest f09fe80eb0e7 6 days ago 109MB
- 使用nginx镜像开启nginx应用容器
[root@localhost ~]# docker run -p 80:80 -d --name mynginx -v /docker/www:/usr/share/nginx/www nginx
3218b3ad4e47018729b053ad834cf2665cf3af497b4a2ccccd758f792179e365
[root@localhost ~]#
-p 80:80:将容器的80端口映射到主机的80端口
-d 后台运行(守护进程)
--name mynginx:将容器命名为mynginx
-v 将主机中当前目录下的www挂载到容器的www目录
- 查看容器启动情况
[root@localhost ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
3218b3ad4e47 nginx "nginx -g 'daemon off" 3 seconds ago Up 2 seconds 0.0.0.0:80->80/tcp mynginx
- 通过浏览器访问,运行成功
Docker 安装 PHP
- 和
nginx
一样,我们可以先通过docker search php
查找镜像,这里直接拉取官方的镜像,标签为7.1-fpm,其他版本的可自行选择
[root@localhost ~]# docker pull php:7.1-fpm
- 等待下载完成后,我们就可以在本地镜像列表里查到REPOSITORY为php,标签为7.1-fpm的镜像。
[root@localhost ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
nginx latest f09fe80eb0e7 6 days ago 109MB
php 7.1-fpm 7c5ccac5d47f 6 days ago 358MB
- 使用php镜像开启php-frm应用容器
[root@localhost ~]# docker run -p 9000:9000 -d --name myphp-fpm -v /docker/www:/usr/share/nginx/www php:7.1-fpm
51adb2df6004cbfcd113f280c2c5497c83a9720d8b689316a3678b1a126d5129
[root@localhost ~]#
-p 9000:9000 :将容器的9000端口映射到主机的9000端口
-d 后台运行(守护进程)
--name myphp-fpm:将容器命名为myphp-fpm
-v 将主机中当前目录下的www挂载到容器的www目录
- 查看容器启动情况
[root@localhost ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
51adb2df6004 php:7.1-fpm "docker-php-entrypoif" 45 seconds ago Up 43 seconds 0.0.0.0:9000->9000/tcp myphp-fpm
3218b3ad4e47 nginx "nginx -g 'daemon off" 18 minutes ago Up 18 minutes 0.0.0.0:80->80/tcp mynginx
到这里,可以看到nginx和php都运行成功(STATUS为up说明正在运行)
- 查看ip信息
[root@localhost ~]# docker inspect myphp-fpm | grep "IPAddress"
"SecondaryIPAddresses": null,
"IPAddress": "172.17.0.3",
"IPAddress": "172.17.0.3",
修改nginx相关配置
容器里面是没有vim
,不能直接修改配置文件。当然我们也可以在容器里面安装vim
,这里介绍另一种方法
- 进入正在运行的nginx容器
[root@localhost ~]# docker exec -it mynginx bash
root@3218b3ad4e47:/#
配置文件地址 /etc/nginx/conf.d/default.conf
root@3218b3ad4e47:/# cd /etc/nginx/conf.d/
root@3218b3ad4e47:/etc/nginx/conf.d# ls
default.conf
root@3218b3ad4e47:/etc/nginx/conf.d#
- 然后使用
ctrl + p + q
退出容器,使用exit
的话会让容器停止。 - 使用专用的复制命令将配置文件复制到宿主机,然后在宿主机进行编辑
[root@localhost docker]# docker cp mynginx:/etc/nginx/conf.d/default.conf ./default.conf
- 在宿主机修改配置文件的php部分,内容如下:
location ~ \.php$ {
fastcgi_pass 172.17.0.3:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /usr/share/nginx/www$fastcgi_script_name;
fastcgi_param SCRIPT_NAME $fastcgi_script_name;
include fastcgi_params;
}
其中的ip也可以修改为宿主机的ip或者上面docker
命令查看的ip。
- 然后使用复制命令将宿主机的文件复制到容器
[root@localhost docker]# docker cp ./default.conf mynginx:/etc/nginx/conf.d/default.conf
- 进入容器中,重新载入nginx配置文件
[root@localhost docker]# docker exec -it mynginx bash
root@3218b3ad4e47:/# service nginx reload
[ ok ] Reloading nginx: nginx.
root@3218b3ad4e47:/#
大功告成
然后我们测试一下
[root@localhost www]# echo "<?php echo phpinfo();" > info.php
访问成功
上面这个修改后的镜像已经上传至 Docker Hub,可以省略修改配置文件这一步,使用方法
[root@localhost ~]# docker pull codehi/nginx:v1
[root@localhost ~]# docker pull codehi/php:7.1-fpm
这里推荐一款集成环境dnmp
,我也使用过还不错,安装方便,功能齐全。
项目地址: https://github.com/yeszao/dnmp
使用docker快速搭建nginx+php环境的更多相关文章
- 使用Docker快速搭建Nginx+PHP-FPM环境
下载nginx官方镜像和php-fpm镜像 docker pull nginx docker pull bitnami/php-fpm 使用php-fpm镜像开启php-fpm应用容器 docker ...
- 一文教您如何通过 Docker 快速搭建各种测试环境(Mysql, Redis, Elasticsearch, MongoDB) | 建议收藏
欢迎关注个人微信公众号: 小哈学Java, 文末分享阿里 P8 高级架构师吐血总结的 <Java 核心知识整理&面试.pdf>资源链接!! 个人网站: https://www.ex ...
- Docker-教你如何通过 Docker 快速搭建各种测试环境
今天给大家分享的主题是,如何通过 Docker 快速搭建各种测试环境,本文列举的,也是作者在工作中经常用到的,其中包括 MySQL.Redis.Elasticsearch.MongoDB 安装步骤,通 ...
- 五分钟用Docker快速搭建Go开发环境
挺早以前在我写过一篇用 `Docker`搭建LNMP开发环境的文章:[用Docker搭建Laravel开发环境](http://mp.weixin.qq.com/s?__biz=MzUzNTY5MzU ...
- 使用Docker快速搭建PHP开发环境
最近有个同事找过来,希望我对在很早之前写的一个PHP网站上增加一些功能,当时开发使用xampp构建的本地开发环境,但是现在我的笔记本电脑已经更新,没有当时的开发环境.本着尽量不往电脑上装无用软件的原则 ...
- Docker 快速搭建 MySQL8 开发环境
使用 Docker 快速搭建一个 MySQL8 开发环境 步骤 获取镜像 docker pull mysql:8 启动容器,密码 123456,映射 3306 端口 docker run --name ...
- 使用Docker快速搭建Nginx+PHP-FPM+MySQL+phpMyAdmin环境
一.概述 环境介绍 操作系统:centos 7.6 docker版本:19.03.8 ip地址:192.168.31.34 本文将介绍如何使用单机部署Nginx+PHP-FPM环境 二.Nginx+P ...
- 教你如何用Docker快速搭建深度学习环境
本教程搭建集 Tensorflow.Keras.Coffe.PyTorch 等深度学习框架于一身的环境,及jupyter. 本教程使用nvidia-docker启动实例,通过本教程可以从一个全新的Ub ...
- docker一键搭建Nginx+PHP环境(含自动部署命令)
文章的主要部分是一步一步的教程,文章的最后是我整理好的一键安装命令,自动下载并安装docker,构建镜像,启动容器集群(压缩包内注释覆盖范围达到80%) 大家可以看完教程亲自尝试下,也可以直接执行一键 ...
随机推荐
- MSP430F149串口收发程序的学习(一)
首先将用到的IO口设置为第二模式: ①使用串口USART0则设置P3.4 P3.5 ,使用USART1则设置P3.6,P3.7 (P3SEL |= BIT3+BIT4:P3SEL |= BIT6+BI ...
- 那些优秀的.NET开发者----汪宇杰:从重视细节,到成就技术专家
初识汪宇杰 在长沙.NET技术社区筹建过程中,溪源有幸认识来自上海的MVP汪宇杰Edi Wang.在中国众多的微软MVP中,Edi Wang作为一名九零后,也是一位年轻而充满才气的开发者,或许他或许外 ...
- KnockoutJS-快速入门
虽然在WPF中接触过MVVM模式,可是刚开始在Web中接触到Knockout.JS让我大吃一惊,简化了好多工作量,原来可能需要一大堆的JS脚本完成的工作量,被释放许多.接触KnockoutJS一年多了 ...
- 『集群』004 Slithice 集群分布式(多个客户端,基于中央服务器的集群服务)
Slithice 集群分布式(多个客户端,基于中央服务器的多个集群服务端) 案例Demo展示: 集群架构图 如下: 如上图,上图 展示了 这个集群 的 结构: >一个中央服务器(可以有多个),负 ...
- LVS(五)LVS的持久连接
什么是持久链接 把某个客户端的请求始终定向到同一应用服务器上.对于LVS来说持久连接和算法没有关系.也就是使用任何算法LVS都可以实现同一客户端的请求转发到之前选定的应用服务器,以保持会话.而且还能实 ...
- Promise来控制JavaScript的异步执行
一般来说,js.html都是按照从上至下这种方式来进行执行的.这就造成了,基本上所有的执行过程都是在一个线程中进行. 我们都知道,ajax的使用大大的提高了前后台的沟通效率,那么有没有什么方式,让js ...
- Python:黑板课爬虫闯关第三关
第三关开始才算是进入正题了. 输入网址 http://www.heibanke.com/lesson/crawler_ex02/,直接跳转到了 http://www.heibanke.com/acco ...
- Asp.Net进程外Session(状态服务器Session、数据库Session)
介绍 我们知道,当浏览器关闭,或者网站重启的时候,会话就结束了.即Seesion就丢失了.(当Web.config配置文件改动,哪怕什么内容都不加,仅仅往配置文件中加一个空格都是改we.config变 ...
- 在线生成二维码的API接口
现在很多大网站都有这样的一个功能,使用手机扫描一下网页上的二维码便可快速在手机上访问网站.想要实现这样的功能其实很简单,下面麦布分享几个在线生成网址二维码的API接口.都是采用http协议接口,无需下 ...
- asp.net 仿微信端菜单设置
第一步:添加引用文件 <link rel="stylesheet" href="~/assets/css/bootstrap.min.css"> & ...