CoreOS实践(1)—CoreOS初体验
CoreOS主要包含以下一些东西:
(1)最小的OS:kernel+systemd
(2)使用Docker运行应用
(3)使用fleet管理集群
(4)使用etcd实现服务发现:一个分布式的K/V存储引擎存储配置数据
下载vagrant的coreos配置文件
$ git clone https://github.com/coreos/coreos-vagrant.git
$vagrant up
$ vagrant status
Current machine states:
core-01 running (virtualbox)
core-02 running (virtualbox)
core-03 running (virtualbox)
$ ssh-add ~/.vagrant.d/insecure_private_key
Identity added: /Users/yy/.vagrant.d/insecure_private_key (/Users/yy/.vagrant.d/insecure_private_key)
$ vagrant ssh core-01
Last login: Sun Sep 7 16:23:31 2014 from 10.0.2.2
CoreOS (beta)
core@core-01 ~ $ fleetctl list-machines
MACHINE IP METADATA
542a4130... 172.17.8.101 -
bcb90abf... 172.17.8.102 -
e6a8eaa9... 172.17.8.103 -
读写etcd
core@core-01 ~ $ etcdctl set first-etcd-key "Hello World"
Hello World
core@core-01 ~ $ etcdctl get first-etcd-key
Hello World
在core-02上可以读到first-etcd-key对应的值:
core@core-02 ~ $ etcdctl get first-etcd-key
Hello World
也可以直接提供的API读取相应的key:
core@core-02 ~ $ curl -L http://127.0.0.1:4001/v1/keys/first-etcd-key
{"action":"get","key":"/first-etcd-key","value":"Hello World","index":2264}
使用fleetctl管理服务
core@core-01 ~ $ cat hello.service
[Unit]
Description=My Service
After=docker.service
[Service]
TimeoutStartSec=0
ExecStartPre=-/usr/bin/docker kill hello
ExecStartPre=-/usr/bin/docker rm hello
ExecStartPre=/usr/bin/docker pull busybox
ExecStart=/usr/bin/docker run --name hello busybox /bin/sh -c "while true; do echo Hello World; sleep 1; done"
ExecStop=/usr/bin/docker stop hello
core@core-01 ~ $ fleetctl load hello.service
Job hello.service loaded on 542a4130.../172.17.8.101
core@core-01 ~ $ fleetctl start hello.service
Job hello.service launched on 542a4130.../172.17.8.101
查看服务状态
core@core-01 ~ $ fleetctl status hello.service
● hello.service - My Service
Loaded: loaded (/run/fleet/units/hello.service; linked-runtime)
Active: active (running) since Mon 2014-09-08 04:21:13 UTC; 1min 25s ago
Process: 1117 ExecStartPre=/usr/bin/docker pull busybox (code=exited, status=0/SUCCESS)
Process: 1108 ExecStartPre=/usr/bin/docker rm hello (code=exited, status=1/FAILURE)
Process: 1046 ExecStartPre=/usr/bin/docker kill hello (code=exited, status=1/FAILURE)
Main PID: 1185 (docker)
CGroup: /system.slice/hello.service
└─1185 /usr/bin/docker run --name hello busybox /bin/sh -c while true; do echo Hello World; sleep 1; done
Sep 08 04:22:28 core-01 docker[1185]: Hello World
Sep 08 04:22:29 core-01 docker[1185]: Hello World
Sep 08 04:22:30 core-01 docker[1185]: Hello World
Sep 08 04:22:31 core-01 docker[1185]: Hello World
Sep 08 04:22:32 core-01 docker[1185]: Hello World
Sep 08 04:22:33 core-01 docker[1185]: Hello World
Sep 08 04:22:34 core-01 docker[1185]: Hello World
Sep 08 04:22:35 core-01 docker[1185]: Hello World
Sep 08 04:22:36 core-01 docker[1185]: Hello World
Sep 08 04:22:37 core-01 docker[1185]: Hello World
core@core-01 ~ $ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
fa7084105f19 busybox:buildroot-2014.02 /bin/sh -c 'while tr 2 minutes ago Up 2 minutes hello
在另一个coreos查看服务状态
$ vagrant ssh core-02 -- -A
Last login: Mon Sep 8 04:35:40 2014 from 10.0.2.2
CoreOS (beta)
core@core-02 ~ $ fleetctl list-units
UNIT DSTATE TMACHINE STATE MACHINE ACTIVE
hello.service launched 542a4130.../172.17.8.101 launched 542a4130.../172.17.8.101 active
core@core-02 ~ $ fleetctl status hello.service
● hello.service - My Service
Loaded: loaded (/run/fleet/units/hello.service; linked-runtime)
Active: active (running) since Mon 2014-09-08 04:21:13 UTC; 15min ago
Process: 1117 ExecStartPre=/usr/bin/docker pull busybox (code=exited, status=0/SUCCESS)
Process: 1108 ExecStartPre=/usr/bin/docker rm hello (code=exited, status=1/FAILURE)
Process: 1046 ExecStartPre=/usr/bin/docker kill hello (code=exited, status=1/FAILURE)
Main PID: 1185 (docker)
CGroup: /system.slice/hello.service
└─1185 /usr/bin/docker run --name hello busybox /bin/sh -c while true; do echo Hello World; sleep 1; done
Sep 08 04:36:20 core-01 docker[1185]: Hello World
Sep 08 04:36:21 core-01 docker[1185]: Hello World
Sep 08 04:36:22 core-01 docker[1185]: Hello World
Sep 08 04:36:23 core-01 docker[1185]: Hello World
Sep 08 04:36:24 core-01 docker[1185]: Hello World
Sep 08 04:36:25 core-01 docker[1185]: Hello World
Sep 08 04:36:26 core-01 docker[1185]: Hello World
Sep 08 04:36:27 core-01 docker[1185]: Hello World
Sep 08 04:36:28 core-01 docker[1185]: Hello World
Sep 08 04:36:29 core-01 docker[1185]: Hello World
core@core-02 ~ $ fleetctl destroy hello.service
Destroyed hello.service
主要参考
[1] https://coreos.com/docs/quickstart/
作者:YY哥
出处:http://www.cnblogs.com/hustcat/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
CoreOS实践(1)—CoreOS初体验的更多相关文章
- [CoreOS 转载] CoreOS实践指南(一)
转载:http://www.csdn.net/article/2014-12-29/2823356 摘要:CoreOS是一个采用了高度精简的系统内核及外围定制的操作系统.ThoughtWorks的软件 ...
- [CoreOS 转载] CoreOS实践指南(七):Docker容器管理服务
转载:http://www.csdn.net/article/2015-02-11/2823925 摘要:当Docker还名不见经传的时候,CoreOS创始人Alex就预见了这个项目的价值,并将其做为 ...
- [CoreOS 转载] CoreOS实践指南(五):分布式数据存储Etcd(上)
转载:http://www.csdn.net/article/2015-01-22/2823659 摘要:在“漫步云端:CoreOS实践指南”系列的前几篇,分别介绍了如何架设CoreOS集群,系统服务 ...
- [CoreOS 转载] CoreOS实践指南(四):集群的指挥所Fleet
转载:http://www.csdn.net/article/2015-01-14/2823554/2 摘要:CoreOS是采用了高度精简的系统内核及外围定制的操作系统.ThoughtWorks的软件 ...
- [CoreOS 转载] CoreOS实践指南(三):系统服务管家Systemd
转载:http://www.csdn.net/article/2015-01-08/2823477 摘要:CoreOS是采用了高度精简的系统内核及外围定制的操作系统.ThoughtWorks的软件工程 ...
- [CoreOS 转载]CoreOS实践指南(二):架设CoreOS集群
转载:http://www.csdn.net/article/2015-01-04/2823399 摘要:CoreOS是一个采用了高度精简的系统内核及外围定制的操作系统.ThoughtWorks的软件 ...
- node.js 初体验
node.js 初体验 2011-10-31 22:56 by 聂微东, 174545 阅读, 118 评论, 收藏, 编辑 PS: ~ 此篇文章的进阶内容在为<Nodejs初阶之express ...
- Linux之初体验
预备作业03--我的Linux初体验 学习基于VirtualBox虚拟机安装Ubuntu图文教程在自己笔记本上安装Linux操作系统 一开始以为这个项目很简单,以往也在自己的笔记本上看教程安装过软件, ...
- 蚂蚁 RPC 框架 SOFA-RPC 初体验
前言 最近蚂蚁金服开源了分布式框架 SOFA,楼主写了一个 demo,体验了一下 SOFA 的功能,SOFA 完全兼容 SpringBoot(当然 Dubbo 也是可以兼容的). 项目地址:Alipa ...
随机推荐
- PHP查看当前端口号
<?php echo "当前页面服务器IP地址为:"; echo $_SERVER["SERVER_ADDR"]; echo "<br / ...
- 【Java】XML解析之DOM4J
DOM4J介绍 dom4j是一个简单的开源库,用于处理XML. XPath和XSLT,它基于Java平台,使用Java的集合框架,全面集成了DOM,SAX和JAXP,使用需要引用dom4j.jar包 ...
- Ubuntu下配置L2TP
发现PPTP已经不可用了,不知是不是又被墙了.只能尝试L2TP了. Ubuntu可视化配置界面network-manager默认是没有L2TP配置选项的,需要安装第三方插件软件: sudo apt-a ...
- [原] XAF ListView显示隐藏Footer菜单
using System; using DevExpress.ExpressApp; using DevExpress.ExpressApp.Win.Editors; using DevExpress ...
- ubuntn下 nginx+phpstorm 中配置xdebug调试
xdebug安装和配置说明,主要用于个人学习记录. 一.echo phpinfo(); 搜素xdebug,若未搜素到,则标识未安装或安装失败. 二.拷贝步骤1中输出的所有结果.访问http://xde ...
- C#下搭建文件格式转换服务器
文件格式转换,相信很多涉及到office文档在线观看的都会需要,因为浏览器还不能完全支持直接打开office文档,所以很多情况下我们都需要将这些文档转换成flash能够播放的格式,但是另一个问题又来了 ...
- Dynamic CRM 2013学习笔记(五)禁止修改、删除审批通过后的单据
审批通过后的单据,一般要对其进行控制,不能修改,不能添加,删除等,下面分别介绍下如何实现: 一. 禁止修改: 1. 主表控制,如果页面上审批状态为审批中或审批通过,就把整个页面都disable掉 1: ...
- 初识IStructuralEquatable接口
System.Collections.IStructuralEquatable 是 .NET Framework 4.5 新引入的一个接口,位于System.Runtime.dll程序集中. MSDN ...
- 作业七:团队项目——Alpha版本冲刺阶段-03
昨天进展:完善界面设计以及象棋图片的绘制 存在问题:人力不足,任务量大. 今天安排:象棋图片的绘制
- git查看一个文件的历史记录
git log --all -- '*'FILENAME'*' 支持模糊查询 主要用于查找历史上被删除的文件 可以做成git的一个快捷命令 find = "!f(){ git log --a ...