Merge "Fix psutil inconsistencies"

This commit is contained in:
Zuul 2019-10-10 14:51:52 +00:00 committed by Gerrit Code Review
commit 34aed6f20c
2 changed files with 38 additions and 36 deletions

View File

@ -148,25 +148,26 @@ def tcp_socket_state_check(agentq):
rabbitmq_ports = get_rabbitmq_ports() rabbitmq_ports = get_rabbitmq_ports()
for pr in psutil.pids(): for p in psutil.process_iter():
try: try:
p = psutil.Process(pr) with p.oneshot():
if p.name() == proc: if proc in " ".join(p.cmdline()):
if parentId == 0: if parentId == 0:
parentId = p.pid parentId = p.pid
else: else:
if p.ppid() == parentId: if p.ppid() == parentId:
continue continue
pcon = p.connections() pcon = p.connections()
for con in pcon: for con in pcon:
try: try:
port = con.raddr[1] port = con.raddr[1]
status = con.status status = con.status
except IndexError: except IndexError:
continue continue
if port in rabbitmq_ports and status == tcp_established: if port in rabbitmq_ports and\
rabbit_sock_count = rabbit_sock_count + 1 status == tcp_established:
except psutil.NoSuchProcess: rabbit_sock_count = rabbit_sock_count + 1
except psutil.Error:
continue continue
if rabbit_sock_count == 0: if rabbit_sock_count == 0:

View File

@ -90,25 +90,26 @@ def tcp_socket_status(process, ports):
"""Check the tcp socket status on a process""" """Check the tcp socket status on a process"""
sock_count = 0 sock_count = 0
parentId = 0 parentId = 0
for pr in psutil.pids(): for p in psutil.process_iter():
try: try:
p = psutil.Process(pr) with p.oneshot():
if p.name() == process: if process in " ".join(p.cmdline()):
if parentId == 0: if parentId == 0:
parentId = p.pid parentId = p.pid
else: else:
if p.ppid() == parentId and not cfg.CONF.check_all_pids: if p.ppid() == parentId and \
continue not cfg.CONF.check_all_pids:
pcon = p.connections() continue
for con in pcon: pcon = p.connections()
try: for con in pcon:
rport = con.raddr[1] try:
status = con.status rport = con.raddr[1]
except IndexError: status = con.status
continue except IndexError:
if rport in ports and status == tcp_established: continue
sock_count = sock_count + 1 if rport in ports and status == tcp_established:
except psutil.NoSuchProcess: sock_count = sock_count + 1
except psutil.Error:
continue continue
if sock_count == 0: if sock_count == 0: