Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
Y
yunwei
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
wanghongliang
yunwei
Commits
56c887d6
提交
56c887d6
authored
7月 12, 2024
作者:
martin
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
增加日志记录文件1.txt
增加数据库连接失败时的处理逻辑
上级
10d471e2
显示空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
26 行增加
和
14 行删除
+26
-14
service_monitor.py
service_status_exporter/service_monitor.py
+26
-14
没有找到文件。
service_status_exporter/service_monitor.py
浏览文件 @
56c887d6
...
@@ -13,8 +13,20 @@ import time
...
@@ -13,8 +13,20 @@ import time
from
time
import
sleep
from
time
import
sleep
from
prometheus_client
import
start_http_server
,
Gauge
from
prometheus_client
import
start_http_server
,
Gauge
import
argparse
import
argparse
import
pymysql
from
pymysql
import
connect
import
requests
import
requests
import
logging
import
os
current_file_path
=
os
.
path
.
abspath
(
__file__
)
current_dir_path
=
os
.
path
.
dirname
(
current_file_path
)
logging
.
basicConfig
(
filename
=
f
'{current_dir_path}/1.log'
,
# encoding='utf-8',
format
=
'
%(asctime)
s -
%(name)
s -
%(levelname)
s -
%(module)
s:
%(message)
s'
,
datefmt
=
'
%
Y-
%
m-
%
d
%
H:
%
M:
%
S'
,
level
=
logging
.
INFO
)
def
service_status
():
def
service_status
():
...
@@ -29,7 +41,7 @@ def service_status():
...
@@ -29,7 +41,7 @@ def service_status():
# 连接到数据库
# 连接到数据库
try
:
try
:
connection
=
pymysql
.
connect
(
**
config
)
connection
=
connect
(
**
config
)
if
connection
.
open
:
if
connection
.
open
:
# 创建一个游标对象
# 创建一个游标对象
cursor
=
connection
.
cursor
()
cursor
=
connection
.
cursor
()
...
@@ -51,7 +63,8 @@ def service_status():
...
@@ -51,7 +63,8 @@ def service_status():
for
record
in
records
:
for
record
in
records
:
try
:
try
:
status
=
requests
.
get
(
record
[
2
])
.
status_code
status
=
requests
.
get
(
record
[
2
])
.
status_code
except
Exception
:
except
Exception
as
e
:
logging
.
error
(
f
"访问{record[2]}失败,错误为:{e}"
)
# 当网页无法访问时,将状态码设置为777
# 当网页无法访问时,将状态码设置为777
status
=
777
status
=
777
result
.
append
({
result
.
append
({
...
@@ -63,17 +76,14 @@ def service_status():
...
@@ -63,17 +76,14 @@ def service_status():
'owner_email'
:
record
[
4
],
'owner_email'
:
record
[
4
],
'chk_time'
:
time
.
strftime
(
'
%
Y-
%
m-
%
d
%
H:
%
M:
%
S'
,
time
.
localtime
())
'chk_time'
:
time
.
strftime
(
'
%
Y-
%
m-
%
d
%
H:
%
M:
%
S'
,
time
.
localtime
())
})
})
return
result
except
Exception
as
e
:
print
(
f
"数据库连接错误: {e}"
)
finally
:
# 关闭游标和连接
# 关闭游标和连接
if
connection
.
open
:
cursor
.
close
()
cursor
.
close
()
connection
.
close
()
connection
.
close
()
return
result
except
Exception
as
e
:
logging
.
error
(
f
"数据库连接错误: {e}"
)
return
False
if
__name__
==
'__main__'
:
if
__name__
==
'__main__'
:
...
@@ -84,7 +94,7 @@ if __name__ == '__main__':
...
@@ -84,7 +94,7 @@ if __name__ == '__main__':
# 解析命令行参数
# 解析命令行参数
parser
=
argparse
.
ArgumentParser
(
description
=
'这是一个服务状态检查程序,说明如下:'
)
parser
=
argparse
.
ArgumentParser
(
description
=
'这是一个服务状态检查程序,说明如下:'
)
parser
.
add_argument
(
'--port'
,
'-p'
,
default
=
'
8761
'
,
help
=
'监听端口,8761'
)
parser
.
add_argument
(
'--port'
,
'-p'
,
default
=
'
18000
'
,
help
=
'监听端口,8761'
)
parser
.
add_argument
(
'--db_ip'
,
default
=
'114.116.11.225'
,
help
=
'指定mysql的ip,默认为114.116.11.225'
)
parser
.
add_argument
(
'--db_ip'
,
default
=
'114.116.11.225'
,
help
=
'指定mysql的ip,默认为114.116.11.225'
)
parser
.
add_argument
(
'--db_port'
,
default
=
'3306'
,
help
=
'指定mysql端口,默认为3306'
)
parser
.
add_argument
(
'--db_port'
,
default
=
'3306'
,
help
=
'指定mysql端口,默认为3306'
)
parser
.
add_argument
(
'--db_user'
,
default
=
'monitor'
,
help
=
'指定mysql的用户名,monitor'
)
parser
.
add_argument
(
'--db_user'
,
default
=
'monitor'
,
help
=
'指定mysql的用户名,monitor'
)
...
@@ -102,11 +112,13 @@ if __name__ == '__main__':
...
@@ -102,11 +112,13 @@ if __name__ == '__main__':
while
True
:
while
True
:
# 更新指标的值
# 更新指标的值
res
=
service_status
()
res
=
service_status
()
if
res
:
metric
.
clear
()
metric
.
clear
()
for
info
in
res
:
for
info
in
res
:
metric
.
labels
(
project
=
info
[
'project'
],
service_name
=
info
[
'service_name'
],
metric
.
labels
(
project
=
info
[
'project'
],
service_name
=
info
[
'service_name'
],
url
=
info
[
'url'
],
owner_name
=
info
[
'owner_name'
],
url
=
info
[
'url'
],
owner_name
=
info
[
'owner_name'
],
owner_email
=
info
[
'owner_email'
],
chk_time
=
info
[
'chk_time'
])
.
set
(
info
[
'status'
])
owner_email
=
info
[
'owner_email'
],
chk_time
=
info
[
'chk_time'
])
.
set
(
info
[
'status'
])
else
:
logging
.
error
(
"数据获取失败"
)
# 每隔30秒更新一次指标的值
# 每隔30秒更新一次指标的值
sleep
(
3
0
)
sleep
(
6
0
)
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论