Ho chiesto a questo stessa domanda sulla mailing list ufficiale di MongoDB . Hanno detto di non aggiornare più di 1 versione principale alla volta. (Le versioni principali sono:2.2, 2.4, 2.6, 3.0, 3.2, 3.4)
Non volevo seguire il normale processo di aggiornamento dell'installazione di ogni versione Solo per avviare mongod e quindi spegnerlo. Mi sembra che lascerebbe la cruft alle spalle e mi piace avere la mia infrastruttura che costruisce script e il controllo della versione. Quindi, ho deciso di lanciare nuove istanze EC2 con l'ultimo Ubuntu (dal momento che i miei server Mongo v2.4 erano anche 2 versioni LTS dietro) e l'ultimo MongoDB. Ho usato le immagini docker di versioni intermedie di MongoDB per eseguire gli aggiornamenti dei dati.
Il grosso della soluzione è questo:
# mongo.conf is using the default dbPath: /var/lib/mongodb
# this path is for temporary use by the mongo docker container
mkdir -p /data/db/dump
# see: https://hub.docker.com/_/mongo/ (search for /data/db)
# see: https://github.com/docker-library/mongo/blob/30d09dbd6343d3cbd1bbea2d6afde49f5d9a9295/3.4/Dockerfile#L59
cd /data/db
mongodump -h prodmongo.int
# Get major versions from https://hub.docker.com/r/library/mongo/tags/
step=0
for major_version in 2.6.12 3.0.14 3.2.11 3.4.1; do
sudo docker stop some-mongo || true
sudo docker rm some-mongo || true
sudo docker run --name some-mongo -v /data/db:/data/db -d mongo:$major_version
false; while [[ $? > 0 ]]; do
sleep 0.5
sudo docker exec -it some-mongo mongo --eval 'printjson((new Mongo()).getDBNames())'
done
if (( $step == 0 )); then
sudo docker exec -it some-mongo mongorestore /data/db/dump
fi
((step += 1))
done
# Finish up with docker
sudo rm -rf /data/db/dump/*
sudo docker exec -it some-mongo bash -c 'cd /data/db; mongodump'
sudo docker stop some-mongo
sudo docker rm some-mongo
# Load upgraded data into latest version of MongoDB (WiredTiger storage engine will be used)
mongorestore /data/db/dump
sudo rm -rf /data