Dev 0.2.1 #30

Merged
LukeGus merged 47 commits from dev-0.2.1 into main 2025-03-24 03:17:56 +00:00
Showing only changes of commit c8b583607a - Show all commits
+69 -29
View File
@@ -6,43 +6,79 @@ mkdir -p /data/db /var/log/mongodb /var/run/mongodb
chown -R mongodb:mongodb /data/db /var/log/mongodb /var/run/mongodb chown -R mongodb:mongodb /data/db /var/log/mongodb /var/run/mongodb
chmod 755 /data/db /var/log/mongodb /var/run/mongodb chmod 755 /data/db /var/log/mongodb /var/run/mongodb
# Check if we need to migrate from MongoDB 5.0 # Function to check MongoDB version
check_mongo_version() {
echo "Checking MongoDB version..."
if [ -f "/data/db/diagnostic.data/metrics.2" ] || [ -f "/data/db/WiredTiger.wt" ]; then if [ -f "/data/db/diagnostic.data/metrics.2" ] || [ -f "/data/db/WiredTiger.wt" ]; then
echo "Existing MongoDB data detected, checking version..." echo "Existing MongoDB data detected, attempting migration..."
# Start MongoDB temporarily with --repair to handle version mismatch # Clear any existing mongod lock file
gosu mongodb mongod --dbpath $MONGODB_DATA_DIR --logpath $MONGODB_LOG_DIR/mongodb.log --repair rm -f /tmp/mongodb-27017.sock
rm -f /data/db/mongod.lock
# Start MongoDB with specific options for migration # Run repair first
echo "Starting MongoDB for migration..." echo "Running initial repair..."
gosu mongodb mongod --dbpath $MONGODB_DATA_DIR --logpath $MONGODB_LOG_DIR/mongodb.log --bind_ip 0.0.0.0 & gosu mongodb mongod --dbpath $MONGODB_DATA_DIR --repair
# Start MongoDB in standalone mode for version check
echo "Starting MongoDB for version check..."
gosu mongodb mongod --dbpath $MONGODB_DATA_DIR --port 27017 --bind_ip 127.0.0.1 &
MONGO_PID=$! MONGO_PID=$!
# Wait for MongoDB to be ready # Wait for MongoDB to start
echo "Waiting for MongoDB to start for migration..." echo "Waiting for MongoDB to start..."
until gosu mongodb mongo --eval "print(\"waited for connection\")" > /dev/null 2>&1; do MAX_TRIES=30
sleep 1 COUNT=0
if ! kill -0 $MONGO_PID 2>/dev/null; then while ! gosu mongodb mongo --quiet --eval "db.version()" > /dev/null 2>&1; do
echo "MongoDB failed to start for migration. Checking logs:" sleep 2
cat $MONGODB_LOG_DIR/mongodb.log COUNT=$((COUNT + 1))
exit 1 if [ $COUNT -ge $MAX_TRIES ]; then
echo "Failed to start MongoDB after $MAX_TRIES attempts"
kill -9 $MONGO_PID 2>/dev/null || true
return 1
fi fi
done done
echo "Setting featureCompatibilityVersion to 4.4..." # Try to set compatibility version
# Try to set featureCompatibilityVersion echo "Attempting to set feature compatibility version..."
if gosu mongodb mongo --eval 'db.adminCommand({setFeatureCompatibilityVersion: "4.4"})' > /dev/null 2>&1; then if gosu mongodb mongo --quiet --eval 'db.adminCommand({setFeatureCompatibilityVersion: "4.4"})'; then
echo "Successfully set featureCompatibilityVersion to 4.4" echo "Successfully set feature compatibility version to 4.4"
else
echo "Failed to set featureCompatibilityVersion. Attempting repair..."
gosu mongodb mongod --dbpath $MONGODB_DATA_DIR --repair
fi
# Stop MongoDB after migration
kill $MONGO_PID kill $MONGO_PID
while kill -0 $MONGO_PID 2>/dev/null; do while kill -0 $MONGO_PID 2>/dev/null; do
sleep 1 sleep 1
done done
return 0
else
echo "Failed to set feature compatibility version"
kill $MONGO_PID
while kill -0 $MONGO_PID 2>/dev/null; do
sleep 1
done
return 1
fi
fi
return 0
}
# Try migration up to 3 times
MAX_MIGRATION_ATTEMPTS=3
MIGRATION_ATTEMPT=1
while [ $MIGRATION_ATTEMPT -le $MAX_MIGRATION_ATTEMPTS ]; do
echo "Migration attempt $MIGRATION_ATTEMPT of $MAX_MIGRATION_ATTEMPTS"
if check_mongo_version; then
break
fi
MIGRATION_ATTEMPT=$((MIGRATION_ATTEMPT + 1))
if [ $MIGRATION_ATTEMPT -le $MAX_MIGRATION_ATTEMPTS ]; then
echo "Migration failed, waiting before retry..."
sleep 5
fi
done
if [ $MIGRATION_ATTEMPT -gt $MAX_MIGRATION_ATTEMPTS ]; then
echo "Migration failed after $MAX_MIGRATION_ATTEMPTS attempts"
exit 1
fi fi
# Start MongoDB normally # Start MongoDB normally
@@ -52,13 +88,17 @@ MONGO_PID=$!
# Wait for MongoDB to be ready # Wait for MongoDB to be ready
echo "Waiting for MongoDB to start..." echo "Waiting for MongoDB to start..."
until gosu mongodb mongo --eval "print(\"waited for connection\")" > /dev/null 2>&1; do MAX_TRIES=30
sleep 0.5 COUNT=0
if ! kill -0 $MONGO_PID 2>/dev/null; then while ! gosu mongodb mongo --quiet --eval "db.version()" > /dev/null 2>&1; do
echo "MongoDB failed to start. Checking logs:" sleep 2
COUNT=$((COUNT + 1))
if [ $COUNT -ge $MAX_TRIES ]; then
echo "Failed to start MongoDB. Checking logs:"
cat $MONGODB_LOG_DIR/mongodb.log cat $MONGODB_LOG_DIR/mongodb.log
exit 1 exit 1
fi fi
echo "Waiting for MongoDB... (attempt $COUNT/$MAX_TRIES)"
done done
echo "MongoDB started successfully" echo "MongoDB started successfully"