Docker六脉神剑(二) 使用Docker构建lnmp开发环境

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: Docker六脉神剑(二) 使用Docker构建lnmp开发环境

docker可以快速启动一个容器, 而且非常轻量级。

使用docker来构建开发环境效率特别高,而且迁移特别快。

像以前如果想在本地搭建开发环境的话, 首先得先考虑本地windows或者linux环境, 然后安装各种包及扩展。

docker完全不用考虑, 接下来我们用docker来构建一套lnmp环境。

LNMP

  • l: linux
  • n: nginx
  • m: mysql
  • p: php

这就是所谓的lnmp了, 一套开发环境。

我们搭建php采用7.2-fpm, nginx采用最新即可, mysql使用5.7

搭建

我们先将所需镜像拉取下来, 然后运行各自容器, 并且做到相关容器连接即可完成环境搭建。

运行以下命令获取镜像
docker pull php:7.2-fpm
docker pull mysql:5.7
docker pull nginx

docker images 查看本地镜像

基于获取的镜像启动容器

随意在哪新建一个lnmp的目录, 然后进入这个目录

  • 运行一个php-fpm的容器
mkdir -p ~/Workspace/lnmp/mysql/mysql_sock  // 为之后存放sock文件
docker run --name  aoppp-fpm -v ~/Workspace/lnmp/www:/www  -v ~/Workspace/lnmp/mysql/mysql_sock:/var/run/mysqld -d php:7.2-fpm
  • --name aoppp-fpm 将容器命名为 aoppp-fpm
  • -v ~/Workspace/lnmp/www:/www 将主机中项目的目录 www 挂载到容器的 /www
运行nginx的容器

因为我们希望nginx是可配置的 不然每次都要进容器修改nginx配置, 所以我们可以利用docker容器的目录映射将配置文件放到宿主机, 这样就很方便了

创建nginx配置文件目录

mkdir ~/Workspace/lnmp/conf/conf.d

创建nginx配置文件在conf.d目录下

  • longing.conf
server {
    listen       80;
    server_name  www.longing.com;
    location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm index.php;
    }
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }
    # 走fpm解析
    location ~ \.php$ {
        fastcgi_pass   php:9000;    # php:9000 表示php-fpm的服务名称
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME  /www/$fastcgi_script_name;  # /www已经是宿主机的目录了,因为我们进行了映射
        include        fastcgi_params;
    }
}
  • 启动nginx容器
docker run --name longing-php-nginx -p 8083:80 -d -v ~/Workspace/lnmp/www:/usr/share/nginx/html:ro -v ~/Workspace/lnmp/conf/conf.d:/etc/nginx/conf.d:ro --link aoppp-fpm:php nginx
-p 8083:80: 端口映射,把 nginx 中的 80 映射到本地的 8083 端口。
~/Workspace/lnmp/www: 是本地 html 文件的存储目录,/usr/share/nginx/html 是容器内 html 文件的存储目录。
~/Workspace/lnmp/conf/conf.d: 是本地 nginx 配置文件的存储目录,/etc/nginx/conf.d 是容器内 nginx 配置文件的存储目录。
--link aoppp-fpm:php: 把 aoppp-fpm 的网络并入 nginx,并通过修改 nginx 的 /etc/hosts,把域名 php 映射成 127.0.0.1,让 nginx 通过 php:9000 访问 php-fpm。

接下来我们在~/Workspace/lnmp/www目录下创建 index.php,代码如下:

<?php
echo phpinfo();
?>
  • 设置本地hosts
vim /etc/hosts 追加这行 127.0.0.1 www.longing.com

访问虚拟域名加上映射的nginx端口

配置Mysql
  • 创建mysql的映射目录
mkdir -p ~/Workspace/lnmp/mysql/data ~/Workspace/lnmp/mysql/logs 
data 目录将映射为 mysql 容器配置的数据文件存放路径
logs 目录将映射为 mysql 容器的日志目录
其实还可以将mysql的配置文件映射出来, 这样要方便一点, 但是我这里为了演示就不做这个了, 还得弄配置文件, 大家可以顺便把这个配置一下
  • 启动mysql容器
docker run -p 3307:3306 --name aoppp-mysql -v ~/Workspace/lnmp/mysql/logs:/var/log/mysql -v ~/Workspace/lnmp/mysql/data:/var/lib/mysql -v ~/Workspace/lnmp/mysql/mysql_sock:/var/run/mysqld  -e MYSQL_ROOT_PASSWORD=123456 -e MYSQL_USER=longing -e MYSQL_PASSWORD=123456 -e MYSQL_DATABASE=longing -d --link aoppp-fpm mysql:5.7
-e 指设置环境变量
MYSQL_USER 设置mysql用户
MYSQL_PASSWORD 设置用户密码
MYSQL_DATABASE 设置需要使用的数据库

可以利用Navicat连接数据库了,我连接上已经随意创建了一张test的表

  • php操作mysql

我们这里利用的是pdo来操作mysql, 默认php这个镜像是没有mysqlpdo扩展的, 需要先安装

执行以下两条命令

docker-php-ext-install pdo_mysql
echo "pdo_mysql.default_socket=/var/run/mysqld/mysqld.sock" >> /usr/local/etc/php/conf.d/docker-php-ext-mysqli.ini \
    && echo "mysql.default_socket=/var/run/mysqld/mysqld.sock" >> /usr/local/etc/php/conf.d/docker-php-ext-mysqli.ini \
    && echo "mysqli.default_socket=/var/run/mysqld/mysqld.sock" >> /usr/local/etc/php/conf.d/docker-php-ext-mysqli.ini

然后重启php容器

docker restart aoppp-fpm

博主在配置环境的时候还出现一个坑, 就是使用pdo去连接mysql的时候,pdo和mysql通信sock文件来通信的, 但是因为在单独的容器里面, 所以需要把mysql的sock文件挂载出来, 然后再到php-fpm的容器里面去设置sock文件的路径, 一定要注意!!!!!

  • index.php代码
<?php
//PDO中的预处理1:sql语句中是: (别名的方式)的
header("Content-type:text/html;charset=utf-8");
//实例化PDO
try{
    $pdo = new PDO(
        "mysql:host=localhost;dbname=longing",
        "longing",
        "123456"
    );
}catch(PDOException $pe){
    die("PDO实例失败!原因:".$pe->getMessage());
}
//定义sql语句
$sql = "select * from test";
//预处理sql
$stmt = $pdo->prepare($sql); 
//执行
$stmt->execute();
// 获取多条数据
$res = $stmt->fetchAll(PDO::FETCH_ASSOC);
var_dump($res);

结束

这样,开发环境就搭建成功了, 如果想使用Laravel框架的话, 将nginx目录指向wwwpublic即可

本文为作者原创,手码不易,允许转载,转载后请以链接形式说明文章出处。

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2天前
|
Kubernetes 持续交付 Docker
构建高效微服务架构:Docker与Kubernetes的完美搭档
【5月更文挑战第17天】在当今云计算和微服务架构的大潮中,Docker容器化技术和Kubernetes容器编排系统成为了后端开发领域的热门技术栈。本文将探讨如何通过Docker和Kubernetes的结合使用来构建一个高效、可扩展且易于管理的微服务环境。我们将从基础概念出发,深入到实际操作层面,最后讨论这种组合对持续集成和持续部署(CI/CD)流程的影响,旨在为开发者和企业提供一种可靠的后端服务解决方案。
|
4天前
|
存储 前端开发 JavaScript
基于 GitHub Workflow和 Docker 构建 NextJS
基于 GitHub Workflow和 Docker 构建 NextJS
8 0
|
4天前
|
Prometheus 监控 Cloud Native
构建高效稳定的Docker容器监控体系
【5月更文挑战第14天】 在现代微服务架构中,Docker容器作为应用部署的基本单元,其运行状态的监控对于保障系统稳定性和性能至关重要。本文将探讨如何构建一个高效且稳定的Docker容器监控体系,涵盖监控工具的选择、关键指标的采集、数据可视化以及告警机制的设计。通过对Prometheus和Grafana的整合使用,实现对容器资源利用率、网络IO以及应用健康状态的全方位监控,确保系统的高可用性和故障快速响应。
|
4天前
|
Prometheus 监控 Cloud Native
构建高效稳定的Docker容器监控体系
【5月更文挑战第13天】在微服务架构和容器化部署日益普及的背景下,对Docker容器的监控变得尤为重要。本文将探讨一种构建高效稳定Docker容器监控体系的方法,通过集成Prometheus和cAdvisor工具,实现对容器资源使用情况、性能指标和运行状态的实时监控。同时,结合Grafana进行数据可视化,为运维人员提供直观的分析界面,以便及时发现和解决潜在问题,保障系统的高可用性和稳定性。
30 6
|
关系型数据库 MySQL 应用服务中间件
Docker 搭建 LNMP + Wordpress的大纲
Docker 搭建 LNMP + Wordpress的大纲
171 0
|
4天前
|
存储 安全 数据安全/隐私保护
【Docker 专栏】Docker 容器化应用的备份与恢复策略
【5月更文挑战第9天】本文探讨了Docker容器化应用的备份与恢复策略,强调了备份在数据保护、业务连续性和合规要求中的关键作用。内容涵盖备份的重要性、内容及方法,推荐了Docker自带工具和第三方工具如Portainer、Velero。制定了备份策略,包括频率、存储位置和保留期限,并详细阐述了恢复流程及注意事项。文章还提及案例分析和未来发展趋势,强调了随着技术发展,备份与恢复策略将持续演进,以应对数字化时代的挑战。
【Docker 专栏】Docker 容器化应用的备份与恢复策略
|
4天前
|
监控 Kubernetes Docker
【Docker 专栏】Docker 容器内应用的健康检查与自动恢复
【5月更文挑战第9天】本文探讨了Docker容器中应用的健康检查与自动恢复,强调其对应用稳定性和系统性能的重要性。健康检查包括进程、端口和应用特定检查,而自动恢复则涉及重启容器和重新部署。Docker原生及第三方工具(如Kubernetes)提供了相关功能。配置检查需考虑检查频率、应用特性和监控告警。案例分析展示了实际操作,未来发展趋势将趋向更智能和高效的检查恢复机制。
【Docker 专栏】Docker 容器内应用的健康检查与自动恢复
|
2天前
|
Java 虚拟化 Docker
Docker简介及用途,为什么要使用Docker?Docker容器和虚拟机的区别
Docker简介及用途,为什么要使用Docker?Docker容器和虚拟机的区别
|
2天前
|
存储 Linux Docker
CentOS7修改Docker容器和镜像默认存储位置
CentOS7修改Docker容器和镜像默认存储位置
|
2天前
|
Linux Docker 容器
更改docker容器中的时间而不影响宿主机
更改docker容器中的时间而不影响宿主机