Skip to content
Toggle navigation
P
Projects
G
Groups
S
Snippets
Help
CIRCLE3
/
monitor-client
This project
Loading...
Sign in
Toggle navigation
Go to a project
Project
Repository
Issues
1
Merge Requests
0
Pipelines
Wiki
Snippets
Members
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Commit
19abb91f
authored
Jan 17, 2022
by
Szeberényi Imre
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'python3.6' into 'master'
Python3.6 See merge request
!1
parents
5978a646
2990b6a7
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
13 additions
and
14 deletions
+13
-14
requirements.txt
+2
-1
src/client.py
+11
-13
No files found.
requirements.txt
View file @
19abb91f
pika
==1.2.0
psutil
==2.1.1
psutil
==2.1.1
pika
src/client.py
View file @
19abb91f
...
@@ -16,9 +16,7 @@ level = os.environ.get('LOGLEVEL', 'INFO')
...
@@ -16,9 +16,7 @@ level = os.environ.get('LOGLEVEL', 'INFO')
logger
.
setLevel
(
level
)
logger
.
setLevel
(
level
)
class
Client
:
class
Client
:
env_config
=
{
env_config
=
{
"server_address"
:
"GRAPHITE_HOST"
,
"server_address"
:
"GRAPHITE_HOST"
,
"server_port"
:
"GRAPHITE_PORT"
,
"server_port"
:
"GRAPHITE_PORT"
,
...
@@ -43,7 +41,7 @@ class Client:
...
@@ -43,7 +41,7 @@ class Client:
Missing only one of these variables will cause the client not to work.
Missing only one of these variables will cause the client not to work.
"""
"""
self
.
name
=
'circle.
%
s'
%
gethostname
()
.
split
(
"."
)[
0
]
self
.
name
=
'circle.
%
s'
%
gethostname
()
.
split
(
"."
)[
0
]
for
var
,
env_var
in
self
.
env_config
.
items
(
):
for
var
,
env_var
in
list
(
self
.
env_config
.
items
()
):
value
=
os
.
getenv
(
env_var
,
""
)
value
=
os
.
getenv
(
env_var
,
""
)
if
value
:
if
value
:
setattr
(
self
,
var
,
value
)
setattr
(
self
,
var
,
value
)
...
@@ -85,7 +83,7 @@ class Client:
...
@@ -85,7 +83,7 @@ class Client:
self
.
connection
.
close
()
self
.
connection
.
close
()
except
RuntimeError
as
e
:
except
RuntimeError
as
e
:
logger
.
error
(
'An error has occured while disconnecting.
%
s'
,
logger
.
error
(
'An error has occured while disconnecting.
%
s'
,
unicode
(
e
))
str
(
e
))
raise
raise
def
send
(
self
,
message
):
def
send
(
self
,
message
):
...
@@ -124,13 +122,13 @@ class Client:
...
@@ -124,13 +122,13 @@ class Client:
}
}
try
:
try
:
for
k
,
v
in
psutil
.
disk_io_counters
()
.
__dict__
.
items
(
):
for
k
,
v
in
list
(
psutil
.
disk_io_counters
()
.
__dict__
.
items
()
):
metrics
[
'disk.
%
s'
%
k
]
=
v
metrics
[
'disk.
%
s'
%
k
]
=
v
except
:
except
:
pass
pass
interfaces
=
psutil
.
net
work
_io_counters
(
pernic
=
True
)
interfaces
=
psutil
.
net_io_counters
(
pernic
=
True
)
for
interface
,
data
in
interfaces
.
ite
rite
ms
():
for
interface
,
data
in
interfaces
.
items
():
if
not
(
interface
.
startswith
(
'cloud'
)
or
if
not
(
interface
.
startswith
(
'cloud'
)
or
interface
.
endswith
(
'-EXT'
)
or
interface
.
endswith
(
'-EXT'
)
or
interface
.
startswith
(
'net'
)
or
interface
.
startswith
(
'net'
)
or
...
@@ -145,7 +143,7 @@ class Client:
...
@@ -145,7 +143,7 @@ class Client:
'name'
:
name
,
'name'
:
name
,
'val'
:
value
,
'val'
:
value
,
'time'
:
now
}
'time'
:
now
}
for
name
,
value
in
metrics
.
ite
rite
ms
()]
for
name
,
value
in
metrics
.
items
()]
def
collect_vms
(
self
):
def
collect_vms
(
self
):
"""
"""
...
@@ -158,7 +156,7 @@ class Client:
...
@@ -158,7 +156,7 @@ class Client:
running_vms
=
[]
running_vms
=
[]
try
:
try
:
for
entry
in
psutil
.
get_process_list
():
for
entry
in
psutil
.
process_iter
():
if
entry
.
name
()
in
(
'kvm'
,
'qemu-system-x86_64'
):
if
entry
.
name
()
in
(
'kvm'
,
'qemu-system-x86_64'
):
parser
=
argparse
.
ArgumentParser
()
parser
=
argparse
.
ArgumentParser
()
parser
.
add_argument
(
'-name'
)
parser
.
add_argument
(
'-name'
)
...
@@ -166,7 +164,7 @@ class Client:
...
@@ -166,7 +164,7 @@ class Client:
args
,
unknown
=
parser
.
parse_known_args
(
args
,
unknown
=
parser
.
parse_known_args
(
entry
.
cmdline
()[
1
:])
entry
.
cmdline
()[
1
:])
# for Red Hat style parametering of kvm
# for Red Hat style parametering of kvm
if
isinstance
(
args
.
name
,
basestring
):
if
isinstance
(
args
.
name
,
str
):
args
.
name
=
re
.
sub
(
r"^guest="
,
""
,
args
.
name
)
args
.
name
=
re
.
sub
(
r"^guest="
,
""
,
args
.
name
)
args
.
name
=
re
.
sub
(
r",debug-threads=.*$"
,
""
,
args
.
name
)
args
.
name
=
re
.
sub
(
r",debug-threads=.*$"
,
""
,
args
.
name
)
...
@@ -194,8 +192,8 @@ class Client:
...
@@ -194,8 +192,8 @@ class Client:
except
(
psutil
.
NoSuchProcess
,
TypeError
):
except
(
psutil
.
NoSuchProcess
,
TypeError
):
logger
.
warning
(
'Process
%
d lost. Entry:
%
s'
,
entry
.
pid
,
entry
.
cmdline
()[
0
:])
logger
.
warning
(
'Process
%
d lost. Entry:
%
s'
,
entry
.
pid
,
entry
.
cmdline
()[
0
:])
interfaces
=
psutil
.
net
work
_io_counters
(
pernic
=
True
)
interfaces
=
psutil
.
net_io_counters
(
pernic
=
True
)
for
interface
,
data
in
interfaces
.
ite
rite
ms
():
for
interface
,
data
in
interfaces
.
items
():
try
:
try
:
vm
,
vlan
=
interface
.
rsplit
(
'-'
,
1
)
vm
,
vlan
=
interface
.
rsplit
(
'-'
,
1
)
except
ValueError
:
except
ValueError
:
...
@@ -224,7 +222,7 @@ class Client:
...
@@ -224,7 +222,7 @@ class Client:
def
_chunker
(
seq
,
size
):
def
_chunker
(
seq
,
size
):
"""Yield seq in size-long chunks.
"""Yield seq in size-long chunks.
"""
"""
for
pos
in
x
range
(
0
,
len
(
seq
),
size
):
for
pos
in
range
(
0
,
len
(
seq
),
size
):
yield
islice
(
seq
,
pos
,
pos
+
size
)
yield
islice
(
seq
,
pos
,
pos
+
size
)
def
run
(
self
):
def
run
(
self
):
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment