mysql docker化_如何开发一个 PHP + MySQL 的 Docker 化应用

目标:基于典型的 LAMP 技术栈,用 Docker 镜像的方式搭建一个 Linux + Apache + MySQL + PHP 的应用 。

本项目代码维护在

创建 PHP 应用容器

因所有官方镜像均位于境外服务器,为了确保所有示例能正常运行,DaoCloud 提供了一套境内镜像源,并与官方源保持同步。

首先,选择官方的 PHP 镜像作为项目的基础镜像。

FROMdaocloud.io/php:5.6-apache

接着,用官方 PHP 镜像内置命令docker-php-ext-install安装 PHP 的 MySQL 扩展依赖。

RUN docker-php-ext-install pdo_mysql

依赖包通过 docker-php-ext-install 安装,如果依赖包需要配置参数则通过 docker-php-ext-configure 命令。

安装 pdo_mysql PHP 扩展。

然后,将代码复制到目标目录。

COPY . /var/www/html/

因为基础镜像内已经声明了暴露端口和启动命令,此处可以省略。

至此,包含 PHP 应用的 Docker 容器已经准备好了。PHP 代码中访问数据库所需的参数,是通过读取环境变量的方式声明的。

$serverName = env("MYSQL_PORT_3306_TCP_ADDR", "localhost");

$databaseName = env("MYSQL_INSTANCE_NAME", "homestead");

$username = env("MYSQL_USERNAME", "homestead");

$password = env("MYSQL_PASSWORD", "secret");

/**

* 获取环境变量

* @param $key

* @param null $default

* @return null|string

*/

function env($key, $default = null)

{

$value = getenv($key);

if ($value === false) {

return $default;

}

return $value;

}

这样做是因为在 Docker 化应用开发的最佳实践中,通常将有状态的数据类服务放在另一个容器内运行,并通过容器特有的 link 机制将应用容器与数据容器动态的连接在一起。

绑定 MySQL 数据容器(本地)

首先,需要创建一个 MySQL 容器。

docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d daocloud.io/mysql:5.5

之后,通过 Docker 容器间的 link 机制,便可将 MySQL 的默认端口(3306)暴露给应用容器。

docker run --name some-app --link some-mysql:mysql -d app-that-uses-mysql

绑定 MySQL 数据服务(云端)

比起本地创建,在云端创建和绑定 MySQL 数据服务会更简单。

注册成为 DaoCloud 用户。

在 DaoCloud 「控制台」中选择「代码构建」。

创建新项目,选择代码源,开始构建镜像。

在「服务集成」创建 MySQL 服务实例。

将构建的应用镜像关联 MySQL 服务实例并部署在云端。

DaoCloud 使用图文介绍

了解如何用 DaoCloud 进行代码构建:参考

了解如何用 DaoCloud 进行持续集成:参考

了解如何用为应用准备一个数据库服务:参考

了解如何部署一个刚刚构建好的应用镜像:参考

php-apache-mysql-sample 应用截图

你可能感兴趣的:(mysql,docker化)