Files
doris-mcp-server/restart_server.sh
2025-05-06 12:56:55 +08:00

167 lines
4.9 KiB
Bash
Executable File

#!/bin/bash
# Doris MCP Server Restart Script
# Detects port and process usage, terminates existing processes, then restarts the server
# Set terminal colors
GREEN='\033[0;32m'
RED='\033[0;31m'
YELLOW='\033[0;33m'
NC='\033[0m' # No Color
# Server configuration
MCP_PORT=3000
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
START_SCRIPT="${SCRIPT_DIR}/start_server.sh"
echo -e "${GREEN}========== Doris MCP Server Restart Script ==========${NC}"
# Check if start_server.sh exists
if [ ! -f "$START_SCRIPT" ]; then
echo -e "${RED}Error: Start script $START_SCRIPT does not exist${NC}"
exit 1
fi
# Check port usage
check_port() {
echo -e "${YELLOW}Checking port $MCP_PORT usage...${NC}"
PORT_PID=$(lsof -ti:$MCP_PORT)
if [ -n "$PORT_PID" ]; then
echo -e "${YELLOW}Port $MCP_PORT is used by process $PORT_PID${NC}"
return 0
else
echo -e "${GREEN}Port $MCP_PORT is not in use${NC}"
return 1
fi
}
# Check if Python process is running
check_python_process() {
echo -e "${YELLOW}Checking if Python process is running doris_mcp_server.main...${NC}"
PYTHON_PID=$(ps aux | grep "[p]ython.*-m doris_mcp_server.main --sse" | awk '{print $2}')
if [ -n "$PYTHON_PID" ]; then
echo -e "${YELLOW}Detected Python process $PYTHON_PID running doris_mcp_server.main --sse${NC}"
return 0
else
echo -e "${GREEN}No Python process running doris_mcp_server.main detected${NC}"
return 1
fi
}
# Kill process
kill_process() {
local PID=$1
echo -e "${YELLOW}Terminating process $PID...${NC}"
kill $PID 2>/dev/null
# Wait for process termination
for i in {1..5}; do
if ! ps -p $PID > /dev/null 2>&1; then
echo -e "${GREEN}Process $PID has terminated${NC}"
return 0
fi
echo -e "${YELLOW}Waiting for process termination (${i}/5)...${NC}"
sleep 1
done
# If process is still running, force kill
if ps -p $PID > /dev/null 2>&1; then
echo -e "${YELLOW}Process still running, force killing process $PID...${NC}"
kill -9 $PID 2>/dev/null
sleep 1
if ! ps -p $PID > /dev/null 2>&1; then
echo -e "${GREEN}Process $PID has been force killed${NC}"
return 0
else
echo -e "${RED}Failed to terminate process $PID${NC}"
return 1
fi
fi
return 0
}
# Clean up all process and port usage
cleanup() {
# Check and terminate process using the port
check_port
if [ $? -eq 0 ]; then
kill_process $PORT_PID
fi
# Check and terminate Python process
check_python_process
if [ $? -eq 0 ]; then
kill_process $PYTHON_PID
fi
# Check port usage again to ensure it's released
check_port
if [ $? -eq 0 ]; then
echo -e "${RED}Warning: Failed to release port $MCP_PORT, please check the process manually${NC}"
return 1
fi
# Clean up possible Python bytecode cache
echo -e "${YELLOW}Cleaning Python bytecode cache...${NC}"
find "$SCRIPT_DIR" -name "*.pyc" -delete
find "$SCRIPT_DIR" -name "__pycache__" -exec rm -rf {} + 2>/dev/null || true
echo -e "${GREEN}Cleanup complete${NC}"
return 0
}
# Start server
start_server() {
echo -e "${YELLOW}Stopping existing Doris MCP server process (SSE mode)...${NC}"
pkill -f "python -m doris_mcp_server.main --sse" || true
# Wait for the process to stop completely
sleep 2
echo -e "${YELLOW}Starting Doris MCP server (SSE mode)...${NC}"
nohup python -m doris_mcp_server.main --sse >> logs/doris_mcp.log 2>> logs/doris_mcp.error &
# Wait for server startup
sleep 5
echo -e "${YELLOW}Checking if the server started successfully (SSE mode)...${NC}"
if pgrep -f "python -m doris_mcp_server.main --sse" > /dev/null; then
echo -e "${GREEN}Doris MCP server (SSE mode) started successfully${NC}"
echo -e "${GREEN}Service address: http://localhost:$MCP_PORT/${NC}"
return 0
else
echo -e "${RED}Server startup failed, please check the log files${NC}"
tail -n 20 logs/doris_mcp.error
return 1
fi
}
# Main function
main() {
echo -e "${YELLOW}Starting Doris MCP server restart...${NC}"
# Clean up existing processes
cleanup
if [ $? -ne 0 ]; then
echo -e "${RED}Failed to clean up existing processes, restart aborted${NC}"
exit 1
fi
# Wait for port to be fully released
sleep 2
# Start the server
start_server
if [ $? -ne 0 ]; then
echo -e "${RED}Server startup failed${NC}"
exit 1
fi
echo -e "${GREEN}Server restarted successfully${NC}"
echo -e "${YELLOW}Service running at: http://localhost:$MCP_PORT${NC}"
echo -e "${YELLOW}Health check: http://localhost:$MCP_PORT/health${NC}"
echo -e "${YELLOW}SSE test endpoint: http://localhost:$MCP_PORT/sse"
}
# Run main function
main