作者以自己的Mac筆記本為例,介紹了如何在CoreOS上安裝WordPress應用,沒有過多的理論解釋,全部是實戰類教程,推薦想快速了解CoreOS的同學閱讀。
我相信你一定聽說過CoreOS,但是你是否真正在它上面部署過一個應用了?可能很多人都沒有部署過。在CoreOS上構建一個應用是非常困難且令人沮喪的(譯者注:frustrating,用了這個詞,看來確實難)。因為文檔比較散亂,並且你不得不在開始之前學習所有相關的技術,包括etcd、systemd、Docker。如果你和我一樣比較懶惰,只是想試試CoreOS而不想小題大做,那麼讓我來幫你吧。接下來我們將會在CoreOS上創建一個簡單的WordPress應用以及MySQL數據庫。
如果你使用的是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/
安裝一個本地的CoreOS集群,並運行
Vagrant是非常簡單的。
復制代碼代碼如下: $ git clone https://github.com/CenturyLinkLabs/coreos-vagrant
$ cd coreos-vagrant/cluster
$ vagrant up --provision
現在你的筆記本上有一個由最小的3個CoreOS系統組成的集群。簡單極了,現在讓我們使用fleetctl來檢查下。
復制代碼代碼如下:$ fleetctl list-machines MACHINE IP METADATA
09fd0a88... 10.0.2.15 -
77763947... 10.0.2.15 -
f31c383c... 10.0.2.15 -
太棒了,跑起來了。
使用fleet在CoreOS集群上部署應用
現在你有一個CoreOS集群了。接下來fleetctl命令可以讓你在CoreOS集群節點上部署應用,但要用fleet寫服務文件。當然,不需要你自己來寫。你可以用簡單的YAML格式來生成服務(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的鍵值存儲來確定它要訪問的服務器以及訪問集群中有etcd服務端運行的服務器。下面是如何在CoreOS集群中部署你的應用。
復制代碼代碼如下:$ 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
現在你的程序運行起來了,但是服務還沒有注冊到etcd。幸運的是,fig2coreos已經為我們自動生成服務文件。
復制代碼代碼如下:$ 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應用。如下圖:
復制代碼代碼如下:$ cd ~/coreos-vagrant/cluster/
找出哪個機器監聽著你的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