手把手教你在 CoreOS 上構建你的第一個應用
【編者的話】作者以自己的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
-
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的鍵值存儲來確定它要訪問的服務器以及訪問集群中有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" }$ 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</pre>
結論
現在你可以用CoreOS做很多事情,但至少現在你已經做完基本的工作了,如果你打算在生產環境使用多主機的Coreos集群。需要你在系統中增加ambassador容器。事實上,你可以通過ambassador容器連接etc服務器,我們將會在下周發表另外一篇博文。
原文: http://newlabs.wpengine.com/building-your-first-app-on-coreos/ 作者: Lucas Carlson
譯文: http://dockerone.com/article/66