前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >每日一题_Python.纯Python实

每日一题_Python.纯Python实

作者头像
py3study
发布2020-01-08 16:35:27
4250
发布2020-01-08 16:35:27
举报
文章被收录于专栏:python3python3

具体需求: 1. 由于自主开发的XmZoomEye-Agent目前被动监控为主,为了实现Zabbix Low-Level Discovery服务自主发现,需要根据进程名自动获取占用端口列表,并根据端口分析上报数据

实现思路:

1. 利用psutil模块通过进程名获取进程id列表 2. 遍历/proc/net/tcp文件获取rem_address为00000000:0000的列,将第九列的socket_id和它以集合形式的字典存储去重 3. 利用获取到的pid列表和socket_id集合字典生成端口集合 4. 尝试连接端口获取动态数据上报

wKiom1flKmWSePxdAAAlVjy4230417.png
wKiom1flKmWSePxdAAAlVjy4230417.png

具体代码:

代码语言:javascript
复制
#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
#
# Authors: limanman
# OsChina: http://xmdevops.blog.51cto.com/
# Purpose:
#
"""
# 说明: 导入公共模块
import os
import re
import psutil
# 说明: 导入其它模块


# 说明: 获取进程
def pidof_processname(srvname):
    pids = []
    for pid in psutil.process_iter():
        if pid.name() == srvname:
            pids.append(str(pid.pid))
    return pids


# 说明: 套接端口
def socks_with_ports():
    sockets = {}
    with open('/proc/net/tcp', 'r+b') as fd:
        for curline in fd:
            sepline = curline.split()
            if sepline[2] != '00000000:0000':
                continue
            key = sepline[9]
            addr, port = sepline[1].split(':')
            if key not in sockets:
                sockets[key] = set()
            sockets[key].add(int(port, 16))
    return sockets


# 说明: 获取端口
def analysis_sockports(pids, socks):
    sock_ports = set()
    for pid in pids:
        fd_path = os.path.join(os.path.join('/proc', pid), 'fd')
        for rlink in os.listdir(fd_path):
            rpath = os.path.join(fd_path, rlink)
            if not os.path.exists(rpath):
                continue
            vlink = os.readlink(rpath)
            if not vlink.startswith('socket:'):
                continue
            match = re.search(r'(?<=socket:\[)([0-9]+)(?=\])', vlink)
            if not match:
                continue
            addr = match.group(1)
            if addr in socks:
                sock_ports.update(socks[addr])
    return sock_ports


def service_redis_running_status(add_data=None):
    srv_name = 'redis-server'
    pids = pidof_processname(srv_name)
    socks = socks_with_ports()
    ports = analysis_sockports(pids, socks)
    return 'service: %s -> port: ' % srv_name, ports


if __name__ == '__main__':
    import pprint
    pprint.pprint(service_redis_running_status())

有图有相:

wKioL1flNUCCprWkAABFkw9S7f0428.png
wKioL1flNUCCprWkAABFkw9S7f0428.png
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-09-03 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档