从头到尾在CoreOS上构建你的第一个应用

云计算
本文作者以自己的Mac笔记本为例,介绍了如何在CoreOS上安装WordPress应用,没有过多的理论解释,全部是实战类教程,推荐想快速了解CoreOS的同学阅读。

我相信你一定听说过CoreOS,但是你是否真正在它上面部署过一个应用了?可能很多人都没有部署过。在CoreOS上构建一个应用是非常困难且令人沮丧的(译者注:frustrating,用了这个词,看来确实难)。因为文档比较散乱,并且你不得不在开始之前学习所有相关的技术,包括etcd、systemd、Docker。如果你和我一样比较懒惰,只是想试试CoreOS而不想小题大做,那么让我来帮你吧。接下来我们将会在CoreOS上创建一个简单的WordPress应用以及MySQL数据库。

如果你使用的是Mac,可以通过安装命令行工具来控制CoreOS

fleetctl 和 etcdctl 是原生的控制CoreOS集群的工具,安装步骤如下:

  1. $ brew install go etcdctl $ git clone https://github.com/coreos/fleet.git 
  2. $ cd fleet 
  3. $ ./build 
  4. $ mv bin/fleetctl /usr/local/bin/ 

安装一个本地的CoreOS集群,并运行

Vagrant是非常简单的。

  1. $ git clone https://github.com/CenturyLinkLabs/coreos-vagrant $ cd coreos-vagrant/cluster 
  2. $ vagrant up --provision 

现在你的笔记本上有一个由最小的3个CoreOS系统组成的集群。简单极了,现在让我们使用fleetctl来检查下。

  1. $ fleetctl list-machines MACHINE IP METADATA 
  2. 09fd0a88... 10.0.2.15 - 
  3. 77763947... 10.0.2.15 - 
  4. f31c383c... 10.0.2.15 - 

太棒了,跑起来了。

使用fleet在CoreOS集群上部署应用

现在你有一个CoreOS集群了。接下来fleetctl命令可以让你在CoreOS集群节点上部署应用,但要用fleet写服务文件。当然,不需要你自己来写。你可以用简单的YAML格式来生成服务(service)文件。

  1. $ sudo gem install bundler fig2coreos 
  2.  
  3. $ cat fig.yml 
  4. web: 
  5. image: ctlc/wordpress 
  6. ports: 
  7. 80:80 
  8. environment: 
  9. DB_USER: root 
  10. DB_PASSWORD: qa1N76pWAri9 
  11. links: 
  12. - db 
  13. db: 
  14. image: ctlc/mysql 
  15. ports: 
  16. 3306:3306 
  17. environment: 
  18. MYSQL_DATABASE: wordpress 
  19. MYSQL_ROOT_PASSWORD: qa1N76pWAri9 
  20.  
  21. $ fig2coreos myapp fig.yml coreos-files 
  22.  
  23. $ cd coreos-files 
  24.  
  25. $ ls 
  26. db-discovery.1.service 
  27. db.1.service 
  28. web-discovery.1.service 
  29. web.1.service  

fleetctl客户端工具使用etcd的键值存储来确定它要访问的服务器以及访问集群中有etcd服务端运行的服务器。下面是如何在CoreOS集群中部署你的应用。

  1. $ fleetctl start db.1.service 
  2.  
  3. $ fleetctl list-units 
  4. UNIT        LOAD    ACTIVE  SUB DESC        MACHINE 
  5. db.1.service    loaded  active  running Run db_1    9c008961.../10.0.2.15 
  6.  
  7. $ fleetctl start web.1.service 
  8.  
  9. $ fleetctl list-units 
  10. UNIT        LOAD    ACTIVE  SUB DESC        MACHINE 
  11. db.1.service    loaded  active  running Run db_1    9c008961.../10.0.2.15 
  12. web.1.service   loaded  active  running Run web_1   9c008961.../10.0.2.15  

现在你的程序运行起来了,但是服务还没有注册到etcd。幸运的是,fig2coreos已经为我们自动生成服务文件。

  1. $ fleetctl start db-discovery.1.service 
  2. $ fleetctl start web-discovery.1.service 
  3.  
  4. $ fleetctl list-units 
  5. UNIT            LOAD    ACTIVE  SUB DESC        MACHINE 
  6. db-discovery.1.service  loaded  active  running Announce db_1   9c008961.../10.0.2.15 
  7. db.1.service        loaded  active  running Run db_1    9c008961.../10.0.2.15 
  8. web-discovery.1.service loaded  active  running Announce web_1  9c008961.../10.0.2.15 
  9. web.1.service       loaded  active  running Run web_1   9c008961.../10.0.2.15 
  10.  
  11. $ etcdctl ls --recursive 
  12. /services 
  13. /services/web 
  14. /services/web/web_1 
  15. /services/db 
  16. /services/db/db_1 
  17.  
  18. $ etcdctl get /services/web/web_1 
  19. "host""core-03""port"80"version""52c7248a14" } 
  20.  
  21. $ etcdctl get /services/db/db_1 
  22. "host""core-03""port"3306"version""52c7248a14" } 

部署完成

就这样,搞定了。在Vagrant 1.5使用Vagrant Cloud账号,你可以访问你的WordPress应用。如下:

  1. $ cd ~/coreos-vagrant/cluster/ 
  2. find out which box is hosting your port 80 
  3. $ etcdctl get /services/web/web_1 
  4. "host""core-03""port"80"version""52c7248a14" } 
  5.  
  6. $ vagrant share core-03 --http 80 
  7. ==> core-03: Detecting network information for machine... 
  8. core-03: Local machine address: 192.168.65.2 
  9. core-03: Local HTTP port: 80 
  10. core-03: Local HTTPS port: disabled 
  11. ==> core-03: Checking authentication and authorization... 
  12. ==> core-03: Creating Vagrant Share session... 
  13. core-03: Share will be at: quick-iguana-4689 
  14. ==> core-03: Your Vagrant Share is running! Name: quick-iguana-4689 
  15. ==> core-03: URL: http://quick-iguana-4689.vagrantshare.com

结论

现在你可以用CoreOS做很多事情,但至少现在你已经做完基本的工作了,如果你打算在生产环境使用多主机的Coreos集群。需要你在系统中增加ambassador容器。事实上,你可以通过ambassador容器连接etc服务器,我们将会在下周发表另外一篇博文。

本文出自:http://dockerone.com/article/66

责任编辑:Ophira 来源: dockerone
相关推荐

2015-09-21 09:48:48

私有云云架构云管理

2013-05-02 11:21:36

iOS开发流程

2014-10-30 14:19:13

本文由简单的字符串匹配

2013-10-10 10:34:47

哈希算法

2013-01-14 09:44:58

JavaScriptJSJS框架

2019-08-21 08:54:46

垃圾回收Java算法

2021-11-08 17:03:13

IO模型

2018-08-22 17:32:45

2021-04-21 10:00:08

MySQL索引数据库

2018-01-31 15:45:07

前端Vue.js组件

2022-10-17 10:28:05

Web 组件代码

2021-04-07 13:38:27

Django项目视图

2010-07-30 14:58:06

Flex应用

2012-02-08 11:15:38

HibernateJava

2018-11-08 13:53:15

Flink程序环境

2023-10-09 14:32:48

2020-11-13 07:08:51

Spring Boot应用Spring

2016-03-09 09:42:15

App产品经理项目启动

2018-10-15 10:10:41

Linux内核补丁

2017-11-21 09:20:06

深度学习TensorFlow游戏AI
点赞
收藏

51CTO技术栈公众号