Initial commit: AI Interview System

This commit is contained in:
111
2026-01-23 13:57:48 +08:00
commit 95770afe21
127 changed files with 24686 additions and 0 deletions

124
deploy/check_docker.py Normal file
View File

@@ -0,0 +1,124 @@
#!/usr/bin/env python3
"""
检查 Docker 容器状态
"""
import requests
import time
import hashlib
# 禁用 SSL 警告
import urllib3
urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)
# 宝塔配置
BT_PANEL = "http://47.107.172.23:8888"
BT_API_KEY = "PKdfnaInQL0P5ghB8SvwbrGcIpXWaEvq"
DEPLOY_PATH = "/www/wwwroot/ai-interview"
def bt_api(action, data=None, timeout=60):
"""调用宝塔 API"""
if data is None:
data = {}
request_time = int(time.time())
request_token = hashlib.md5(
f"{request_time}{hashlib.md5(BT_API_KEY.encode()).hexdigest()}".encode()
).hexdigest()
data['request_time'] = request_time
data['request_token'] = request_token
url = f"{BT_PANEL}/{action}"
try:
response = requests.post(url, data=data, timeout=timeout, verify=False)
try:
return response.json()
except:
return {"status": True, "msg": response.text[:2000]}
except Exception as e:
return {"status": False, "msg": str(e)}
def run_and_get_log(shell_body, task_name):
"""创建计划任务,运行并获取日志"""
# 1. 创建任务
result = bt_api("crontab?action=AddCrontab", {
"name": task_name,
"type": "minute-n",
"where1": "1",
"hour": "",
"minute": "",
"week": "",
"sType": "toShell",
"sBody": shell_body,
"sName": "",
"backupTo": "",
"save": "",
"urladdress": ""
})
if not result.get("status") or not result.get("id"):
print(f"创建任务失败: {result}")
return None
cron_id = result["id"]
print(f"任务创建成功ID: {cron_id}")
# 2. 执行任务
bt_api("crontab?action=StartTask", {"id": cron_id}, timeout=120)
print("任务已启动,等待执行...")
time.sleep(10)
# 3. 获取日志
log_result = bt_api("crontab?action=GetLogs", {"id": cron_id})
# 4. 删除任务
bt_api("crontab?action=DelCrontab", {"id": cron_id})
return log_result
def main():
print("=" * 60)
print("🔍 检查 Docker 容器状态")
print("=" * 60)
print()
# 检查命令
check_script = f"""#!/bin/bash
echo "========== Docker 容器状态 =========="
docker ps -a
echo ""
echo "========== Docker Compose 状态 =========="
cd {DEPLOY_PATH}/deploy && docker-compose ps 2>&1 || echo "docker-compose 未运行"
echo ""
echo "========== 后端容器日志 (最后 50 行) =========="
docker logs --tail 50 ai-interview-backend 2>&1 || echo "后端容器不存在"
echo ""
echo "========== 检查端口 =========="
netstat -tlnp | grep -E ':(3000|8000)' || ss -tlnp | grep -E ':(3000|8000)' || echo "端口未监听"
echo ""
echo "========== 测试本地服务 =========="
curl -s http://127.0.0.1:8000/health 2>&1 || echo "后端 8000 端口无响应"
curl -s -o /dev/null -w "前端 3000 端口: HTTP %{{http_code}}" http://127.0.0.1:3000 2>&1 || echo "前端 3000 端口无响应"
"""
result = run_and_get_log(check_script, f"check_docker_{int(time.time())}")
if result:
print("\n📋 执行结果:")
print("-" * 60)
if isinstance(result, dict) and result.get("msg"):
print(result["msg"])
else:
print(result)
print()
print("=" * 60)
if __name__ == "__main__":
main()