|
| 1 | +#!/bin/bash |
| 2 | + |
| 3 | +function initStaticParams |
| 4 | +{ |
| 5 | + MONGODB_SERVER=$MONGODB_HOST |
| 6 | + MONOGDB_PORT=$MONGODB_PORT |
| 7 | + MONGODB_USER=NA |
| 8 | + MONGODB_PWD=NA |
| 9 | + OUTPUT_DIRECTORY=$BACKUP_DATA_PATH/mongodb-backup |
| 10 | + LOG_PATH=$OUTPUT_DIRECTORY/logs |
| 11 | + LOG_FILE="$LOG_PATH/backup.log" |
| 12 | + |
| 13 | + LOG_MESSAGE_ERROR=1 |
| 14 | + LOG_MESSAGE_WARN=2 |
| 15 | + LOG_MESSAGE_INFO=3 |
| 16 | + LOG_MESSAGE_DEBUG=4 |
| 17 | + LOG_LEVEL=$LOG_MESSAGE_DEBUG |
| 18 | + SCRIPT=`readlink -f ${BASH_SOURCE[0]}` |
| 19 | + ABSOLUTE_SCRIPT_PATH=$(cd `dirname "$SCRIPT"` && pwd) |
| 20 | +} |
| 21 | + |
| 22 | + |
| 23 | + |
| 24 | +function log |
| 25 | +{ |
| 26 | + MESSAGE_LEVEL=$1 |
| 27 | + shift |
| 28 | + MESSAGE="$@" |
| 29 | + |
| 30 | + if [ $MESSAGE_LEVEL -le $LOG_LEVEL ]; then |
| 31 | + echo "`date +'%Y-%m-%dT%H:%M:%S.%3N'` $MESSAGE" >> $LOG_FILE |
| 32 | + fi |
| 33 | +} |
| 34 | + |
| 35 | +initStaticParams |
| 36 | + |
| 37 | +mkdir -p $OUTPUT_DIRECTORY |
| 38 | +mkdir -p $LOG_PATH |
| 39 | + |
| 40 | +log $LOG_MESSAGE_INFO "[INFO] starting incremental backup of oplog" |
| 41 | + |
| 42 | + |
| 43 | +LAST_OPLOG_DUMP=`ls -t ${OUTPUT_DIRECTORY}/*.bson 2> /dev/null | head -1` |
| 44 | + |
| 45 | +if [ "$LAST_OPLOG_DUMP" != "" ]; then |
| 46 | + log $LOG_MESSAGE_DEBUG "[DEBUG] last incremental oplog backup is $LAST_OPLOG_DUMP" |
| 47 | + LAST_OPLOG_ENTRY=`bsondump ${LAST_OPLOG_DUMP} 2>> $LOG_FILE | grep ts | tail -1` |
| 48 | + if [ "$LAST_OPLOG_ENTRY" == "" ]; then |
| 49 | + log $LOG_MESSAGE_ERROR "[ERROR] evaluating last backuped oplog entry with bsondump failed" |
| 50 | + exit 1 |
| 51 | + else |
| 52 | + TIMESTAMP_LAST_OPLOG_ENTRY=`echo $LAST_OPLOG_ENTRY | jq '.ts[].t'` |
| 53 | + INC_NUMBER_LAST_OPLOG_ENTRY=`echo $LAST_OPLOG_ENTRY | jq '.ts[].i'` |
| 54 | + START_TIMESTAMP="Timestamp( ${TIMESTAMP_LAST_OPLOG_ENTRY}, ${INC_NUMBER_LAST_OPLOG_ENTRY} )" |
| 55 | + log $LOG_MESSAGE_DEBUG "[DEBUG] dumping everything newer than $START_TIMESTAMP" |
| 56 | + fi |
| 57 | + log $LOG_MESSAGE_DEBUG "[DEBUG] last backuped oplog entry: $LAST_OPLOG_ENTRY" |
| 58 | +else |
| 59 | + log $LOG_MESSAGE_WARN "[WARN] no backuped oplog available. creating initial backup" |
| 60 | +fi |
| 61 | + |
| 62 | +if [ "$LAST_OPLOG_ENTRY" != "" ]; then |
| 63 | + mongodump -h $MONGODB_SERVER --authenticationDatabase=admin -d local -c oplog.rs --query "{ \"ts\" : { \"\$gt\" : $START_TIMESTAMP } }" -o - > ${OUTPUT_DIRECTORY}/${TIMESTAMP_LAST_OPLOG_ENTRY}_${INC_NUMBER_LAST_OPLOG_ENTRY}_oplog.bson 2>> $LOG_FILE |
| 64 | + RET_CODE=$? |
| 65 | +else |
| 66 | + TIMESTAMP_LAST_OPLOG_ENTRY=0000000000 |
| 67 | + INC_NUMBER_LAST_OPLOG_ENTRY=0 |
| 68 | + mongodump -h $MONGODB_SERVER --authenticationDatabase=admin -d local -c oplog.rs -o - > ${OUTPUT_DIRECTORY}/${TIMESTAMP_LAST_OPLOG_ENTRY}_${INC_NUMBER_LAST_OPLOG_ENTRY}_oplog.bson 2>> $LOG_FILE |
| 69 | + RET_CODE=$? |
| 70 | +fi |
| 71 | + |
| 72 | +if [ $RET_CODE -gt 0 ]; then |
| 73 | + log $LOG_MESSAGE_ERROR "[ERROR] incremental backup of oplog with mongodump failed with return code $RET_CODE" |
| 74 | +fi |
| 75 | + |
| 76 | +FILESIZE=`stat --printf="%s" ${OUTPUT_DIRECTORY}/${TIMESTAMP_LAST_OPLOG_ENTRY}_${INC_NUMBER_LAST_OPLOG_ENTRY}_oplog.bson` |
| 77 | + |
| 78 | +if [ $FILESIZE -eq 0 ]; then |
| 79 | + log $LOG_MESSAGE_WARN "[WARN] no documents have been dumped with incremental backup (no changes in mongodb since last backup?). Deleting ${OUTPUT_DIRECTORY}/${TIMESTAMP_LAST_OPLOG_ENTRY}_${INC_NUMBER_LAST_OPLOG_ENTRY}_oplog.bson" |
| 80 | + rm -f ${OUTPUT_DIRECTORY}/${TIMESTAMP_LAST_OPLOG_ENTRY}_${INC_NUMBER_LAST_OPLOG_ENTRY}_oplog.bson |
| 81 | +else |
| 82 | + log $LOG_MESSAGE_INFO "[INFO] finished incremental backup of oplog to ${OUTPUT_DIRECTORY}/${TIMESTAMP_LAST_OPLOG_ENTRY}_${INC_NUMBER_LAST_OPLOG_ENTRY}_oplog.bson" |
| 83 | +fi |
0 commit comments