python c/s模式下的内存监控模拟代码

简介:

对与服务端我们可以自己写些API供监控使用。

以下Code只是简单的给监控机吐出固定的mem值:80,不过,可以根据后期需要来开发相应的模块。此次我采用的是select来作为server端的socket监控,不过对与他的1024限制来说,我觉得仅作为监控服务端来说足够了,如果作为更大并发的server端话,可以使用poll,epoll,或者多线程并且结合队列来做到一定的限制,别让过多的连接把服务器干挂。


Server端

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
#!/usr/bin/env python
#Author:Badboy
#CreatBy:2014/5/1
import  socket,select
host = "192.168.1.61"
port = 1001
sock = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
sock.setblocking( 0 )
sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR,  1 )
sock.bind((host,port))
sock.listen( 1024 )
inputs = [sock]
outputs = []
addrs = {}
debug = 0
def  get_free_mem():
     return  "80"
def  send_data(sock,data):
     if  data.strip() = = 'mem' :
         sock.send(get_free_mem())
     else :
         sock.send( "Error key words!" )
while  inputs:
     rlist,wlist,elist = select.select(inputs,outputs,[], 0 )
     for  in  rlist:
         if  = =  inputs[ 0 ]:
             clientsock,clientaddr = s.accept()
             inputs.append(clientsock)
             addrs[clientsock] = clientaddr[ 0 ]
             print  "ClientAddr:" ,clientaddr[ 0 ]
             if  debug:
                 clientsock.send( "Welcome here!\r\n" )
         else :
             words = s.recv( 1024 )
             if  not  words:
                 print  "Byebye" ,addrs[s]
                 s.close()
                 inputs.remove(s)
                 del  addrs[s]
                 if  in  outputs:
                     outputs.remove(s)
                 continue
             if  not  in  outputs:
                 outputs.append(s)
     for  in  wlist:
         send_data(s,words)
         outputs.remove(s)

Client

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#!/usr/bin/env python
#Author Badboy
#CreatBy:2014/5/1
import  socket,sys
mem_check = "mem"
host = "192.168.1.61"
port = 1001
sock  =  socket.socket(socket.AF_INET,socket.SOCK_STREAM)
sock.connect((host,port))
sock.send(mem_check)
mem_warning = 40
mem_critical = 20
mem_size = sock.recv( 1024 )
if  mem_size = = "Error key words!" :
    print  "Please check client!"
    sys.exit( 1 )
mem_size = int (mem_size)
if  mem_size > mem_warning:
     print  "Mem Size Ok!"
elif  mem_size < mem_critical:
     print  "Mem Size Critical!"
else :
     print  "Mem Size Warning!"

以上仅是案例,大家可以在此基础上扩展修改的。



本文转自hahazhu0634 51CTO博客,原文链接:http://blog.51cto.com/5ydycm/1405310,如需转载请自行联系原作者

相关文章
|
1天前
|
数据采集 JSON API
【2024-简洁版】python爬虫 批量查询自己所有CSDN文章的质量分:方便快速上手修改代码
【2024-简洁版】python爬虫 批量查询自己所有CSDN文章的质量分:方便快速上手修改代码
8 0
|
1天前
|
Python
Python中的装饰器:提升代码可读性与复用性
Python中的装饰器是一种强大的工具,能够提升代码的可读性和复用性。本文将深入探讨装饰器的原理、用法以及在实际项目中的应用,帮助读者更好地理解和利用这一特性,提升代码质量和开发效率。
|
2天前
|
监控 Python
Python中的装饰器:提升代码可读性与可维护性
Python中的装饰器是一种强大的工具,可以在不修改函数源代码的情况下,增加新的功能。本文将介绍装饰器的基本概念,以及如何使用装饰器来提升代码的可读性和可维护性。通过实例演示,读者将了解装饰器在各种场景下的灵活运用,从而更好地理解并应用于实际开发中。
|
2天前
|
缓存 Python
Python中的装饰器:提升代码可读性与灵活性
在Python编程中,装饰器是一种强大的工具,可以通过在函数或方法周围包装额外的功能来提升代码的可读性和灵活性。本文将深入探讨装饰器的概念、用法和实际应用,帮助读者更好地理解并运用这一Python编程的利器。
|
3天前
|
存储 关系型数据库 数据库
python中内存错误(MemoryError)
【5月更文挑战第3天】
11 1
|
3天前
|
缓存 并行计算 Serverless
优化Python代码性能的5个技巧
在日常Python编程中,代码性能的优化是一个重要的议题。本文介绍了5个实用的技巧,帮助你提高Python代码的执行效率,包括使用适当的数据结构、优化循环结构、利用内置函数、使用生成器表达式以及并行化处理。通过这些技巧,你可以更高效地编写Python代码,提升程序的性能和响应速度。
|
4天前
|
Python
探索Python中的装饰器:提升代码灵活性与可维护性
Python中的装饰器是一种强大的工具,可以在不改变原有代码结构的情况下,动态地添加功能或修改函数的行为。本文将深入探讨装饰器的原理、常见用法以及如何利用装饰器提升代码的灵活性和可维护性。
|
5天前
|
机器学习/深度学习 自然语言处理 算法
Python遗传算法GA对长短期记忆LSTM深度学习模型超参数调优分析司机数据|附数据代码
Python遗传算法GA对长短期记忆LSTM深度学习模型超参数调优分析司机数据|附数据代码
|
5天前
|
数据可视化 Python
python中Copula在多元联合分布建模可视化2实例合集|附数据代码
python中Copula在多元联合分布建模可视化2实例合集|附数据代码
|
5天前
|
人工智能 Python
Python中的反对称矩阵:理论、应用与代码实践
Python中的反对称矩阵:理论、应用与代码实践
23 1