You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
335 lines
9.6 KiB
335 lines
9.6 KiB
#!/bin/bash
|
|
|
|
set -euo pipefail
|
|
|
|
# Colors for output
|
|
RED='\033[0;31m'
|
|
GREEN='\033[0;32m'
|
|
BLUE='\033[0;34m'
|
|
YELLOW='\033[1;33m'
|
|
NC='\033[0m' # No Color
|
|
|
|
# Configuration
|
|
COMPOSE_FILE="docker-compose.mount-rdma.yml"
|
|
PROJECT_NAME="seaweedfs-rdma-mount"
|
|
|
|
# Function to show usage
|
|
show_usage() {
|
|
echo -e "${BLUE}🚀 SeaweedFS RDMA Mount Test Runner${NC}"
|
|
echo "===================================="
|
|
echo ""
|
|
echo "Usage: $0 [COMMAND] [OPTIONS]"
|
|
echo ""
|
|
echo "Commands:"
|
|
echo " start Start the RDMA mount environment"
|
|
echo " stop Stop and cleanup the environment"
|
|
echo " restart Restart the environment"
|
|
echo " status Show status of all services"
|
|
echo " logs [service] Show logs for all services or specific service"
|
|
echo " test Run integration tests"
|
|
echo " perf Run performance tests"
|
|
echo " shell Open shell in mount container"
|
|
echo " cleanup Full cleanup including volumes"
|
|
echo ""
|
|
echo "Services:"
|
|
echo " seaweedfs-master SeaweedFS master server"
|
|
echo " seaweedfs-volume SeaweedFS volume server"
|
|
echo " seaweedfs-filer SeaweedFS filer server"
|
|
echo " rdma-engine RDMA engine (Rust)"
|
|
echo " rdma-sidecar RDMA sidecar (Go)"
|
|
echo " seaweedfs-mount SeaweedFS mount with RDMA"
|
|
echo ""
|
|
echo "Examples:"
|
|
echo " $0 start # Start all services"
|
|
echo " $0 logs seaweedfs-mount # Show mount logs"
|
|
echo " $0 test # Run integration tests"
|
|
echo " $0 perf # Run performance tests"
|
|
echo " $0 shell # Open shell in mount container"
|
|
}
|
|
|
|
# Function to check if Docker Compose is available
|
|
check_docker_compose() {
|
|
if ! command -v docker-compose >/dev/null 2>&1 && ! docker compose version >/dev/null 2>&1; then
|
|
echo -e "${RED}❌ Docker Compose is not available${NC}"
|
|
echo "Please install Docker Compose to continue"
|
|
exit 1
|
|
fi
|
|
|
|
# Use docker compose if available, otherwise docker-compose
|
|
if docker compose version >/dev/null 2>&1; then
|
|
DOCKER_COMPOSE="docker compose"
|
|
else
|
|
DOCKER_COMPOSE="docker-compose"
|
|
fi
|
|
}
|
|
|
|
# Function to build required images
|
|
build_images() {
|
|
echo -e "${BLUE}🔨 Building required Docker images...${NC}"
|
|
|
|
# Build SeaweedFS binary first
|
|
echo "Building SeaweedFS binary..."
|
|
cd ..
|
|
make
|
|
cd seaweedfs-rdma-sidecar
|
|
|
|
# Copy binary for Docker builds
|
|
mkdir -p bin
|
|
if [[ -f "../weed" ]]; then
|
|
cp ../weed bin/
|
|
elif [[ -f "../bin/weed" ]]; then
|
|
cp ../bin/weed bin/
|
|
elif [[ -f "../build/weed" ]]; then
|
|
cp ../build/weed bin/
|
|
else
|
|
echo "Error: Cannot find weed binary"
|
|
find .. -name "weed" -type f
|
|
exit 1
|
|
fi
|
|
|
|
# Build RDMA sidecar
|
|
echo "Building RDMA sidecar..."
|
|
go build -o bin/demo-server cmd/sidecar/main.go
|
|
|
|
# Build Docker images
|
|
$DOCKER_COMPOSE -f "$COMPOSE_FILE" -p "$PROJECT_NAME" build
|
|
|
|
echo -e "${GREEN}✅ Images built successfully${NC}"
|
|
}
|
|
|
|
# Function to start services
|
|
start_services() {
|
|
echo -e "${BLUE}🚀 Starting SeaweedFS RDMA Mount environment...${NC}"
|
|
|
|
# Build images if needed
|
|
if [[ ! -f "bin/weed" ]] || [[ ! -f "bin/demo-server" ]]; then
|
|
build_images
|
|
fi
|
|
|
|
# Start services
|
|
$DOCKER_COMPOSE -f "$COMPOSE_FILE" -p "$PROJECT_NAME" up -d
|
|
|
|
echo -e "${GREEN}✅ Services started${NC}"
|
|
echo ""
|
|
echo "Services are starting up. Use '$0 status' to check their status."
|
|
echo "Use '$0 logs' to see the logs."
|
|
}
|
|
|
|
# Function to stop services
|
|
stop_services() {
|
|
echo -e "${BLUE}🛑 Stopping SeaweedFS RDMA Mount environment...${NC}"
|
|
|
|
$DOCKER_COMPOSE -f "$COMPOSE_FILE" -p "$PROJECT_NAME" down
|
|
|
|
echo -e "${GREEN}✅ Services stopped${NC}"
|
|
}
|
|
|
|
# Function to restart services
|
|
restart_services() {
|
|
echo -e "${BLUE}🔄 Restarting SeaweedFS RDMA Mount environment...${NC}"
|
|
|
|
stop_services
|
|
sleep 2
|
|
start_services
|
|
}
|
|
|
|
# Function to show status
|
|
show_status() {
|
|
echo -e "${BLUE}📊 Service Status${NC}"
|
|
echo "================"
|
|
|
|
$DOCKER_COMPOSE -f "$COMPOSE_FILE" -p "$PROJECT_NAME" ps
|
|
|
|
echo ""
|
|
echo -e "${BLUE}🔍 Health Checks${NC}"
|
|
echo "==============="
|
|
|
|
# Check individual services
|
|
check_service_health "SeaweedFS Master" "http://localhost:9333/cluster/status"
|
|
check_service_health "SeaweedFS Volume" "http://localhost:8080/status"
|
|
check_service_health "SeaweedFS Filer" "http://localhost:8888/"
|
|
check_service_health "RDMA Sidecar" "http://localhost:8081/health"
|
|
|
|
# Check mount status
|
|
echo -n "SeaweedFS Mount: "
|
|
if docker exec "${PROJECT_NAME}-seaweedfs-mount-1" mountpoint -q /mnt/seaweedfs 2>/dev/null; then
|
|
echo -e "${GREEN}✅ Mounted${NC}"
|
|
else
|
|
echo -e "${RED}❌ Not mounted${NC}"
|
|
fi
|
|
}
|
|
|
|
# Function to check service health
|
|
check_service_health() {
|
|
local service_name=$1
|
|
local health_url=$2
|
|
|
|
echo -n "$service_name: "
|
|
if curl -s "$health_url" >/dev/null 2>&1; then
|
|
echo -e "${GREEN}✅ Healthy${NC}"
|
|
else
|
|
echo -e "${RED}❌ Unhealthy${NC}"
|
|
fi
|
|
}
|
|
|
|
# Function to show logs
|
|
show_logs() {
|
|
local service=$1
|
|
|
|
if [[ -n "$service" ]]; then
|
|
echo -e "${BLUE}📋 Logs for $service${NC}"
|
|
echo "===================="
|
|
$DOCKER_COMPOSE -f "$COMPOSE_FILE" -p "$PROJECT_NAME" logs -f "$service"
|
|
else
|
|
echo -e "${BLUE}📋 Logs for all services${NC}"
|
|
echo "======================="
|
|
$DOCKER_COMPOSE -f "$COMPOSE_FILE" -p "$PROJECT_NAME" logs -f
|
|
fi
|
|
}
|
|
|
|
# Function to run integration tests
|
|
run_integration_tests() {
|
|
echo -e "${BLUE}🧪 Running integration tests...${NC}"
|
|
|
|
# Make sure services are running
|
|
if ! $DOCKER_COMPOSE -f "$COMPOSE_FILE" -p "$PROJECT_NAME" ps | grep -q "Up"; then
|
|
echo -e "${RED}❌ Services are not running. Start them first with '$0 start'${NC}"
|
|
exit 1
|
|
fi
|
|
|
|
# Run integration tests
|
|
$DOCKER_COMPOSE -f "$COMPOSE_FILE" -p "$PROJECT_NAME" --profile test run --rm integration-test
|
|
|
|
# Show results
|
|
if [[ -d "./test-results" ]]; then
|
|
echo -e "${BLUE}📊 Test Results${NC}"
|
|
echo "==============="
|
|
|
|
if [[ -f "./test-results/overall.result" ]]; then
|
|
local result
|
|
result=$(cat "./test-results/overall.result")
|
|
if [[ "$result" == "SUCCESS" ]]; then
|
|
echo -e "${GREEN}🎉 ALL TESTS PASSED!${NC}"
|
|
else
|
|
echo -e "${RED}💥 SOME TESTS FAILED!${NC}"
|
|
fi
|
|
fi
|
|
|
|
echo ""
|
|
echo "Detailed results available in: ./test-results/"
|
|
ls -la ./test-results/
|
|
fi
|
|
}
|
|
|
|
# Function to run performance tests
|
|
run_performance_tests() {
|
|
echo -e "${BLUE}🏁 Running performance tests...${NC}"
|
|
|
|
# Make sure services are running
|
|
if ! $DOCKER_COMPOSE -f "$COMPOSE_FILE" -p "$PROJECT_NAME" ps | grep -q "Up"; then
|
|
echo -e "${RED}❌ Services are not running. Start them first with '$0 start'${NC}"
|
|
exit 1
|
|
fi
|
|
|
|
# Run performance tests
|
|
$DOCKER_COMPOSE -f "$COMPOSE_FILE" -p "$PROJECT_NAME" --profile performance run --rm performance-test
|
|
|
|
# Show results
|
|
if [[ -d "./performance-results" ]]; then
|
|
echo -e "${BLUE}📊 Performance Results${NC}"
|
|
echo "======================"
|
|
echo ""
|
|
echo "Results available in: ./performance-results/"
|
|
ls -la ./performance-results/
|
|
|
|
if [[ -f "./performance-results/performance_report.html" ]]; then
|
|
echo ""
|
|
echo -e "${GREEN}📄 HTML Report: ./performance-results/performance_report.html${NC}"
|
|
fi
|
|
fi
|
|
}
|
|
|
|
# Function to open shell in mount container
|
|
open_shell() {
|
|
echo -e "${BLUE}🐚 Opening shell in mount container...${NC}"
|
|
|
|
if ! $DOCKER_COMPOSE -f "$COMPOSE_FILE" -p "$PROJECT_NAME" ps seaweedfs-mount | grep -q "Up"; then
|
|
echo -e "${RED}❌ Mount container is not running${NC}"
|
|
exit 1
|
|
fi
|
|
|
|
docker exec -it "${PROJECT_NAME}-seaweedfs-mount-1" /bin/bash
|
|
}
|
|
|
|
# Function to cleanup everything
|
|
cleanup_all() {
|
|
echo -e "${BLUE}🧹 Full cleanup...${NC}"
|
|
|
|
# Stop services
|
|
$DOCKER_COMPOSE -f "$COMPOSE_FILE" -p "$PROJECT_NAME" down -v --remove-orphans
|
|
|
|
# Remove images
|
|
echo "Removing Docker images..."
|
|
docker images | grep "$PROJECT_NAME" | awk '{print $3}' | xargs -r docker rmi -f
|
|
|
|
# Clean up local files
|
|
rm -rf bin/ test-results/ performance-results/
|
|
|
|
echo -e "${GREEN}✅ Full cleanup completed${NC}"
|
|
}
|
|
|
|
# Main function
|
|
main() {
|
|
local command=${1:-""}
|
|
|
|
# Check Docker Compose availability
|
|
check_docker_compose
|
|
|
|
case "$command" in
|
|
"start")
|
|
start_services
|
|
;;
|
|
"stop")
|
|
stop_services
|
|
;;
|
|
"restart")
|
|
restart_services
|
|
;;
|
|
"status")
|
|
show_status
|
|
;;
|
|
"logs")
|
|
show_logs "${2:-}"
|
|
;;
|
|
"test")
|
|
run_integration_tests
|
|
;;
|
|
"perf")
|
|
run_performance_tests
|
|
;;
|
|
"shell")
|
|
open_shell
|
|
;;
|
|
"cleanup")
|
|
cleanup_all
|
|
;;
|
|
"build")
|
|
build_images
|
|
;;
|
|
"help"|"-h"|"--help")
|
|
show_usage
|
|
;;
|
|
"")
|
|
show_usage
|
|
;;
|
|
*)
|
|
echo -e "${RED}❌ Unknown command: $command${NC}"
|
|
echo ""
|
|
show_usage
|
|
exit 1
|
|
;;
|
|
esac
|
|
}
|
|
|
|
# Run main function with all arguments
|
|
main "$@"
|