• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

dinp-agent: DINP的Agent,部署在所有计算节点,收集各个节点运行状态和container列表 ...

原作者: [db:作者] 来自: 网络 收藏 邀请

开源软件名称:

dinp-agent

开源软件地址:

https://gitee.com/cnperl/dinp-agent

开源软件介绍:

Agent

这个模块部署在资源池的所有节点机器上,主要用于收集数据做汇报

收集的数据分成两部分

  • 机器剩余内存,调度模块拿到这个信息之后才能做调度
  • container情况,这是读取的Docker Daemon的接口,list所有container

对于container这块,目前只是拿到了本机的container列表,得知这些container的PublicPort,汇报给server,server把路由信息写入redis中的路由表

Q1:如何得知某个container是哪个app的呢?

刚开始的做法是把app的名称写入image的url中,container本身是可以知道使用了哪个image创建的,这样就知道了app与container的对应关系。但是这个规范比较强,太具侵入性

现在的做法是把app的名称写入ENV,在创建container的时候写入,之后再通过inspect拿到ENV["APP_NAME"]

注意:

  • agent会把本机的ip汇报给server,server用此构建路由表,那本机的ip是如何获取的呢?多个ip的情况怎么办?现在的做法是只拿内网ip,然后过滤掉回环ip,只要网卡名称使用eth打头的,过滤掉Docker创建的虚拟网卡,如果用户配置了localIp,就直接使用用户配置的localIp
  • agent是个前台进程,真正线上部署的时候可以使用god或者supervisor之类的管理

配置项说明

  • debug: true/false 只影响打印的log
  • localIp: 本机Ip地址,server会用这个ip地址和docker daemon通信
  • servers: server的地址
  • interval: 心跳周期,单位是秒
  • timeout: 连接server的超时时间,单位是毫秒
  • docker: Docker Daemon的接口地址,推荐Docker Daemon监听一个127.0.0.1的tcp接口,unix socket也可以,不过要注意文件权限了

install

mkdir -p $GOPATH/src/github.com/dinpcd $GOPATH/src/github.com/dinp; git clone https://github.com/dinp/agent.gitcd agentgo get ./...# check cfg.json, depend docker daemon and server./control start

鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap