在CoreOS上搭建一個(gè)WordPress程序操作實(shí)例
CoreOS是一個(gè)專門為大規(guī)模服務(wù)器部署定制的Linux精簡(jiǎn)系統(tǒng),它將操作系統(tǒng)和應(yīng)用程序完全分離,從而降低操作系統(tǒng)和應(yīng)用程序的耦合度,同時(shí)解決了現(xiàn)有Linux服務(wù)器在容器資源、權(quán)限管理方面出現(xiàn)的問(wèn)題。就目前來(lái)說(shuō),CoreOS會(huì)是未來(lái)操作系統(tǒng)的發(fā)展趨勢(shì)。
那你有沒(méi)有親自在CoreOS上部署一個(gè)應(yīng)用程序呢?相信大多數(shù)人都沒(méi)有過(guò)這樣的經(jīng)驗(yàn),在CoreOS上建立一個(gè)應(yīng)用程序可以說(shuō)是非常辛苦及沮喪的。因?yàn)樵陂_(kāi)始建立程序之前你首先必須了解所有不同的技術(shù)。
下面,我們將手把手地教你來(lái)創(chuàng)建一個(gè)簡(jiǎn)單的WordPress應(yīng)用程序,采用MySQL作為服務(wù)器,在CoreOS上運(yùn)行。
1. 安裝CLI來(lái)控制CoreOS
如果你的電腦是Mac,可以在本機(jī)安裝fleetctl和etcdctl來(lái)控制CoreOS集群:
$ brew install go etcdctl
$ git clone https://github.com/coreos/fleet.git
$ cd fleet
$ ./build
$ mv bin/fleetctl /usr/local/bin/
2. 安裝本地集群
使用部署虛擬化開(kāi)發(fā)環(huán)境Vagrant來(lái)安裝本地集群很容易:
$ git clone https://github.com/CenturyLinkLabs/coreos-vagrant
$ cd coreos-vagrant/cluster
$ vagrant up --provision
現(xiàn)在集群就安裝好了,簡(jiǎn)單吧!下面就讓我們來(lái)檢查一下本地fleetctl:
MACHINE IP METADATA
09fd0a88... 10.0.2.15 -
77763947... 10.0.2.15 -
f31c383c... 10.0.2.15 -
真棒,它起作用了!
3. 使用fleet部署一個(gè)應(yīng)用程序
fleetctl命令可把應(yīng)用程序部署到CoreOS集群的節(jié)點(diǎn)中,但要為fleet寫(xiě)服務(wù)文件真的是太糟糕了。幸運(yùn)的是,你不必自己編寫(xiě),你可以使用yaml format來(lái)生成服務(wù)文件:
$ sudo gem install bundler fig2coreos
$ cat fig.yml
web:
image: ctlc/wordpress
ports:
- 80:80
environment:
DB_USER: root
DB_PASSWORD: qa1N76pWAri9
links:
- db
db:
image: ctlc/mysql
ports:
- 3306:3306
environment:
MYSQL_DATABASE: wordpress
MYSQL_ROOT_PASSWORD: qa1N76pWAri9
$ fig2coreos myapp fig.yml coreos-files
$ cd coreos-files
$ ls
db-discovery.1.service
db.1.service
web-discovery.1.service
web.1.service
fleetctl客戶端工具使用的是etcd系統(tǒng)的Key/Value存儲(chǔ)形式,以分享配置和服務(wù)發(fā)現(xiàn)。下面教大家如何把程序部署到集群中:
$ fleetctl list-units
UNIT LOAD ACTIVE SUB DESC MACHINE
db.1.service loaded active running Run db_1 9c008961.../10.0.2.15
$ fleetctl start web.1.service
$ fleetctl list-units
UNIT LOAD ACTIVE SUB DESC MACHINE
db.1.service loaded active running Run db_1 9c008961.../10.0.2.15
web.1.service loaded active running Run web_1 9c008961.../10.0.2.15
現(xiàn)在程序就運(yùn)行了,但是還沒(méi)有注冊(cè)etcd的服務(wù),幸運(yùn)的是fig2coreos生成的服務(wù)發(fā)現(xiàn)文件可以幫助我們:
$ fleetctl start web-discovery.1.service
$ fleetctl list-units
UNIT LOAD ACTIVE SUB DESC MACHINE
db-discovery.1.service loaded active running Announce db_1 9c008961.../10.0.2.15
db.1.service loaded active running Run db_1 9c008961.../10.0.2.15
web-discovery.1.service loaded active running Announce web_1 9c008961.../10.0.2.15
web.1.service loaded active running Run web_1 9c008961.../10.0.2.15
$ etcdctl ls --recursive
/services
/services/web
/services/web/web_1
/services/db
/services/db/db_1
$ etcdctl get /services/web/web_1
{ "host": "core-03", "port": 80, "version": "52c7248a14" }
$ etcdctl get /services/db/db_1
{ "host": "core-03", "port": 3306, "version": "52c7248a14" }
這樣就完成了!如果你使用的是Vagrant 1.5及Vagrant Cloud,那么你就可以實(shí)現(xiàn) WordPress程序并看到它可以實(shí)行了:
$ cd ~/coreos-vagrant/cluster/
# find out which box is hosting your port 80
$ etcdctl get /services/web/web_1
{ "host": "core-03", "port": 80, "version": "52c7248a14" }
$ vagrant share core-03 --http 80
==> core-03: Detecting network information for machine...
core-03: Local machine address: 192.168.65.2
core-03: Local HTTP port: 80
core-03: Local HTTPS port: disabled
==> core-03: Checking authentication and authorization...
==> core-03: Creating Vagrant Share session...
core-03: Share will be at: quick-iguana-4689
==> core-03: Your Vagrant Share is running! Name: quick-iguana-4689
==> core-03: URL: http://quick-iguana-4689.vagrantshare.com
下面就是做好的效果圖:
![]() |
其實(shí)我們可以在CoreOS上能做很多事,今天這個(gè)只是基礎(chǔ),感興趣的你可以動(dòng)手試一試。
相關(guān)文章
Centos7 mysql數(shù)據(jù)庫(kù)安裝及配置實(shí)現(xiàn)教程
這篇文章主要介紹了Centos7 mysql數(shù)據(jù)庫(kù)安裝及配置實(shí)現(xiàn)教程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08
Linux 創(chuàng)建子進(jìn)程執(zhí)行任務(wù)的實(shí)現(xiàn)方法
下面小編就為大家分享一篇Linux 創(chuàng)建子進(jìn)程執(zhí)行任務(wù)的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,一起跟隨小編過(guò)來(lái)看看吧2018-01-01
Linux crontab定時(shí)任務(wù)執(zhí)行失敗處理方案
這篇文章主要介紹了Linux crontab定時(shí)任務(wù)執(zhí)行失敗處理方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06
詳解ubuntu雙系統(tǒng)啟動(dòng)時(shí)卡死解決辦法
這篇文章主要介紹了詳解ubuntu雙系統(tǒng)啟動(dòng)時(shí)卡死解決辦法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12
linux系統(tǒng)下一個(gè)冷門的RAID卡ioc0及其監(jiān)控mpt-status
這篇文章主要介紹了linux系統(tǒng)下一個(gè)冷門的RAID卡ioc0及其監(jiān)控mpt-status,需要的朋友可以參考下2016-05-05


