python向influxdb写入数据

python版本:3.6
influxdb版本:1.5.2
kafka版本:2.11-1.1.0

1、基本环境
使用python消费kafka中的数据,然后插入influxdb

python安装 requests模块
python安装 kafka模块
kafka服务器:192.168.1.100:9092
influxdb服务器:192.168.1.100:8086

2、关键代码

# coding: utf-8
from kafka import KafkaConsumer
import requests     

topic = 'host-resource-detector'
broker_list = ['192.168.1.100:9092'] ##kafka ip,也可以是集群
kafka = KafkaConsumer(topic, bootstrap_servers=broker_list, group_id='host-monitor', enable_auto_commit=True, auto_offset_reset='latest')

##带验证的写法,u 表示用户名,p 表示密码
influxdb_url = "http://10.25.172.88:8086/write?db=hostdb&u=monitor;&p=tiger1234"

for msg in kafka:
    record = eval(str(msg.value,encoding = "utf-8"))
    ##从kafka消费数据并组装成influxdb sql语句
    influxdb_data = "hostdb," + "hostname=" + record['hostname'] + " cpu_used=" + str(round(100-float(record['cpu_idle']),2)) + ",memory_used=" + str(record['memory_used']) + ",num_process=" + str(record['num_process']) + " " + str(record['timestamp']) + "000000000"
    ##通过http api插入数据到influxdb
    response = requests.post(influxdb_url, data=influxdb_data)
    ##获取请求返回信息,特别是报错信息
    print(response.content) 
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值