您的位置:首页 > 其它

Ambari服务依赖关系图生成脚本

2016-07-13 13:05 162 查看

1. 生成服务依赖关系

#!/usr/bin/python

import sys
import commands
import json

def genDependString(ip):
url="curl --user admin:admin -H 'X-Requested-By:admin' 'http://{0}:8080/api/v1/stacks/HDP/versions/2.2/services?fields=StackServices/required_services&minimal_response=true' 2> /dev/null".format(ip)
(status, output) = commands.getstatusoutput(url)
if not status:
items = json.loads(output).get("items")
content = ""
for item in items:
service_name = item.get("StackServices").get("service_name")
require_services = item.get("StackServices").get("required_services")
content += '''  "ROOT" -> "{0}"\n'''.format(service_name)
if not len(require_services):
content += '''  "{0}" -> "NULL"\n'''.format(service_name)
for require_service in require_services:
content += '''  "{0}" -> "{1}"\n'''.format(service_name, require_service)
content = "digraph G {\n" + content + "}"
return content

if __name__ == '__main__':
ip = sys.argv[1]
print genDependString(ip)

2. 在线生成依赖关系图

访问url:http://www.webgraphviz.com/
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: