当前位置: 移动技术网 > 科技>操作系统>Linux > 用Mac在CoreOS上搭建WordPress的教程

用Mac在CoreOS上搭建WordPress的教程

2018年07月23日  | 移动技术网科技  | 我要评论

陶唯倩,刘德华的资料,我爱我车

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

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

2015615153403015.png (342×264)

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集群,并运行

是非常简单的。

   

复制代码
代码如下:
$ 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 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

2015615153704806.png (1078×752)

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网