Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
Y
yunwei
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
wanghongliang
yunwei
Commits
1aefa209
提交
1aefa209
authored
2月 23, 2024
作者:
martin
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
window版进程监控exporter
上级
4a21853c
隐藏空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
122 行增加
和
2 行删除
+122
-2
profiles_settings.xml
.idea/inspectionProfiles/profiles_settings.xml
+1
-0
service_monitor.py
service_monitor.py
+101
-0
svc_chk.py
svc_chk.py
+6
-2
tmp.py
tmp.py
+14
-0
没有找到文件。
.idea/inspectionProfiles/profiles_settings.xml
浏览文件 @
1aefa209
<component
name=
"InspectionProjectProfileManager"
>
<component
name=
"InspectionProjectProfileManager"
>
<settings>
<settings>
<option
name=
"PROJECT_PROFILE"
value=
"Default"
/>
<option
name=
"USE_PROJECT_PROFILE"
value=
"false"
/>
<option
name=
"USE_PROJECT_PROFILE"
value=
"false"
/>
<version
value=
"1.0"
/>
<version
value=
"1.0"
/>
</settings>
</settings>
...
...
service_monitor.py
0 → 100644
浏览文件 @
1aefa209
import
time
from
time
import
sleep
from
prometheus_client
import
start_http_server
,
Gauge
import
argparse
import
pymysql
import
requests
def
service_status
():
# 数据库连接配置
config
=
{
'host'
:
args
.
db_ip
,
'port'
:
int
(
args
.
db_port
),
'database'
:
'monitor'
,
# 替换为你的数据库名称
'user'
:
args
.
db_user
,
# 替换为你的数据库用户名
'password'
:
args
.
db_password
# 替换为你的数据库密码
}
# 连接到数据库
try
:
connection
=
pymysql
.
connect
(
**
config
)
if
connection
.
open
:
# 创建一个游标对象
cursor
=
connection
.
cursor
()
# 执行一个查询来获取项目和服务的相关信息
query
=
"""
SELECT a.project,a.service_name,a.url,b.owner_name,b.owner_email
from monitor.service a JOIN monitor.project b ON a.project=b.project
order by a.project ,a.service_name;
"""
cursor
.
execute
(
query
)
# 获取所有记录
records
=
cursor
.
fetchall
()
# 将记录转换为字典列表
result
=
[]
for
record
in
records
:
try
:
status
=
requests
.
get
(
record
[
2
])
.
status_code
except
Exception
:
# 当网页无法访问时,将状态码设置为777
status
=
777
result
.
append
({
'project'
:
record
[
0
],
'service_name'
:
record
[
1
],
'url'
:
record
[
2
],
'status'
:
status
,
'owner_name'
:
record
[
3
],
'owner_email'
:
record
[
4
],
'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
()
connection
.
close
()
if
__name__
==
'__main__'
:
# 创建一个Gauge指标
metric
=
Gauge
(
'zzsn_service_status'
,
'service running status code'
,
[
'project'
,
'service_name'
,
'url'
,
'owner_name'
,
'owner_email'
,
'chk_time'
])
# 解析命令行参数
parser
=
argparse
.
ArgumentParser
(
description
=
'这是一个服务状态检查程序,说明如下:'
)
parser
.
add_argument
(
'--port'
,
'-p'
,
default
=
'8761'
,
help
=
'监听端口,8761'
)
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_user'
,
default
=
'monitor'
,
help
=
'指定mysql的用户名,monitor'
)
parser
.
add_argument
(
'--db_password'
,
default
=
'@ZZsn9988'
,
help
=
'指定mysql的密码,默认值你猜'
)
args
=
parser
.
parse_args
()
# 启动HTTP服务器,监听指定的端口,并添加基本身份验证
start_http_server
(
int
(
args
.
port
))
print
(
"zzsn Service Exporter for Prometheus is running..."
)
print
(
f
"System args is
\n
"
f
"Listen port:{args.port}
\n
"
f
"Mysql IP:{args.db_ip}
\n
"
f
"Mysql port:{args.db_port}
\n
"
f
"Mysql username:{args.db_user}
\n
"
f
"Mysql Database:monitor"
)
while
True
:
# 更新指标的值
res
=
service_status
()
metric
.
clear
()
for
info
in
res
:
metric
.
labels
(
project
=
info
[
'project'
],
service_name
=
info
[
'service_name'
],
url
=
info
[
'url'
],
owner_name
=
info
[
'owner_name'
],
owner_email
=
info
[
'owner_email'
],
chk_time
=
info
[
'chk_time'
])
.
set
(
info
[
'status'
])
# 每隔30秒更新一次指标的值
sleep
(
30
)
svc_chk.py
浏览文件 @
1aefa209
from
subprocess
import
check_output
as
co
from
subprocess
import
check_output
as
co
import
os
def
bash_cmd
(
cmd
):
def
bash_cmd
(
cmd
):
...
@@ -11,5 +12,8 @@ def bash_cmd(cmd):
...
@@ -11,5 +12,8 @@ def bash_cmd(cmd):
return
False
return
False
print
(
bash_cmd
(
'cd /etc/ ; ls ; cd / ;ls'
))
bat_file
=
"start cmd /k C:/Users/EDY/Desktop/monitor/dist/start.bat"
print
(
bash_cmd
(
'ps -ef'
))
os
.
system
(
bat_file
)
# print(bash_cmd('cd /etc/ ; ls ; cd / ;ls'))
# print(bash_cmd('ps -ef'))
tmp.py
0 → 100644
浏览文件 @
1aefa209
import
argparse
parser
=
argparse
.
ArgumentParser
(
description
=
"这是帮助信息第一部分"
)
parser
.
add_argument
(
'--port'
,
'-i'
,
default
=
'7890'
,
help
=
'这里监听端口,默认为7890'
)
parser
.
add_argument
(
'--db_ip'
,
default
=
'127.0.0.1'
,
help
=
'这里指定mysql的ip,默认为127.0.0.1'
)
parser
.
add_argument
(
'--db_port'
,
default
=
'3306'
,
help
=
'这里指定mysql端口,默认为3306'
)
parser
.
add_argument
(
'--db_user'
,
default
=
'root'
,
help
=
'这里指定mysql的用户名,默认为root'
)
parser
.
add_argument
(
'--db_password'
,
default
=
'123456'
,
help
=
'这里指定mysql的密码,默认为123456'
)
parser
.
add_argument
(
'--db_database'
,
default
=
'test'
,
help
=
'这里指定mysql的密码,默认为test'
)
args
=
parser
.
parse_args
()
print
(
args
.
db_ip
)
print
(
type
(
args
))
if
args
.
port
!=
'7860'
:
args
.
port
=
8888
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论