手把手教你在 CoreOS 上構建你的第一個應用

jopen 10年前發布 | 32K 次閱讀 CoreOS

【編者的話】作者以自己的Mac筆記本為例,介紹了如何在CoreOS上安裝WordPress應用,沒有過多的理論解釋,全部是實戰類教程,推薦想快速了解CoreOS的同學閱讀。

我相信你一定聽說過CoreOS,但是你是否真正在它上面部署過一個應用了?可能很多人都沒有部署過。在CoreOS上構建一個應用是非常困難且令人沮喪的(譯者注:frustrating,用了這個詞,看來確實難)。因為文檔比較散亂,并且你不得不在開始之前學習所有相關的技術,包括etcd、systemd、Docker。如果你和我一樣比較懶惰,只是想試試CoreOS而不想小題大做,那么讓我來幫你吧。接下來我們將會在CoreOS上創建一個簡單的WordPress應用以及MySQL數據庫。

手把手教你在 CoreOS 上構建你的第一個應用

如果你使用的是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做很多事情,但至少現在你已經做完基本的工作了,如果你打算在生產環境使用多主機的Coreos集群。需要你在系統中增加ambassador容器。事實上,你可以通過ambassador容器連接etc服務器,我們將會在下周發表另外一篇博文。

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!