Docker-LAMP是一套基于Phusion基础镜像的Docker镜像,包含Apache、MySQL和PHP组成的LAMP栈,支持Ubuntu 14.04、16.04和18.04版本,提供一站式LAMP开发环境,适用于各类PHP应用开发与部署,具备多版本灵活性和简便的使用流程。
收藏数: 362
下载次数: 4954504
状态: active
发布者: mattrayner
类型: 镜像
mattrayner/lampDocker-LAMP是一组Docker镜像,包含Phusion基础镜像(14.04、16.04和18.04版本)以及LAMP栈(Apache、MySQL和PHP),打包为便捷的一站式解决方案。
通过latest-1804和latest-1604标签提供Ubuntu 18.04和16.04镜像,Docker-LAMP具备足够的灵活性,可用于所有LAMP项目。
.bash_profile别名示例
docker-compose -f docker-compose.test.yml -p ci build;docker-compose -f docker-compose.test.yml -p ci up -d;docker logs -f ci_sut_1;echo "Exited with status code: $(docker wait ci_sut_1)"作为开发人员,日常工作中需要构建LAMP应用。在寻找满足需求的镜像时,发现现有选项缺乏更新的软件包、简洁的接口、完善的文档和活跃的支持。更复杂的是,需要同时支持14.04和16.04两个版本的镜像,而维护两套独立工作流并不合理,因此Docker-LAMP应运而生。
Docker-LAMP设计为单一接口,不干扰开发流程,支持14.04和16.04版本,兼容PHP 5和PHP 7。用户可在4个镜像间无缝切换,无需改变Docker使用方式。
注意: PHP 5.6已停止支持,因此PHP 5镜像
mattrayner/lamp:latest-1404-php5和mattrayner/lamp:latest-1604-php5将不再更新。尽管这些镜像仍会保留在Docker Hub上,但强烈建议将应用升级至PHP 7。
注意: 该镜像的14.04变体不再积极支持更新。
Docker镜像主要有4个“版本”。下表显示了可用的不同标签,以及随附的PHP、MySQL和Apache版本。
| 组件 | latest-1404 | latest-1604 | latest-1804 |
|---|---|---|---|
| Apache | 2.4.7 | 2.4.18 | 2.4.29 |
| MySQL | 5.5.62 | 5.7.26 | 5.7.26 |
| PHP | 7.3.3 | 7.3.6 | 7.3.6 |
| phpMyAdmin | 4.8.5 | 4.9.0.1 | 4.9.0.1 |
这是最快捷的方式:
bash# 启动基于18.04的镜像 docker run -p "80:80" -v ${PWD}/app:/app mattrayner/lamp:latest-1804 # 启动基于16.04的镜像 docker run -p "80:80" -v ${PWD}/app:/app mattrayner/lamp:latest-1604 # 启动基于14.04的镜像 docker run -p "80:80" -v ${PWD}/app:/app mattrayner/lamp:latest-1404
dockerFROM mattrayner/lamp:latest-1804 # 自定义命令 CMD ["/run.sh"]
默认情况下,镜像包含一个无密码的MySQL root账户。该账户仅本地可用(即应用内部),无法从Docker镜像外部或通过phpMyAdmin访问。
首次运行镜像时,会显示admin用户的密码信息。此用户可本地和外部使用,可通过连接MySQL端口(默认3306)使用MySQL Workbench或Sequel Pro等工具,或通过phpMyAdmin访问。
如需后续查看此登录信息,可运行docker logs CONTAINER_ID,密码信息会显示在日志顶部。
应用如需数据库,有两种方式:
通过PHPMyAdmin
Docker-LAMP预装phpMyAdmin,可通过[***]访问。
注意: 不能使用root用户登录PHPMyAdmin。建议使用本节介绍的admin用户登录。
通过命令行
首先,使用docker ps获取运行中容器的ID,然后替换以下命令中的CONTAINER_ID和DATABASE_NAME:
bashdocker exec CONTAINER_ID mysql -uroot -e "create database DATABASE_NAME"
向LAMP镜像添加自定义内容的“最简单”方式是使用Docker卷,可将本地特定文件夹与Docker容器中的文件夹“同步”。
以下示例假设项目结构如下,且命令从“项目根目录”运行:
/ (项目根目录) /app/ (PHP文件存放目录) /mysql/ (Docker将创建此目录存储MySQL数据)
简单来说,项目应包含一个名为app的文件夹,其中包含所有应用代码。
以下命令将交互式运行mattrayner/lamp:latest镜像,将主机的80端口映射到容器的80端口,并创建卷将项目中的app/目录链接到容器的/app目录(Apache期望PHP文件存放的位置):
bashdocker run -i -t -p "80:80" -v ${PWD}/app:/app mattrayner/lamp:latest
以下命令运行mattrayner/lamp:latest镜像,在项目中创建mysql/文件夹,链接到容器中存储MySQL文件的/var/lib/mysql目录。停止/启动容器后,数据库更改将保留。
也可在-p 80:80后添加-p 3306:3306,将MySQL端口暴露到主机,以便外部应用(如SequelPro或MySQL Workbench)连接:
bashdocker run -i -t -p "80:80" -v ${PWD}/mysql:/var/lib/mysql mattrayner/lamp:latest
以下命令是“推荐”方案,可同时添加PHP应用和持久化数据库文件。可在.bash_profile中创建更高级的别名,实现ldi和launchdocker等简短命令。详见下节示例:
bashdocker run -i -t -p "80:80" -v ${PWD}/app:/app -v ${PWD}/mysql:/var/lib/mysql mattrayner/lamp:latest
.bash_profile别名示例以下示例可添加到~/.bash_profile文件,创建launchdocker和ldi别名。默认启动16.04镜像,如需14.04镜像,将mattrayner/lamp:latest替换为mattrayner/lamp:latest-1404:
bash# 启动mattrayner/lamp容器的辅助函数,支持参数覆盖 # # $1 - Apache端口(可选) # $2 - MySQL端口(可选 - 无值则不映射MySQL) function launchdockerwithparams { APACHE_PORT=80 MYSQL_PORT_COMMAND="" if ! [[ -z "$1" ]]; then APACHE_PORT=$1 fi if ! [[ -z "$2" ]]; then MYSQL_PORT_COMMAND="-p \"$2:3306\"" fi docker run -i -t -p "$APACHE_PORT:80" $MYSQL_PORT_COMMAND -v ${PWD}/app:/app -v ${PWD}/mysql:/var/lib/mysql mattrayner/lamp:latest } alias launchdocker='launchdockerwithparams $1 $2' alias ldi='launchdockerwithparams $1 $2'
使用示例
bash# 启动docker并映射80端口(Apache) ldi # 启动docker并映射8080端口(Apache) ldi 8080 # 启动docker并映射3000端口(Apache)和3306端口(MySQL) ldi 3000 3306
bash# 从Github克隆项目 git clone [***] cd docker-lamp # 构建18.04、16.04和14.04镜像 docker build -t=mattrayner/lamp:latest -f ./1804/Dockerfile-php7 . docker build -t=mattrayner/lamp:latest-1604 -f ./1604/Dockerfile-php7 . docker build -t=mattrayner/lamp:latest-1404 -f ./1404/Dockerfile-php7 . # 运行14.04镜像作为容器 docker run -p "3000:80" mattrayner/lamp:latest-1404 -d # 等待容器启动 sleep 5 # 访问容器内容 curl "[***] ip):3000/"
我们使用docker-compose设置、构建和运行测试环境,可将大量测试工作负载转移到Docker,确保在不受主机影响的一致环境中测试镜像。
可在docker-lamp目录中运行以下单行测试命令,测试所有更改,并验证Apache、MySQL、PHP和phpMyAdmin的安装版本是否符合预期:
bashdocker-compose -f docker-compose.test.yml -p ci build; docker-compose -f docker-compose.test.yml -p ci up -d; docker logs -f ci_sut_1; echo "Exited with status code: $(docker wait ci_sut_1)";
该命令的作用如下:
docker-compose -f docker-compose.test.yml -p ci build;首先,构建最新版本的docker-compose镜像。
docker-compose -f docker-compose.test.yml -p ci up -d;以守护进程模式启动容器(web1804、web1604、web1404和sut即“被测系统”)。
docker logs -f ci_sut_1;显示sut容器的所有日志输出(对调试非常有用)。
echo "Exited with status code: $(docker wait ci_sut_1)"报告sut容器的退出状态码。
该镜像最初基于dgraziotin/lamp,并进行了一些修改以兼容Concrete5 CMS。此外,将其设置为Ubuntu(基础镜像)镜像,以便该项目能尽可能多地帮助用户。
如需提交错误修复或功能,可创建拉取请求,经代码审查后合并。
Docker-LAMP采用Apache 2.0许可证授权。
以下是 mattrayner/lamp 相关的常用 Docker 镜像,适用于 不同场景 等不同场景:
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 版本下载页面。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
在 Linux 系统配置镜像服务
在 Docker Desktop 配置镜像
Docker Compose 项目配置
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
在宝塔面板一键配置镜像
Synology 群晖 NAS 配置
飞牛 fnOS 系统配置镜像
极空间 NAS 系统配置服务
爱快 iKuai 路由系统配置
绿联 NAS 系统配置镜像
QNAP 威联通 NAS 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
无需登录使用专属域名
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
免费版仅支持 Docker Hub 访问,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。
专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等;免费版仅支持 docker.io。
当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。
通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。
先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。
使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。
来自真实用户的反馈,见证轩辕镜像的优质服务