從頭到尾在CoreOS上構(gòu)建你的第一個(gè)應(yīng)用
我相信你一定聽說過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而不想小題大做,那么讓我來幫你吧。接下來我們將會(huì)在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
- 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的鍵值存儲(chǔ)來確定它要訪問的服務(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)為我們自動(dò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賬號(hào),你可以訪問你的WordPress應(yīng)用。如下:
- $ 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
結(jié)論
現(xiàn)在你可以用CoreOS做很多事情,但至少現(xiàn)在你已經(jīng)做完基本的工作了,如果你打算在生產(chǎn)環(huán)境使用多主機(jī)的Coreos集群。需要你在系統(tǒng)中增加ambassador容器。事實(shí)上,你可以通過ambassador容器連接etc服務(wù)器,我們將會(huì)在下周發(fā)表另外一篇博文。