Docker+宝塔:零基础在Mac上快速搭建PHP开发环境

张开发
2026/4/7 11:49:08 15 分钟阅读

分享文章

Docker+宝塔:零基础在Mac上快速搭建PHP开发环境
1. 为什么选择Docker宝塔组合作为一个在Mac上折腾过各种开发环境的老手我强烈推荐Docker宝塔这个黄金组合。你可能听说过宝塔面板在Linux服务器上的强大功能但官方并没有提供Mac版本。这时候Docker就像个魔术师能让我们在Mac上完美运行宝塔环境。我最初尝试用MAMP、XAMPP这些传统方案时经常遇到版本冲突问题。比如项目A需要PHP7.4项目B需要PHP8.0来回切换能把人逼疯。而Docker的容器隔离特性让每个项目都能拥有独立的环境互不干扰。宝塔面板则提供了可视化管理界面特别适合刚入门的新手。实测下来这套方案有三大优势环境隔离每个项目独立运行不会出现装一个项目搞崩整个系统的情况一键部署docker-compose配置文件可以重复使用新电脑5分钟就能搭好环境资源友好不用装虚拟机MacBook的风扇终于可以安静下来了2. 准备工作安装必备软件2.1 安装Docker Desktop首先到Docker官网下载Mac版安装包。建议选择Apple Silicon芯片版本如果你是M1/M2 Mac这样性能会更好。安装过程就是常规的拖拽到Applications文件夹第一次启动时会要求授权记得点允许。安装完成后你会在顶部菜单栏看到小鲸鱼图标。我建议做两个设置偏好设置 → Resources → 内存调到4GB以上PHP开发很吃内存偏好设置 → Docker Engine → 加上国内镜像加速地址{ registry-mirrors: [ https://registry.docker-cn.com, https://docker.mirrors.ustc.edu.cn ] }2.2 准备项目目录打开终端创建一个专门存放宝塔配置的目录。我习惯放在用户目录下mkdir -p ~/Development/baota cd ~/Development/baota这个目录将成为我们的工作区所有配置文件都会放在这里。3. 配置Docker版宝塔面板3.1 编写docker-compose.yml在baota目录下创建docker-compose.yml文件这是我优化过的配置version: 3.8 services: baota: image: registry.cn-hangzhou.aliyuncs.com/btpanel/baota:latest container_name: baota_panel restart: unless-stopped ports: - 80:80 # Nginx - 443:443 # HTTPS - 888:888 # PHPMyAdmin - 8888:8888 # 宝塔面板 - 3306:3306 # MySQL volumes: - ./wwwroot:/www/wwwroot - ./mysql_data:/www/server/data - ./vhost:/www/server/nginx/conf/vhost environment: BT_USER: admin BT_PASS: your_secure_password privileged: true tty: true关键配置说明ports左边是Mac主机端口右边是容器内部端口volumes把容器内的重要目录映射到主机防止数据丢失environment设置默认账号密码记得修改成你自己的3.2 启动宝塔容器在终端执行以下命令docker compose up -d第一次运行会自动下载镜像速度取决于你的网络。我实测在200M宽带下大约需要5分钟。启动完成后用这个命令检查状态docker ps应该能看到baota_panel容器显示为Up状态。4. 初始化宝塔面板4.1 登录面板在浏览器打开http://localhost:8888你会看到宝塔的登录界面。如果用的是我上面的配置账号是admin密码是你设置的your_secure_password。第一次登录会提示安装套件。我建议选择LNMP组合Nginx 1.22MySQL 5.7兼容性最好PHP 7.4 8.0多版本共存4.2 常见问题排查如果遇到无法访问的情况可以查看容器日志docker logs baota_panel我遇到过两个典型问题端口冲突比如本地已经有服务占用了80端口。解决方案是修改docker-compose.yml中的左侧端口号比如改成8080:80权限问题Mac下某些目录需要额外权限。可以在volumes部分加上:z后缀如./wwwroot:/www/wwwroot:z5. 创建第一个PHP项目5.1 配置网站在宝塔面板点击网站→添加站点填写域名local.project.com记得后面配置hosts根目录/www/wwwroot/projectPHP版本根据项目需求选择然后到Mac的终端修改hosts文件sudo nano /etc/hosts添加一行127.0.0.1 local.project.com5.2 项目文件管理所有网站文件都应该放在baota目录下的wwwroot子目录。比如~/Development/baota/wwwroot/project/index.php这样既能用宝塔管理又能在Finder中直接编辑文件。我习惯用VS Code打开整个baota目录这样所有配置文件都在一个工作区code ~/Development/baota6. 高级技巧与优化6.1 多PHP版本管理宝塔支持同时安装多个PHP版本。在面板的软件商店搜索PHP安装你需要的版本。然后在网站设置里可以指定每个站点使用的PHP版本。比如老项目用PHP7.4新项目用PHP8.2。两个项目可以同时运行互不影响。6.2 数据库管理宝塔内置了PHPMyAdmin访问地址是http://localhost:888/phpmyadmin你也可以用本地的Navicat或TablePlus连接主机填127.0.0.1端口3306用户名密码是宝塔MySQL的账号。6.3 定期备份虽然Docker容器本身是临时的但我们通过volumes把数据持久化到了Mac上。我建议每周备份一次baota目录使用宝塔的计划任务功能自动备份数据库重要项目上传到Git仓库7. 常见问题解决方案7.1 性能优化如果感觉Docker占用资源太多可以尝试docker system prune这个命令会清理无用的镜像和容器。另外在Docker Desktop的设置里可以限制CPU和内存使用量。7.2 文件同步问题有时候在Finder中修改了文件但网站没有更新。这是因为Docker的文件监听机制有时会延迟。解决方法是在宝塔面板重启Nginxservice nginx restart7.3 容器更新当宝塔推出新版本时更新步骤很简单docker compose down docker compose pull docker compose up -d你的所有网站和数据库都会保持原样。

更多文章