docker-compose 部署 nginx + php-fpm + mysql

先把 nginx 运行起来,直接使用官方镜像即可

新建一个空文件夹test(如果是Windows系统,在C:\Users文件夹下新建)

在test下新建文件docker-compose.yml,内容如下:

version:"3"services:web:image:nginx    ports:-"80:80"volumes:-./project:/var/www/html/project-./default.conf:/etc/nginx/conf.d/default.conf-./log/nginx:/var/log/nginx    networks:-webnetnetworks:webnet:

新建文件default.conf,内容如下:

server{listen80;index          index.php index.html;server_name    _;root/var/www/html/project;access_log/var/log/nginx/access.log;error_log/var/log/nginx/error.log;}

最后再新建一个project目录模拟项目目录,新建入口文件index.html, 内容如下:

<!DOCTYPE html><html><head><metacharset="utf-8"><title></title></head><body><h1>Nginx 运行成功</h1></body></html>

目录结构是这样的

test 目录结构

在 test 文件夹下执行:

docker-compose up

docker-compose up

如果本地没有 nginx 镜像,docker 会自动先拉取镜像

可以看到,docker 先用默认驱动新建了一个网络 test_webnet,因为我们在 docker-compose.ym 中有配置网络 webnet,其中 test 是文件夹名(这是默认行为,为了防止重名)。然后新建了一个 nginx 容器 test_web_1

此时 nginx 在运行状态,打开浏览器,访问http://localhost或者对应虚拟机的 ip 即可,运行结果如下:

ctrl + c停止容器运行,然后加上 -d (detach)参数,可以让容器在后台运行:

docker-compose up -d

然后就可以查看容器的运行状态了

docker ps

移除部署

docker-compose down

PHP

在docker-compose.yml中添加 php 服务:

version:"3"services:web:image:nginx    ports:-"80:80"volumes:-./project:/var/www/html/project-./default.conf:/etc/nginx/conf.d/default.conf-./log/nginx:/var/log/nginx    networks:-webnet  php:image:php:5.6-fpm    volumes:-./project:/var/www/html/project    networks:-webnetnetworks:webnet:

修改default.conf添加 FastCGI 配置:

server{listen80;index          index.php index.html;server_name_;root/var/www/html/project;access_log/var/log/nginx/access.log;error_log/var/log/nginx/error.log;location~\.php${try_files$uri=404;fastcgi_split_path_info^(.+\.php)(/.+)$;fastcgi_pass php:9000;fastcgi_index index.php;includefastcgi_params;fastcgi_paramSCRIPT_FILENAME$document_root$fastcgi_script_name;fastcgi_paramPATH_INFO$fastcgi_path_info;}}

最后在项目目录project中添加phpinfo.php文件

<?phpphpinfo();

现在目录结构是这样的:

test 目录

运行

docker-compose up -d

测试成功

http://localhost/phpinfo.php

安装 PDO 扩展

官方的镜像都是“纯净版”,也就是没有安装任何扩展,要用 PHP 连接数据库还需要先安装一下扩展,这里我们安装 PDO

所以接下来我们要自己动手构建一个镜像了

新建一个空的文件夹php_pdo,新建文件Dockerfile:

FROMphp:5.6-fpmRUNapt-getupdate \&&docker-php-ext-install pdo pdo_mysql

构建

docker build -t lince/php:5.6-fpm

上传到dockerhub(具体步骤可以查看官方文档

docker login// 登录,随后会提示输入密码docker push lince/php:5.6-fpm

这样我们就可以在docker-compose.yml中将官方 php 镜像替换成我们刚刚构建成的带 PDO 扩展的镜像

version:"3"services:web:image:nginx    ports:-"80:80"volumes:-./project:/var/www/html/project-./default.conf:/etc/nginx/conf.d/default.conf-./log/nginx:/var/log/nginx    networks:-webnet  php:image:lince/php:5.6-fpm # 替换这里    volumes:-./project:/var/www/html/project    networks:-webnetnetworks:webnet:

重新部署并测试一下

docker-compose up-dhttp://localhost/phpinfo.php

MYSQL

修改docker-compose.yml如下:

version:"3"services:web:image:nginx    ports:-"80:80"volumes:-./project:/var/www/html/project-./default.conf:/etc/nginx/conf.d/default.conf-./log/nginx:/var/log/nginx    networks:-webnet  php:image:lince/php:5.6-fpm    volumes:-./project:/var/www/html/project    networks:-webnet  mysql:# 添加 mysql 服务    image:mysql:5.6environment:-TZ=Asia/Shanghai # 设置时区-MYSQL_ROOT_PASSWORD=zxcvbnm # 设置 root 用户密码    command:--character-set-server=utf8mb4--collation-server=utf8mb4_unicode_ci # 设置编码    networks:-webnetnetworks:webnet:

运行:

docker-compose up -d

进入容器:

docker psdocker exec -it CONTAINER ID bash

need-to-insert-img

进入 mysql 容器

新建一个数据库test,然后再建一个表name作为测试,新建几条数据

最后新建文件connect_mysql.php:

<?phptry{$conn=newPDO("mysql:host=mysql:3306;dbname=test","root","zxcvbnm");echo"连接成功\n";$stmt=$conn->prepare("SELECT * FROM name");$stmt->execute();$stmt->setFetchMode(PDO::FETCH_ASSOC);foreach($stmt->fetchAll()as$key=>$value){echo$value["name"]."\n";}}catch(PDOException$e){echo$e->getMessage();}?>

连接成功:

连接 mysql 成功

为了数据持久化需求,还需要挂载一个数据卷(Volume)到本机上:

mysql:image:mysql:5.6ports:-"3306:3306"volumes:# 挂载数据卷-./mysql:/var/lib/mysql    restart:always    environment:-TZ=Asia/Shanghai-MYSQL_ROOT_PASSWORD=zxcvbnm    command:--character-set-server=utf8mb4--collation-server=utf8mb4_unicode_ci    networks:-webnet

Windows系统中mysql挂载了数据卷,启动mysql时可能会报错:

...InnoDB:Operating system errornumber22ina file operation.InnoDB:Errornumber22means'Invalid argument'....

解决办法是关闭 innodb_use_native_aio

mysql:image:mysql:5.6ports:-"3306:3306"volumes:-./mysql:/var/lib/mysql    restart:always    environment:-TZ=Asia/Shanghai-MYSQL_ROOT_PASSWORD=zxcvbnm    command:--character-set-server=utf8mb4--collation-server=utf8mb4_unicode_ci--innodb_use_native_aio=0networks:-webnet

重新运行,成功

作者:linceln

链接:https://www.jianshu.com/p/f9bc3f0f0ffe

来源:简书

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容