摘要:此時,可以構(gòu)建映像,并將其部署為容器。從執(zhí)行以下操作以上命令將使用文件中定義的端口,構(gòu)建對應(yīng)鏡像和部署成為容器。
數(shù)人云之前分享了《如何用Docker實現(xiàn)PHP命令行程序的CI/CD》,詳細(xì)地介紹了整體過程中的思路以及以及注意事項,今天帶來的文章將闡述怎樣部署一個PHP應(yīng)用容器,并且與后端Couchbase Server容器進(jìn)行通信。
本篇文章講述如何創(chuàng)建一個自動提供的Couchbase節(jié)點和簡化PHP應(yīng)用程序讀取寫入Couchbase NoSQ數(shù)據(jù)庫。
首先定義代表兩個容器的項目結(jié)構(gòu):
root -- couchbase -- -- configure.sh -- -- Dockerfile -- php -- -- application -- -- -- index.php -- -- configuration -- -- -- php.ini -- -- Dockerfile -- docker-compose.yml
每個容器都有包含自身構(gòu)建鏡像步驟對應(yīng)的Dockerfile文件,docker-compose.yml將使用定義好的端口和環(huán)境變量信息構(gòu)建和部署容器。
每個容器都有包含自身構(gòu)建鏡像步驟對應(yīng)的Dockerfile文件,docker-compose.yml將使用定義好的端口和環(huán)境變量信息構(gòu)建和部署容器。
PHP應(yīng)用程序容器化本文是PHP容器化教程,首先構(gòu)建簡單的PHP應(yīng)用程序并對其進(jìn)行容器化,因為要自動化部署,所以在本地存儲php.ini文件,并在構(gòu)建過程中復(fù)制。
在此之前,為index.php文件中添加一些代碼:
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); ?>
所有打印數(shù)據(jù)都將是JSON格式,與Couchbase集群建立一個連接,并在該集群中打開一個特定的Bucket,稍后使用環(huán)境變量來定義集群名和Bucket,將在部署過程中進(jìn)行設(shè)置。
應(yīng)用程序連接Couchbase并且成功打開Bucket,嘗試通過Couchbase讀取文檔。若該文檔不存在,將會創(chuàng)建并讀取該文檔,所獲文檔會被打印出來。
這是一個簡單的應(yīng)用,現(xiàn)在可以專注于應(yīng)用程序的Docker方面。
打開Dockerfile文件,內(nèi)容如下:
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鏡像,如果曾經(jīng)使用過PHP和Couchbase,下面看起來會很熟悉,所有依賴關(guān)系都是直接從Couchbase官方SDK文檔中獲取,RUN命令表示依賴關(guān)系將在構(gòu)建時收集安裝,而非運行過程中。
依賴安裝完成后,把php.ini文件以及index.php文件復(fù)制到構(gòu)建鏡像的過程中去。首先從php.ini文件這一步:
最好是從官方的PHP GitHub倉庫下載php.ini文件,而非粘貼一冗長的配置文件。擴(kuò)展唯一要做的改變,根據(jù)Couchbase SDK文檔 找到擴(kuò)展部分,在php.ini文件中添加一行extension=couchbase.so。
此時,可以構(gòu)建PHP映像,并將其部署為容器。但我們多做一些:創(chuàng)建一個Compose文件。
打開docker-compose.yml文件內(nèi)容如下:
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的服務(wù),使用了一系列端口映射環(huán)境變量的。此處有一些重要的注意事項,COUCHBASE_HOST在PHP服務(wù)的設(shè)置,Key對應(yīng)的值必須與數(shù)據(jù)庫的服務(wù)名稱Couchbase相匹配。
使用Docker部署上述容器基礎(chǔ)工作完成,是時候開始部署兩個容器了,開始創(chuàng)建一系列有用的微服務(wù)。是時候開始部署兩個容器了,這樣就能創(chuàng)建一系列有用的微服務(wù)。
從Docker CLI執(zhí)行以下操作:
docker-compose run -d --service-ports --name couchbase couchbase docker-compose run -d --service-ports --name php php
以上命令將使用Compose文件中定義的端口,構(gòu)建對應(yīng)鏡像和部署成為容器。從Web瀏覽器,http:// localhost:8091 可以轉(zhuǎn)到Couchbase Server儀表板,http:// localhost:8080 可以進(jìn)入PHP應(yīng)用程序。
成功后,即可看到保存在數(shù)據(jù)庫中并顯示在屏幕上的信息。
結(jié)論以上是部署一個PHP應(yīng)用容器并且與后端的Couchbase Server容器進(jìn)行通信的過程,雖然選擇的應(yīng)用很簡單,但方法可以很容易地推廣到任意PHP應(yīng)用框架容器化和部署。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/26951.html
摘要:與分布式應(yīng)用捆綁包分布式應(yīng)用捆綁包,或者簡稱,是一種多服務(wù)可分發(fā)鏡像格式。而當(dāng)中新推出的分布式應(yīng)用捆綁包,或者簡稱,則屬于一種新的概念,其專門面向多套容器的遷移需求。利用創(chuàng)建一個分布式應(yīng)用捆綁包添加了一條新的命令。 在本文中數(shù)人云將帶大家了解如何利用Docker Compose創(chuàng)建一套分布式應(yīng)用捆綁包,并將其作為Docker Stack在Docker Swarm Mode中進(jìn)行部署。 ...
摘要:今天,我們將通過實踐,將一個網(wǎng)站運行在上,話不多說,課堂繼續(xù)開講視頻應(yīng)用的高可用部署,幫你輕松搞定視頻應(yīng)用的高可用部署,幫你輕松搞定我們提煉一下本期要點原環(huán)境改造環(huán)境是我們常見的網(wǎng)站運行環(huán)境。上一期視頻,沈老師帶大家認(rèn)識了UCloud容器實例Cube。今天,我們將通過實踐,將一個PHP網(wǎng)站運行在Cube上,話不多說,Cube課堂繼續(xù)開講!我們提煉一下本期要點:①原LNMP環(huán)境改造LNMP環(huán)境...
摘要:本文將演示如何使用創(chuàng)建集群。本次將使用,和企業(yè)版進(jìn)行測試。默認(rèn)情況下服務(wù)僅在集群內(nèi)可見,但我們會將該服務(wù)作為一個負(fù)載均衡器暴露出去。等待分鐘左右讓負(fù)載均衡器啟動。 編者按:本文由Couchbase 的VP Arun Gupta 編寫,展示了如何用Kubernetes 設(shè)置 Couchbase 集群。 Couchbase Server是一個開源的、分布式的文檔型NoSQL數(shù)據(jù)庫。它有低...
摘要:本期內(nèi)容是結(jié)合在的持續(xù)部署流程,實現(xiàn)從代碼至到部署應(yīng)用至中全自動的持續(xù)部署。編寫自己的命令如果有困難,可以加群申請源代碼示例也可以等近期即將發(fā)布的,這樣更香。千呼萬喚始出來,Cube完結(jié)篇來了!今天的內(nèi)容,是持續(xù)部署至Cube掌握前3期教程內(nèi)容搭配第四期使用,你就是全場最靚的仔!朋友們,來咯!上一期我們用云游戲的演示網(wǎng)站介紹了Java應(yīng)用如何做成鏡像部署至Cube。本期內(nèi)容是結(jié)合Cube A...
摘要:源碼解讀系列一好難都跑不起來怎么破了解一下唄閱讀框架源碼第一步搞定環(huán)境小伙伴剛接觸的時候會感覺壓力有點大更直觀的說法是難開發(fā)組是不贊成難這個說法的的代碼都是實現(xiàn)的而又是世界上最好的語言的代碼閱讀起來是很輕松的開發(fā)組會用源碼解讀系列博客深 date: 2018-8-01 14:22:17title: swoft| 源碼解讀系列一: 好難! swoft demo 都跑不起來怎么破? doc...
閱讀 1470·2019-08-30 15:55
閱讀 1172·2019-08-30 15:52
閱讀 1282·2019-08-29 13:53
閱讀 1465·2019-08-29 11:19
閱讀 2964·2019-08-26 13:29
閱讀 527·2019-08-26 11:33
閱讀 2587·2019-08-23 17:20
閱讀 1022·2019-08-23 14:14