python修改influxdb的数据_python+influxdb+shell编写区域网络状况表
发布日期:2021-06-25 19:30:02 浏览次数:4 分类:技术文章

本文共 2098 字,大约阅读时间需要 6 分钟。

本文为大家分享了python+influxdb+shell写一个区域网络状况表,供大家参考,具体内容如下

shell脚本部分:

ex:就是ping 各个目的ip10个包,然后获取丢包率和平均延迟时间,在Linux上设置为定时任务,每分钟执行一次。他会把数据写到influxdb服务器上面去,表示hk_vnloss和hk_vn01rtt,字段是loss和rtt,其他各区域的都是类似。

python代码部分:

1、在Django项目的setting里面,配置influxdb数据库连接;

ALLOWED_HOSTS = ['*']

# Application definition

INSTALLED_APPS = [

'django.contrib.admin',

'django.contrib.auth',

'django.contrib.contenttypes',

'django.contrib.sessions',

'django.contrib.messages',

'django.contrib.staticfiles',

'network_ping.apps.NetworkPingConfig',

'influxdb_metrics',

]

##influxdb

INFLUXDB_HOST = 'influxdb服务器ip'

INFLUXDB_PORT = 'influxdb port'

INFLUXDB_USER = 'influxdb username'

INFLUXDB_PASSWORD = 'influxdb passwd'

INFLUXDB_DATABASE = 'influxdb database'

INFLUXDB_TIMEOUT = 36000

2、从influxdb数据库查询保存的loss和rtt数据;

from influxdb_metrics.utils import query

def get_loss(tab_name):

loss_res = query('SELECT * FROM %s ORDER BY time DESC limit 1' % tab_name)

loss = [res for res in loss_res]

return loss

3、把数据传到web页面;

##network ping loss

def network_ping(request):

# vn01 ping vn01

vnloss01 = get_loss('vnloss')

# vn01 ping vn02

vnloss02 = get_loss('vn02loss')

# vn01 ping th

thloss = get_loss('thloss')

# vn01 ping id

idloss = get_loss('idloss')

# vn01 ping sg

sgloss = get_loss('sgloss')

# vn01 ping tw

twloss = get_loss('twloss')

# vn01 ping hk

hkloss = get_loss('hkloss')

# vn01 ping sh

shloss = get_loss('shloss')

return render(request, 'net_ping.html',

{'vn01': {

'vnloss01': vnloss01,

'vnloss02': vnloss02,

'thloss': thloss,

'hkloss': hkloss,

'idloss': idloss,

'sgloss': sgloss,

'twloss': twloss,

'shloss': shloss

},...)

4、在web页面获取进行展示;

VN-01
45.119.241.249

5、js定时刷新页面;

$(function () {

$("[tloss]").each(function () {

var loss_res = $(this).attr('tloss');

if (loss_res < 10) {

$(this).html('

loss: ' + loss_res);

} else if (loss_res <= 20) {

$(this).html('

loss: ' + loss_res);

} else {

$(this).html('

loss: ' + loss_res);

}

});

setTimeout("self.location.reload();", 60000);

})

6、最后的效果展示;

最后:页面是每分钟定时刷新一次,但这个都是当前ping的loss和rtt值,要想看历史的ping情况,可以搭建一个Grafana,然后Grafana配置数据源为influxdb,就可以查看历史曲线等等,例如:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

转载地址:https://blog.csdn.net/weixin_39622901/article/details/111426036 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:python中reversed函数怎么用_python入门课|Python reversed函数使用方法公布,能解决80%的python流程问题...
下一篇:维特比算法 python_如何通俗地讲解 viterbi 算法?

发表评论

最新留言

第一次来,支持一个
[***.219.124.196]2024年03月28日 23时41分12秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章