统计ES性能的python脚本

简介:

思路:通过http请求获取es集群中某一index的索引docs数目变化来进行ES性能统计

复制代码
import time
from datetime import datetime
import urllib2

def get_docs(data_type, today):
    # curl '192.168.3.153:9200/_cat/indices/metadata-dis-2017.05.16-*-93001?v'
    url = 'http://192.168.3.153:9200/_cat/indices/%s-dis-%s-*' % (data_type, today)
    out = urllib2.urlopen(urllib2.Request(url))
    data = out.read()
    docs_cnt = 0
    for line in data.split('\n'):
        if line:
            docs_cnt += int(line.split()[5])
    return docs_cnt


def main():
    today = datetime.now().strftime("%Y.%m.%d")
    init_data = {"event": 0, "metadata": 0}
    docs_cnt, docs_cnt2, total_speed = dict(init_data), dict(init_data), dict(init_data)
    data_types = docs_cnt.keys()
    cnt = 0
    sleepy_time = 20
    for data_type in data_types:
        try:
            got_doc_cnt = get_docs(data_type, today)
        except:
            got_doc_cnt = docs_cnt[data_type]
        docs_cnt[data_type] = got_doc_cnt
    while True:
        time.sleep(sleepy_time)
        for data_type in data_types:
            try:
                got_doc_cnt = get_docs(data_type, today)
            except:
                got_doc_cnt = docs_cnt[data_type]
            docs_cnt2[data_type] = got_doc_cnt
        cnt += 1
        for data_type in data_types:
            speed = (docs_cnt2[data_type]-docs_cnt[data_type])/(sleepy_time+0.0)
            total_speed[data_type] += speed
            print "cnt=%d %s speed = %.1f total_speed=%.1f" % (cnt, data_type, speed, total_speed[data_type]/cnt)
        docs_cnt = dict(docs_cnt2)
        
if __name__ == "__main__":
    main()
复制代码

 












本文转自张昺华-sky博客园博客,原文链接:http://www.cnblogs.com/bonelee/p/6860144.html,如需转载请自行联系原作者

相关文章
|
2月前
|
JSON 算法 API
深度分析小红书城API接口,用Python脚本实现
小红书作为以UGC内容为核心的生活方式平台,其非官方API主要通过移动端抓包解析获得,涵盖内容推荐、搜索、笔记详情、用户信息和互动操作等功能。本文分析了其接口体系、认证机制及请求规范,并提供基于Python的调用框架,涉及签名生成、登录态管理与数据解析。需注意非官方接口存在稳定性与合规风险,使用时应遵守平台协议及法律法规。
|
2月前
|
JSON API 数据安全/隐私保护
【干货满满】分享微店API接口到手价,用python脚本实现
微店作为知名社交电商平台,其开放平台提供商品查询、订单管理等API接口。本文介绍如何通过微店API获取商品到手价(含优惠、券等),涵盖认证机制、Python实现及关键说明。
|
2月前
|
JSON API 数据安全/隐私保护
【干货满满】分享淘宝API接口到手价,用python脚本实现
淘宝开放平台通过API可获取商品到手价,结合商品详情与联盟接口实现优惠计算。需使用AppKey、AppSecret及会话密钥认证,调用taobao.tbk.item.info.get接口获取最终价格。代码示例展示签名生成与数据解析流程。
|
2月前
|
JSON API 数据格式
深度分析大麦网API接口,用Python脚本实现
大麦网为国内领先演出票务平台,提供演唱会、话剧、体育赛事等票务服务。本文基于抓包分析其非官方接口,并提供Python调用方案,涵盖演出列表查询、详情获取及城市列表获取。需注意非官方接口存在稳定性风险,使用时应遵守平台规则,控制请求频率,防范封禁与法律风险。适用于个人学习、演出信息监控等场景。
|
2月前
|
JSON API 开发者
深度分析阿里妈妈API接口,用Python脚本实现
阿里妈妈是阿里巴巴旗下营销平台,提供淘宝联盟、直通车等服务,支持推广位管理、商品查询等API功能。本文详解其API调用方法,重点实现商品推广信息(佣金、优惠券)获取,并提供Python实现方案。
|
2月前
|
JSON API 数据安全/隐私保护
【干货满满】分享拼多多API接口到手价,用python脚本实现
拼多多开放平台提供商品价格查询API,通过“pdd.ddk.goods.detail”接口可获取商品基础价、优惠券、拼团价等信息。结合client_id、client_secret及签名机制实现身份认证,支持推广位ID获取专属优惠。本文提供完整Python实现,涵盖签名生成、接口调用与价格解析逻辑,适用于比价工具、导购平台等场景。
|
2月前
|
API 数据安全/隐私保护 开发者
深度分析苏宁API接口,用Python脚本实现
深度分析苏宁API接口,用Python脚本实现
|
2月前
|
JSON API 数据安全/隐私保护
深度分析虾皮城API接口,用Python脚本实现
虾皮开放平台提供丰富的API接口,支持商品管理、订单处理及促销信息查询等功能。本文详解API认证机制与调用方法,基于Python实现商品价格及到手价获取方案,适用于电商数据分析与运营。
|
2月前
|
前端开发 Shell API
深度分析58同城API接口,用Python脚本实现
58同城为国内知名分类信息平台,涵盖房产、招聘、二手车等多领域。本文基于网页抓包与解析,分享其非官方接口的Python实现方案,分析核心接口特性与反爬应对策略,适用于数据学习与信息聚合。注意:非官方接口存在风险,使用需遵守平台规则。
|
2月前
|
JSON API 数据安全/隐私保护
【干货满满】分享京东API接口到手价,用python脚本实现
淘宝开放平台提供丰富API,通过商品详情接口与淘宝联盟接口,可获取含优惠券、满减后的商品到手价。本文介绍基于Python的实现方案,涵盖签名生成、接口调用、价格解析及错误处理,适用于比价工具、导购平台等场景。

推荐镜像

更多