使用 Laradock 搭建基于 Docker 的 PHP 开发环境

简介
Laradock 是为 Docker 提供的完整 PHP 本地开发环境,和 Homestead 一样提供了一系列打包好(包括配置)的 Docker Image。Laradock 早期专注为 Laravel 打造 Docker 开发环境,因而最早在 Laravel 社区中出名,后来随着影响力的扩大,逐渐被 PHP 社区接纳和采用,目前支持的 PHP 项目除了 Laravel 之外,还有 Symfony、CodeIgniter、WordPress、Drupal 等等。
Docker 扫盲
在学习和使用 Laradock 之前,我们有必要先学习和了解 Docker,而在使用 Docker 之前,又有必要搞清楚下面两个问题:
Docker 是什么
Docker 基于 Go 语言开发,是一个基于 LXC 技术之上构建的 Container 容器引擎。容器是一种以固定格式打包软件的方式,以便让软件可以在共享的操作系统中运行,不同于虚拟机,容器并不需要捆绑这个操作系统,只需要软件正常工作所必须的库和设置即可,这使得容器更加高效、轻量级、可以自成系统并且不管部署在什么地方都可以保证运行结果一致。
Docker提供了一种在安全、可重复的环境中自动部署软件的方式,它的出现拉开了基于云计算平台发布产品方式的变革序幕。开发者使用 Docker 可以解决当需要和同事共享代码时"只能在我的机器工作"的问题;操作者使用 Docker 可以在关联容器中边运行边管理以便获取更好的计算密度;企业使用 Docker 可以用来构建敏捷的软件分发管道以便可以更快处理新特性。
为什么要使用 Docker
Docker 的出现就是为了解决以下问题:
- 环境管理复杂: 从各种 OS 到各种中间件再到各种 App,一款产品能够成功发布,作为开发者需要关心的东西太多,且难于管理,这个问题在软件行业中普遍存在并需要直接面对。Docker 可以简化部署多种应用实例工作,比如Web应用、后台应用、数据库应用、大数据应用比如 Hadoop 集群、消息队列等等都可以打包成一个 Image 部署。
- 云计算时代的到来: AWS 的成功, 引导开发者将应用转移到云上, 解决了硬件管理的问题,然而软件配置和管理相关的问题依然存在。Docker 的出现正好能帮助软件开发者开阔思路,尝试新的软件管理方法来解决这个问题。
- 虚拟化手段的变化: 云时代采用标配硬件来降低成本,采用虚拟化手段来满足用户按需分配的资源需求以及保证可用性和隔离性。然而无论是 KVM 还是 Xen,在 Docker 看来都在浪费资源,因为用户需要的是高效运行环境而非 OS, GuestOS 既浪费资源又难于管理, 更加轻量级的 LXC 更加灵活和快速。
- LXC的便携性: LXC在 Linux 2.6 的 Kernel 里就已经存在了,但是其设计之初并非为云计算考虑的,缺少标准化的描述手段和容器的可便携性,决定其构建出的环境难于分发和标准化管理。Docker就在这个问题上做出了实质性的创新方法。
Docker 通常用于如下场景:
- Web 应用的自动化打包和发布;
- 自动化测试和持续集成、发布;
- 在服务型环境中部署和调整数据库或其他的后台应用;
- 从头编译或者扩展现有的 OpenShift 或 Cloud Foundry 平台来搭建自己的 PaaS 环境。
本教程不将那么多高大上的东西了,我们专注于通过 Docker 构建一个可移植的本地开发环境。
Docker 安装使用
首先我们需要在系统安装 Docker 的免费社区版,官方提供 Windows、Mac 及 Linux 等版本下载:下载地址。下载操作系统对应版本安装后,双击打开 Docker 应用,即可在命令行检查是否安装成功:
Mac

注:Windows 下使用 Docker 需启用 Hyper-V 组件。
快速上手
深入了解 Laradock 之前让我们先见识下如何在 Laradock 中快速安装 Nginx、PHP、Composer、MySQL、Redis 和 Beanstalkd 吧,有了这些开发 Laravel 必备的工具组件也就差不离了。
1、首先将 Laradock 项目代码克隆到本地:
git clone https://github.com/Laradock/laradock.git
2、进入 laradock
目录将 env-example
重命名为 .env
:
cp env-example .env
3、运行容器:
docker-compose up -d nginx mysql redis beanstalkd
如果指定端口已经被占用,运行上述命令会报错,关闭相应的服务再重新运行上述命令即可。
4、打开项目的 .env
文件并添加如下配置:
DB_HOST=mysql
REDIS_HOST=redis
QUEUE_HOST=beanstalkd
5、要测试配置访问域名指向 Docker 环境目录,我们先在 laradock
父级目录下创建一个与 laradock
同级的 wwwroot
目录,然后在 wwwroot
目录下运行 laravel new blog
命令创建一个新的 Laravel 应用,相应的层级目录关系如下所示:

然后我们需要到 laradock
下编辑 .env
中的 APPLICATION
配置项:
APPLICATION=../wwwroot/
注:最新版本的laradock
对应的配置项是APP_CODE_PATH_HOST
。
这样就相当于为 wwwroot
与 Docker 的 /var/www
目录建立了软链接,然后我们修改 laradock/nginx/sites/default.conf
中的映射关系:

接下来,需要重启 Docker 的 Nginx:
docker-compose up -d nginx
这样,我们就可以在浏览器中通过 http://localhost
访问这个应用了,当然,如果需要的话,也可以将 localhost
换成任意你想要的域名,不过还需要配置 /etc/hosts
和 laradock/nginx/sites/default.conf
里面的域名信息:

以上就是 Laradock 的简单上手指南。这里我们设置的场景是新建一个应用,如果是多个应用的话要怎么办呢?也很简单,就是在上述 wwwroot
目录下创建多个应用目录,然后在 laradock/nginx/sites
下对应创建多个配置文件,最后不要忘记在系统 /etc/hosts
中配置相关域名绑定 IP 即可。
注:更多使用细节请参考官方文档:http://laradock.io/documentation/
功能特性
最后,我们来捋一下 Laradock 的功能特性:
- 可轻松在不同版本 PHP 之间切换: 7.1、7.0、5.6 等
- 自由选择数据库: MySQL、Postgres、MariaDB 等
- 运行自己的软件: Memcached、HHVM、Beanstalkd 等
- 每个软件都运行在隔离的容器中: PHP-FPM、NGINX、PHP-CLI 等
- 轻松自定义容器,只需编辑 Dockerfile 文件即可
- 所有的镜像都扩展自官方的镜像
- 预配置的 NGINX
- 可以在每个项目中使用 Laradock, 也可以让所有项目共享一个 Laradock
- 使用环境变量在容器中轻松安装/卸载软件
- 干净、结构良好的 Dockerfile
- 最新版本的
docker-compose
文件 - 一切均可见、可编辑
- 快速构建镜像
除此之外,目前为止,Laradock 支持的软件包括但不限于:
- 数据库引擎: MySQL - MariaDB - Percona - MongoDB - Neo4j - RethinkDB - MSSQL - PostgreSQL - Postgres-PostGIS.
- 数据库管理工具: PhpMyAdmin - Adminer - PgAdmin
- 缓存工具: Redis - Memcached - Aerospike
- Web 服务器: NGINX - Apache2 - Caddy
- PHP 编译器: PHP FPM - HHVM
- 消息队列: Beanstalkd - RabbitMQ - PHP Worker
- 队列管理器: Beanstalkd Console - RabbitMQ Console
- 大国重器: HAProxy - Certbot - Blackfire - Selenium - Jenkins - ElasticSearch - Kibana - Mailhog - Minio - Varnish - Swoole - Laravel Echo 等
- Laradock 还引入了 Workspace 镜像作为开发环境,里面包含了丰富且实用的工具集:PHP CLI - Composer - Git - Linuxbrew - Node - V8JS - Gulp - SQLite - xDebug - Envoy - Deployer - Vim - Yarn - SOAP - Drush 等
Laradock 还是 Homestead
最后,我们绕不开的话题是作为开发环境,选择 Docker(Laradock) 还是 Vagrant(Homestead),Mac 系统上官方还提供了 Valet,尝鲜的话、做Demo或者快速学习为目的当然 Valet 还是不二之选,因为它最小巧、最轻量级,上手最快,天下武功,唯快不破。
至于 Laradock 还是 Homestead,就是见仁见智了,就功能而言,两者不分伯仲。Laradock 相对 Homestead 而言更加轻量级,因为正如前面所言,Homestead 是 VM 级别的虚拟化解决方案,依赖一个完整的操作系统,虽然功能很全,但是很重,而 Laradock 是容器,只依赖那些它必需的软件,更加灵活,更加高效。
还有一点需要提及的是 Docker 可以用于本地也可以用于线上,所谓 same environment everywhere
,而 Vagrant 部署的 Homestead 开发环境只能用于本地,这一点也可以作为重要考量因素。
181 Comments
.env
这个里面配置开启 npm 然后重新build workspace好的,谢谢,我试试
npm类似问题 https://github.com/laradock/laradock/issues/2459
在hosts文件加入
199.232.28.133 raw.githubusercontent.com
可以解决学院君,我在nginx中给一个项目配置了8080端口,但是无法访问,是什么原因呢
如果是 Windows下,用 DockerTool box 管理 docker 容器的话(会用到 VirtualBox)
在编辑 laradock
.env
APP_CODE_PATH_HOST 的时候,不能以主机的目录去映射,而是应该填写 VirtualBox 共享文件夹中固定分配的目录,比如我分配过 www =》 D:\www\,这个时候我编辑 APP_CODE_PATH_HOST=/www (对应了前者,我的 laradock 目录实际在 F 盘)
重启nginx,
docker-compose up -d nginx
,会发现 Kitematic 界面上 nginx 容器 Volumes 设置项里,/var/www 的 LOCAL FLODER 显示 no folder
这个时候别慌,进入nginx容器看看,就可以看到 /var/www/ 下面的内容跟 D:\www\ 是一样的了
嗯 感谢分享 我没有用 Toolbox 直接升级到 Windows 10 专业版 就可以使用官方的 Docker Desktop for Windows 了
(windows7)虽然我已经用docker compose构建完所有的镜像,启动端口也不冲突,项目目录也映射好了,但是最后访问网址还是拒绝访问,查了一些资料,大概是因为DockerTool box读取不到laradock的 nginx配置,其实我也把laradock的目录挂进去了(跟项目目录同理),但没成功。
由于网络和时间的问题,我还是用回 Mac 做微服务的测试,有时间再回去调试看看
#########################更新#################################
正如 175 楼提到
.env
下已经配置 APP_CODE_PATH_HOST=/www,拒绝访问的原因确实是没有读取到 nginx 的配置,因为我进入 nginx 容器的 /etc/nginx 看不到东西,其实问题没那么复杂,因为.env
下的 nginx 相关路径我没有调整,如下:此时,my_laradock 我是直接放在 code 的同级目录,也就是 D:\www\,这样 VM 上也就只需要映射一个 www
如果用到 laradock 其他组件容器,解决数据卷的问题就举一反三吧
传了一份代码,仅供参考 my_laradock
学院君好,有三个项目ABC,A是php5.6,B是php7.0,C是php7.1,有木有办法同时跑多个workspace容器以支持这三个项目?
要同时跑3个只能额外去 docker-compose.yml 中配置另外的服务实例了,因为不光是 workspace,还有关联的 php-fpm 版本,以及 nginx 中反向代理配置的 php-fpm socket
启动laradock 报错 ERROR: .UnicodeDecodeError: 'utf-8' codec can't decode byte 0x87 in position 0: invalid start byte