轻松搞定|将PHP和Couchbase应用部署为Docker


数人云之前分享了《如何用Docker实现PHP命令行程序的CI/CD》,详细地介绍了整体过程中的思路以及以及注意事项,今天带来的文章将阐述怎样部署一个PHP应用容器,并且与后端Couchbase Server容器进行通信。

本篇文章讲述如何创建一个自动提供的Couchbase节点和简化PHP应用程序读取写入Couchbase NoSQ数据库。

首先定义代表两个容器的项目结构:

root
-- couchbase
-- -- configure.sh
-- -- Dockerfile
-- php
-- -- application
-- -- -- index.php
-- -- configuration
-- -- -- php.ini
-- -- Dockerfile
-- docker-compose.yml

每个容器都有包含自身构建镜像步骤对应的Dockerfile文件,docker-compose.yml将使用定义好的端口和环境变量信息构建和部署容器。

每个容器都有包含自身构建镜像步骤对应的Dockerfile文件,docker-compose.yml将使用定义好的端口和环境变量信息构建和部署容器。

PHP应用程序容器化

本文是PHP容器化教程,首先构建简单的PHP应用程序并对其进行容器化,因为要自动化部署,所以在本地存储php.ini文件,并在构建过程中复制。

在此之前,为index.php文件中添加一些代码:

<?php
header("Content-Type: application/json");
$cluster = new CouchbaseCluster("couchbase://" . getenv("COUCHBASE_HOST"));
$bucket = $cluster->openBucket(getenv("COUCHBASE_BUCKET_NAME"), getenv("COUCHBASE_BUCKET_PASSWORD"));
try {
$result = $bucket->get("nraboy");
} catch (CouchbaseException $e) {
$bucket->insert("nraboy", array(
"name" => "Nic Raboy",
"social_media" => array(
"twitter" => "https://www.twitter.com/nraboy",
"website" => "https://www.thepolyglotdeveloper.com"
)
));
$result = $bucket->get("nraboy");
}
echo json_encode($result->value);
?>


所有打印数据都将是JSON格式,与Couchbase集群建立一个连接,并在该集群中打开一个特定的Bucket,稍后使用环境变量来定义集群名和Bucket,将在部署过程中进行设置。

应用程序连接Couchbase并且成功打开Bucket,尝试通过Couchbase读取文档。若该文档不存在,将会创建并读取该文档,所获文档会被打印出来。

这是一个简单的应用,现在可以专注于应用程序的Docker方面。

打开Dockerfile文件,内容如下:

FROM php:5.6.30-apache
RUN apt-get update
RUN apt-get install -y wget lsb-release
RUN wget http://packages.couchbase.com/releases/couchbase-release/couchbase-release-1.0-2-amd64.deb
RUN dpkg -i couchbase-release-1.0-2-amd64.deb
RUN rm couchbase-release-1.0-2-amd64.deb
RUN apt-get update
RUN apt-get install -y libcouchbase-dev build-essential php5-dev zlib1g-dev
RUN pecl install pcs-1.3.3
RUN pecl install couchbase
WORKDIR /var/www/html
COPY ./configuration/php.ini /usr/local/etc/php/
COPY ./application/ /var/www/html/
RUN chown www-data:www-data . -R

将使用Apache镜像,如果曾经使用过PHP和Couchbase,下面看起来会很熟悉,所有依赖关系都是直接从Couchbase官方SDK文档中获取,RUN命令表示依赖关系将在构建时收集安装,而非运行过程中。

依赖安装完成后,把php.ini文件以及index.php文件复制到构建镜像的过程中去。首先从php.ini文件这一步:

最好是从官方的PHP GitHub仓库下载php.ini文件,而非粘贴一冗长的配置文件。扩展唯一要做的改变,根据Couchbase SDK文档 找到扩展部分,在php.ini文件中添加一行extension=couchbase.so。

此时,可以构建PHP映像,并将其部署为容器。但我们多做一些:创建一个Compose文件。

打开docker-compose.yml文件内容如下:

version: '2'
services:
couchbase:
build: ./couchbase
ports:
- 8091:8091
- 8092:8092
- 8093:8093
environment:
- COUCHBASE_ADMINISTRATOR_USERNAME=Administrator
- COUCHBASE_ADMINISTRATOR_PASSWORD=password
- COUCHBASE_BUCKET=default
- COUCHBASE_BUCKET_PASSWORD=
php:
build: ./php
ports:
- 8080:80
environment:
- COUCHBASE_HOST=couchbase
- COUCHBASE_BUCKET_NAME=default
- COUCHBASE_BUCKET_PASSWORD=
restart: always


这里包括了另外一个名为Couchbase的服务,使用了一系列端口映射环境变量的。此处有一些重要的注意事项,COUCHBASE_HOST在PHP服务的设置,Key对应的值必须与数据库的服务名称Couchbase相匹配。

使用Docker部署上述容器

基础工作完成,是时候开始部署两个容器了,开始创建一系列有用的微服务。是时候开始部署两个容器了,这样就能创建一系列有用的微服务。

从Docker CLI执行以下操作:

docker-compose run -d --service-ports --name couchbase couchbase
docker-compose run -d --service-ports --name php php


以上命令将使用Compose文件中定义的端口,构建对应镜像和部署成为容器。从Web浏览器,ht****tp:// localhost:8091 可以转到Couchbase Server仪表板,http:// localhost:8080 可以进入PHP应用程序。

成功后,即可看到保存在数据库中并显示在屏幕上的信息。

结论

以上是部署一个PHP应用容器并且与后端的Couchbase Server容器进行通信的过程,虽然选择的应用很简单,但方法可以很容易地推广到任意PHP应用框架容器化和部署。

0 个评论

要回复文章请先登录注册