作者以自己的Mac筆記本為例,介紹了如何在CoreOS上安裝WordPress應(yīng)用,沒有過多的理論解釋,全部是實(shí)戰(zhàn)類教程,推薦想快速了解CoreOS的同學(xué)閱讀。
我相信你一定聽說過CoreOS,但是你是否真正在它上面部署過一個(gè)應(yīng)用了?可能很多人都沒有部署過。在CoreOS上構(gòu)建一個(gè)應(yīng)用是非常困難且令人沮喪的(譯者注:frustrating,用了這個(gè)詞,看來確實(shí)難)。因?yàn)槲臋n比較散亂,并且你不得不在開始之前學(xué)習(xí)所有相關(guān)的技術(shù),包括etcd、systemd、Docker。如果你和我一樣比較懶惰,只是想試試CoreOS而不想小題大做,那么讓我來幫你吧。接下來我們將會在CoreOS上創(chuàng)建一個(gè)簡單的WordPress應(yīng)用以及MySQL數(shù)據(jù)庫。
如果你使用的是Mac,可以通過安裝命令行工具來控制CoreOS
fleetctl 和 etcdctl 是原生的控制CoreOS集群的工具,安裝步驟如下:
$ brew install go etcdctl
$ git clone https://github.com/coreos/fleet.git
$ cd fleet
$ ./build
$ mv bin/fleetctl /usr/local/bin/
安裝一個(gè)本地的CoreOS集群,并運(yùn)行
Vagrant是非常簡單的。
$ git clone https://github.com/CenturyLinkLabs/coreos-vagrant
$ cd coreos-vagrant/cluster
$ vagrant up --provision
現(xiàn)在你的筆記本上有一個(gè)由最小的3個(gè)CoreOS系統(tǒng)組成的集群。簡單極了,現(xiàn)在讓我們使用fleetctl來檢查下。
$ fleetctl list-machines MACHINE IP METADATA
09fd0a88... 10.0.2.15 -
77763947... 10.0.2.15 -
f31c383c... 10.0.2.15 -
太棒了,跑起來了。
使用fleet在CoreOS集群上部署應(yīng)用
現(xiàn)在你有一個(gè)CoreOS集群了。接下來fleetctl命令可以讓你在CoreOS集群節(jié)點(diǎn)上部署應(yīng)用,但要用fleet寫服務(wù)文件。當(dāng)然,不需要你自己來寫。你可以用簡單的YAML格式來生成服務(wù)(service)文件。
$ sudo gem install bundler fig2coreos
$ cat fig.yml/p>
p>-/p>
p> 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/p>
p>-/p>
p> $ 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的鍵值存儲來確定它要訪問的服務(wù)器以及訪問集群中有etcd服務(wù)端運(yùn)行的服務(wù)器。下面是如何在CoreOS集群中部署你的應(yīng)用。
$ fleetctl start db.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
$ 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)行起來了,但是服務(wù)還沒有注冊到etcd。幸運(yùn)的是,fig2coreos已經(jīng)為我們自動生成服務(wù)文件。
$ fleetctl start db-discovery.1.service
$ 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賬號,你可以訪問你的WordPress應(yīng)用。如下圖:
$ cd ~/coreos-vagrant/cluster/
找出哪個(gè)機(jī)器監(jiān)聽著你的80端口:
$ etcdctl get /services/web/web_1
{ "host": "core-03", "port": 80, "version": "52c7248a14" }/p>
p>$ 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