feat: 实时监控显示CPU占用最高的进程列表
This commit is contained in:
133
app.py
133
app.py
@@ -799,6 +799,58 @@ def api_system_stats():
|
|||||||
return jsonify({'error': str(e), 'available': False})
|
return jsonify({'error': str(e), 'available': False})
|
||||||
|
|
||||||
|
|
||||||
|
@app.route('/api/system/processes')
|
||||||
|
def api_system_processes():
|
||||||
|
"""获取CPU占用最高的进程列表"""
|
||||||
|
if not HAS_PSUTIL:
|
||||||
|
return jsonify({'error': 'psutil未安装', 'available': False})
|
||||||
|
|
||||||
|
try:
|
||||||
|
limit = int(request.args.get('limit', 10))
|
||||||
|
limit = max(1, min(50, limit)) # 限制1-50
|
||||||
|
|
||||||
|
processes = []
|
||||||
|
for proc in psutil.process_iter(['pid', 'name', 'memory_percent', 'status', 'create_time', 'exe', 'cmdline']):
|
||||||
|
try:
|
||||||
|
pinfo = proc.info
|
||||||
|
# 获取实时CPU占用(需要单独调用)
|
||||||
|
cpu_percent = proc.cpu_percent(interval=0.1)
|
||||||
|
|
||||||
|
# 格式化命令行
|
||||||
|
cmdline = pinfo.get('cmdline', [])
|
||||||
|
cmdline_str = ' '.join(cmdline) if cmdline else pinfo['name']
|
||||||
|
if len(cmdline_str) > 60:
|
||||||
|
cmdline_str = cmdline_str[:60] + '...'
|
||||||
|
|
||||||
|
# 启动时间
|
||||||
|
create_time = datetime.fromtimestamp(pinfo['create_time']).strftime('%m-%d %H:%M')
|
||||||
|
|
||||||
|
processes.append({
|
||||||
|
'pid': pinfo['pid'],
|
||||||
|
'name': pinfo['name'],
|
||||||
|
'cpu': cpu_percent,
|
||||||
|
'memory': pinfo['memory_percent'] or 0,
|
||||||
|
'status': pinfo['status'],
|
||||||
|
'create_time': create_time,
|
||||||
|
'exe': pinfo.get('exe', '') or '',
|
||||||
|
'cmdline': cmdline_str
|
||||||
|
})
|
||||||
|
except (psutil.NoSuchProcess, psutil.AccessDenied):
|
||||||
|
continue
|
||||||
|
|
||||||
|
# 按CPU占用排序,取前N个
|
||||||
|
processes.sort(key=lambda x: x['cpu'], reverse=True)
|
||||||
|
top_processes = processes[:limit]
|
||||||
|
|
||||||
|
return jsonify({
|
||||||
|
'available': True,
|
||||||
|
'processes': top_processes,
|
||||||
|
'count': len(top_processes)
|
||||||
|
})
|
||||||
|
except Exception as e:
|
||||||
|
return jsonify({'error': str(e), 'available': False})
|
||||||
|
|
||||||
|
|
||||||
def guess_cron_name(command):
|
def guess_cron_name(command):
|
||||||
"""从命令推断任务名称"""
|
"""从命令推断任务名称"""
|
||||||
keywords = {
|
keywords = {
|
||||||
@@ -1103,7 +1155,7 @@ HTML_TEMPLATE = '''<!DOCTYPE html>
|
|||||||
<head>
|
<head>
|
||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
<title>项目服务管理面板 v3.2</title>
|
<title>项目服务管理面板 v3.3</title>
|
||||||
<link rel="icon" href="data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><text y='.9em' font-size='90'>📊</text></svg>">
|
<link rel="icon" href="data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><text y='.9em' font-size='90'>📊</text></svg>">
|
||||||
<script src="https://cdn.tailwindcss.com"></script>
|
<script src="https://cdn.tailwindcss.com"></script>
|
||||||
<link href="https://cdn.jsdelivr.net/npm/remixicon@3.5.0/fonts/remixicon.css" rel="stylesheet">
|
<link href="https://cdn.jsdelivr.net/npm/remixicon@3.5.0/fonts/remixicon.css" rel="stylesheet">
|
||||||
@@ -1465,6 +1517,28 @@ HTML_TEMPLATE = '''<!DOCTYPE html>
|
|||||||
<span id="realtimeIndicator" class="text-xs text-green-400 ml-1 hidden">●</span>
|
<span id="realtimeIndicator" class="text-xs text-green-400 ml-1 hidden">●</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<!-- 进程列表(实时监控时显示) -->
|
||||||
|
<div id="processListSection" class="hidden mt-6">
|
||||||
|
<div class="flex items-center justify-between mb-3">
|
||||||
|
<h3 class="font-bold text-gray-200 flex items-center gap-2">
|
||||||
|
<i class="ri-bar-chart-horizontal text-purple-400"></i> CPU占用最高的进程
|
||||||
|
</h3>
|
||||||
|
<div class="flex items-center gap-2">
|
||||||
|
<span class="text-gray-400 text-xs">显示数量:</span>
|
||||||
|
<select id="processLimitSelect" class="bg-gray-700 text-gray-200 px-2 py-1 rounded text-xs" onchange="loadTopProcesses()">
|
||||||
|
<option value="5">5</option>
|
||||||
|
<option value="10" selected>10</option>
|
||||||
|
<option value="15">15</option>
|
||||||
|
<option value="20">20</option>
|
||||||
|
<option value="30">30</option>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div id="processList" class="space-y-2">
|
||||||
|
<div class="text-gray-500 text-center py-4"><i class="ri-loader-4-line animate-spin"></i> 加载中...</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!-- Cron 管理 Tab -->
|
<!-- Cron 管理 Tab -->
|
||||||
@@ -1836,6 +1910,7 @@ HTML_TEMPLATE = '''<!DOCTYPE html>
|
|||||||
document.getElementById('realtimeCheck').checked = false;
|
document.getElementById('realtimeCheck').checked = false;
|
||||||
document.getElementById('realtimeToggle').classList.remove('active');
|
document.getElementById('realtimeToggle').classList.remove('active');
|
||||||
document.getElementById('realtimeIndicator').classList.add('hidden');
|
document.getElementById('realtimeIndicator').classList.add('hidden');
|
||||||
|
document.getElementById('processListSection').classList.add('hidden');
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tab === 'cron') {
|
if (tab === 'cron') {
|
||||||
@@ -2059,26 +2134,82 @@ HTML_TEMPLATE = '''<!DOCTYPE html>
|
|||||||
// 检查阈值
|
// 检查阈值
|
||||||
checkThresholds(data);
|
checkThresholds(data);
|
||||||
|
|
||||||
|
// 如果实时监控开启,加载进程列表
|
||||||
|
if (document.getElementById('realtimeCheck').checked) {
|
||||||
|
loadTopProcesses();
|
||||||
|
}
|
||||||
|
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
console.error('系统资源加载失败:', e);
|
console.error('系统资源加载失败:', e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 加载CPU占用最高的进程
|
||||||
|
async function loadTopProcesses() {
|
||||||
|
try {
|
||||||
|
const limit = document.getElementById('processLimitSelect').value;
|
||||||
|
const res = await fetch(`/api/system/processes?limit=${limit}`);
|
||||||
|
const data = await res.json();
|
||||||
|
|
||||||
|
if (!data.available) {
|
||||||
|
document.getElementById('processList').innerHTML = '<div class="text-red-400 text-center py-4">无法获取进程信息</div>';
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const list = document.getElementById('processList');
|
||||||
|
if (data.processes.length === 0) {
|
||||||
|
list.innerHTML = '<div class="text-gray-500 text-center py-4">暂无进程数据</div>';
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
list.innerHTML = data.processes.map(proc => `
|
||||||
|
<div class="card rounded-lg p-3 hover:border-gray-500 transition-colors">
|
||||||
|
<div class="flex items-center justify-between">
|
||||||
|
<div class="flex items-center gap-3 min-w-0">
|
||||||
|
<span class="text-purple-400 font-mono text-sm">${proc.pid}</span>
|
||||||
|
<div class="min-w-0 flex-1">
|
||||||
|
<div class="text-gray-200 truncate">${proc.name}</div>
|
||||||
|
<div class="text-gray-500 text-xs truncate">${proc.cmdline || proc.exe}</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-center gap-4 text-xs shrink-0">
|
||||||
|
<div class="text-right">
|
||||||
|
<span class="text-blue-400 font-bold">${proc.cpu.toFixed(1)}%</span>
|
||||||
|
<span class="text-gray-500 ml-1">CPU</span>
|
||||||
|
</div>
|
||||||
|
<div class="text-right">
|
||||||
|
<span class="text-green-400 font-bold">${proc.memory.toFixed(1)}%</span>
|
||||||
|
<span class="text-gray-500 ml-1">内存</span>
|
||||||
|
</div>
|
||||||
|
<div class="text-gray-400">${proc.create_time}</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
`).join('');
|
||||||
|
} catch (e) {
|
||||||
|
console.error('进程列表加载失败:', e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function toggleRealtime() {
|
function toggleRealtime() {
|
||||||
const checked = document.getElementById('realtimeCheck').checked;
|
const checked = document.getElementById('realtimeCheck').checked;
|
||||||
const toggle = document.getElementById('realtimeToggle');
|
const toggle = document.getElementById('realtimeToggle');
|
||||||
const indicator = document.getElementById('realtimeIndicator');
|
const indicator = document.getElementById('realtimeIndicator');
|
||||||
|
const processSection = document.getElementById('processListSection');
|
||||||
|
|
||||||
if (checked) {
|
if (checked) {
|
||||||
toggle.classList.add('active');
|
toggle.classList.add('active');
|
||||||
indicator.classList.remove('hidden');
|
indicator.classList.remove('hidden');
|
||||||
|
processSection.classList.remove('hidden');
|
||||||
// 立即加载一次
|
// 立即加载一次
|
||||||
loadSystemStats();
|
loadSystemStats();
|
||||||
|
loadTopProcesses();
|
||||||
// 启动定时器
|
// 启动定时器
|
||||||
realtimeTimer = setInterval(loadSystemStats, realtimeInterval * 1000);
|
realtimeTimer = setInterval(loadSystemStats, realtimeInterval * 1000);
|
||||||
} else {
|
} else {
|
||||||
toggle.classList.remove('active');
|
toggle.classList.remove('active');
|
||||||
indicator.classList.add('hidden');
|
indicator.classList.add('hidden');
|
||||||
|
processSection.classList.add('hidden');
|
||||||
// 停止定时器
|
// 停止定时器
|
||||||
if (realtimeTimer) {
|
if (realtimeTimer) {
|
||||||
clearInterval(realtimeTimer);
|
clearInterval(realtimeTimer);
|
||||||
|
|||||||
283
logs/app.log
283
logs/app.log
@@ -1,8 +1,8 @@
|
|||||||
[2026-04-23 23:33:00] ==================================================
|
[2026-04-23 23:57:38] ==================================================
|
||||||
[2026-04-23 23:33:00] 项目服务管理面板 v2.0.0 启动
|
[2026-04-23 23:57:38] 项目服务管理面板 v2.0.0 启动
|
||||||
[2026-04-23 23:33:00] 访问地址: http://localhost:19013
|
[2026-04-23 23:57:38] 访问地址: http://localhost:19013
|
||||||
[2026-04-23 23:33:00] 进程PID: 1265636
|
[2026-04-23 23:57:38] 进程PID: 1274690
|
||||||
[2026-04-23 23:33:00] ==================================================
|
[2026-04-23 23:57:38] ==================================================
|
||||||
* Serving Flask app 'app'
|
* Serving Flask app 'app'
|
||||||
* Debug mode: off
|
* Debug mode: off
|
||||||
WARNING: This is a development server. Do not use it in a production deployment. Use a production WSGI server instead.
|
WARNING: This is a development server. Do not use it in a production deployment. Use a production WSGI server instead.
|
||||||
@@ -10,247 +10,32 @@ WARNING: This is a development server. Do not use it in a production deployment.
|
|||||||
* Running on http://127.0.0.1:19013
|
* Running on http://127.0.0.1:19013
|
||||||
* Running on http://192.168.2.17:19013
|
* Running on http://192.168.2.17:19013
|
||||||
Press CTRL+C to quit
|
Press CTRL+C to quit
|
||||||
127.0.0.1 - - [23/Apr/2026 23:33:03] "GET / HTTP/1.1" 200 -
|
127.0.0.1 - - [23/Apr/2026 23:57:42] "GET / HTTP/1.1" 200 -
|
||||||
192.168.2.8 - - [23/Apr/2026 23:33:05] "GET /api/projects HTTP/1.1" 200 -
|
192.168.2.14 - - [23/Apr/2026 23:57:43] "GET /api/projects HTTP/1.1" 200 -
|
||||||
127.0.0.1 - - [23/Apr/2026 23:33:06] "GET / HTTP/1.1" 200 -
|
127.0.0.1 - - [23/Apr/2026 23:57:45] "GET / HTTP/1.1" 200 -
|
||||||
127.0.0.1 - - [23/Apr/2026 23:33:13] "GET / HTTP/1.1" 200 -
|
192.168.2.8 - - [23/Apr/2026 23:57:47] "GET /api/projects HTTP/1.1" 200 -
|
||||||
192.168.2.8 - - [23/Apr/2026 23:33:15] "GET /api/projects HTTP/1.1" 200 -
|
127.0.0.1 - - [23/Apr/2026 23:57:52] "GET / HTTP/1.1" 200 -
|
||||||
127.0.0.1 - - [23/Apr/2026 23:33:23] "GET / HTTP/1.1" 200 -
|
192.168.2.14 - - [23/Apr/2026 23:57:53] "GET /api/projects HTTP/1.1" 200 -
|
||||||
192.168.2.8 - - [23/Apr/2026 23:33:25] "GET /api/projects HTTP/1.1" 200 -
|
127.0.0.1 - - [23/Apr/2026 23:57:55] "GET / HTTP/1.1" 200 -
|
||||||
127.0.0.1 - - [23/Apr/2026 23:33:31] "GET / HTTP/1.1" 200 -
|
192.168.2.8 - - [23/Apr/2026 23:57:57] "GET /api/projects HTTP/1.1" 200 -
|
||||||
192.168.2.8 - - [23/Apr/2026 23:33:33] "GET /api/projects HTTP/1.1" 200 -
|
127.0.0.1 - - [23/Apr/2026 23:58:02] "GET / HTTP/1.1" 200 -
|
||||||
127.0.0.1 - - [23/Apr/2026 23:33:33] "GET / HTTP/1.1" 200 -
|
127.0.0.1 - - [23/Apr/2026 23:58:02] "GET / HTTP/1.1" 200 -
|
||||||
127.0.0.1 - - [23/Apr/2026 23:33:33] "GET / HTTP/1.1" 200 -
|
192.168.2.14 - - [23/Apr/2026 23:58:03] "GET /api/projects HTTP/1.1" 200 -
|
||||||
192.168.2.14 - - [23/Apr/2026 23:33:35] "GET /api/projects HTTP/1.1" 200 -
|
192.168.2.8 - - [23/Apr/2026 23:58:04] "GET /api/projects HTTP/1.1" 200 -
|
||||||
192.168.2.8 - - [23/Apr/2026 23:33:35] "GET /api/projects HTTP/1.1" 200 -
|
127.0.0.1 - - [23/Apr/2026 23:58:05] "GET / HTTP/1.1" 200 -
|
||||||
127.0.0.1 - - [23/Apr/2026 23:33:43] "GET / HTTP/1.1" 200 -
|
192.168.2.8 - - [23/Apr/2026 23:58:07] "GET /api/projects HTTP/1.1" 200 -
|
||||||
192.168.2.8 - - [23/Apr/2026 23:33:45] "GET /api/projects HTTP/1.1" 200 -
|
127.0.0.1 - - [23/Apr/2026 23:58:12] "GET / HTTP/1.1" 200 -
|
||||||
127.0.0.1 - - [23/Apr/2026 23:33:53] "GET / HTTP/1.1" 200 -
|
192.168.2.14 - - [23/Apr/2026 23:58:13] "GET /api/projects HTTP/1.1" 200 -
|
||||||
192.168.2.8 - - [23/Apr/2026 23:33:55] "GET /api/projects HTTP/1.1" 200 -
|
127.0.0.1 - - [23/Apr/2026 23:58:15] "GET / HTTP/1.1" 200 -
|
||||||
127.0.0.1 - - [23/Apr/2026 23:34:01] "GET / HTTP/1.1" 200 -
|
192.168.2.8 - - [23/Apr/2026 23:58:17] "GET /api/projects HTTP/1.1" 200 -
|
||||||
192.168.2.8 - - [23/Apr/2026 23:34:03] "GET /api/projects HTTP/1.1" 200 -
|
127.0.0.1 - - [23/Apr/2026 23:58:19] "GET /api/system/processes?limit=5 HTTP/1.1" 200 -
|
||||||
127.0.0.1 - - [23/Apr/2026 23:34:03] "GET / HTTP/1.1" 200 -
|
127.0.0.1 - - [23/Apr/2026 23:58:22] "GET / HTTP/1.1" 200 -
|
||||||
192.168.2.8 - - [23/Apr/2026 23:34:05] "GET /api/projects HTTP/1.1" 200 -
|
192.168.2.14 - - [23/Apr/2026 23:58:23] "GET /api/projects HTTP/1.1" 200 -
|
||||||
127.0.0.1 - - [23/Apr/2026 23:34:13] "GET / HTTP/1.1" 200 -
|
127.0.0.1 - - [23/Apr/2026 23:58:25] "GET / HTTP/1.1" 200 -
|
||||||
192.168.2.8 - - [23/Apr/2026 23:34:15] "GET /api/projects HTTP/1.1" 200 -
|
192.168.2.8 - - [23/Apr/2026 23:58:27] "GET /api/projects HTTP/1.1" 200 -
|
||||||
127.0.0.1 - - [23/Apr/2026 23:34:23] "GET / HTTP/1.1" 200 -
|
127.0.0.1 - - [23/Apr/2026 23:58:32] "GET / HTTP/1.1" 200 -
|
||||||
192.168.2.8 - - [23/Apr/2026 23:34:25] "GET /api/projects HTTP/1.1" 200 -
|
127.0.0.1 - - [23/Apr/2026 23:58:32] "GET / HTTP/1.1" 200 -
|
||||||
127.0.0.1 - - [23/Apr/2026 23:34:32] "GET / HTTP/1.1" 200 -
|
192.168.2.14 - - [23/Apr/2026 23:58:33] "GET /api/projects HTTP/1.1" 200 -
|
||||||
127.0.0.1 - - [23/Apr/2026 23:34:33] "GET / HTTP/1.1" 200 -
|
192.168.2.8 - - [23/Apr/2026 23:58:34] "GET /api/projects HTTP/1.1" 200 -
|
||||||
192.168.2.8 - - [23/Apr/2026 23:34:33] "GET /api/projects HTTP/1.1" 200 -
|
127.0.0.1 - - [23/Apr/2026 23:58:35] "GET / HTTP/1.1" 200 -
|
||||||
127.0.0.1 - - [23/Apr/2026 23:34:34] "GET / HTTP/1.1" 200 -
|
192.168.2.8 - - [23/Apr/2026 23:58:37] "GET /api/projects HTTP/1.1" 200 -
|
||||||
192.168.2.14 - - [23/Apr/2026 23:34:35] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:34:35] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:34:44] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:34:45] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:34:54] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:34:55] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:35:02] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:35:03] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:35:04] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:35:05] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:35:14] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:35:15] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:35:24] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:35:25] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:35:32] "GET / HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:35:33] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:35:33] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:35:34] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:35:35] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:35:35] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:35:44] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:35:45] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:35:54] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:35:55] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:36:02] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:36:04] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:36:04] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:36:06] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:36:14] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:36:16] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:36:24] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:36:26] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:36:29] "GET / HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:36:30] "GET / HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:36:31] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:36:31] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:36:32] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:36:32] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:36:32] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:36:33] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:36:34] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:36:34] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:36:36] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:36:40] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:36:41] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:36:42] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:36:42] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:36:44] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:36:44] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:36:46] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:36:46] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:36:48] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:36:50] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:36:51] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:36:52] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:36:53] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:36:54] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:36:54] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:36:56] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:36:56] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:36:58] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:00] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:37:01] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:02] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:37:02] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:02] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:37:04] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:04] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:37:04] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:37:06] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:06] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:08] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:10] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:37:11] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:12] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:12] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:14] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:37:14] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:37:16] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:16] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:18] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:20] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:37:21] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:22] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:22] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:24] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:37:24] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:37:26] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:26] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:28] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:30] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:37:31] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:32] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:37:32] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:32] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:37:34] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:34] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:37:34] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:37:36] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:36] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:38] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:40] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:37:41] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:42] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:42] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:44] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:37:44] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:37:46] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:46] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:48] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:50] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:37:51] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:52] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:52] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:54] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:37:54] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:37:56] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:56] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:37:58] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:00] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:38:01] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:02] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:38:02] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:02] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:38:04] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:04] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:38:04] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:38:06] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:06] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:08] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:10] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:38:11] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:12] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:12] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:14] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:38:15] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:16] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:38:17] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:18] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:20] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:38:21] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:22] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:22] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:24] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:24] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:38:25] "GET / HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:38:25] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:38:27] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:27] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:27] "GET /api/system/stats HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:38:32] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:38:34] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:38:35] "GET / HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:38:35] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:38:37] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:37] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:38:45] "GET / HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:38:45] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:38:47] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:47] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:38:55] "GET / HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:38:55] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:38:57] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:38:57] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:39:02] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:39:04] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:39:05] "GET / HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:39:05] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:39:07] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:39:07] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:39:15] "GET / HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:39:15] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:39:17] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:39:17] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:39:25] "GET / HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:39:25] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:39:27] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:39:27] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:39:32] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:39:34] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:39:35] "GET / HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:39:35] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:39:37] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:39:37] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:39:38] "GET / HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:39:45] "GET / HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:39:45] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:39:47] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:39:47] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:39:55] "GET / HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:39:55] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:39:57] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:39:57] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:40:01] "GET / HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:40:02] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:40:04] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:40:05] "GET / HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:40:05] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:40:07] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:40:07] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:40:15] "GET / HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:40:15] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:40:17] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:40:17] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:40:25] "GET / HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:40:25] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:40:27] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:40:27] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:40:32] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:40:34] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:40:35] "GET / HTTP/1.1" 200 -
|
|
||||||
127.0.0.1 - - [23/Apr/2026 23:40:35] "GET / HTTP/1.1" 200 -
|
|
||||||
192.168.2.8 - - [23/Apr/2026 23:40:37] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
192.168.2.14 - - [23/Apr/2026 23:40:37] "GET /api/projects HTTP/1.1" 200 -
|
|
||||||
[2026-04-23 23:40:37] ⚠️ 进程收到 SIGTERM 信号,即将退出!
|
|
||||||
|
|||||||
Reference in New Issue
Block a user