-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathbackup_database.sh
More file actions
executable file
·65 lines (54 loc) · 1.63 KB
/
backup_database.sh
File metadata and controls
executable file
·65 lines (54 loc) · 1.63 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
#!/bin/bash
# Backup script for Odoo database
# Usage: ./backup_database.sh [database_name]
set -e
# Configuration
DB_NAME="${1:-gypex_dev}"
DB_USER="odoo"
DB_HOST="localhost"
BACKUP_DIR="/home/user/Documents/Odoo/backups"
TIMESTAMP=$(date +%Y%m%d_%H%M%S)
BACKUP_FILE="${BACKUP_DIR}/${DB_NAME}_backup_${TIMESTAMP}.dump"
# Colors for output
GREEN='\033[0;32m'
BLUE='\033[0;34m'
NC='\033[0m' # No Color
echo -e "${BLUE}========================================${NC}"
echo -e "${BLUE}Odoo Database Backup${NC}"
echo -e "${BLUE}========================================${NC}"
echo ""
echo "Database: ${DB_NAME}"
echo "Backup file: ${BACKUP_FILE}"
echo ""
# Create backup directory if it doesn't exist
mkdir -p "${BACKUP_DIR}"
# Check if database exists
if ! PGPASSWORD=odoo psql -h "${DB_HOST}" -U "${DB_USER}" -lqt | cut -d \| -f 1 | grep -qw "${DB_NAME}"; then
echo "ERROR: Database '${DB_NAME}' does not exist!"
exit 1
fi
echo "Starting backup..."
echo ""
# Perform backup
PGPASSWORD=odoo pg_dump -h "${DB_HOST}" -U "${DB_USER}" \
-F c \
-b \
-v \
-f "${BACKUP_FILE}" \
"${DB_NAME}" 2>&1 | grep -E "(dumping|ERROR|WARNING)" || true
# Check if backup was successful
if [ $? -eq 0 ] && [ -f "${BACKUP_FILE}" ]; then
BACKUP_SIZE=$(du -h "${BACKUP_FILE}" | cut -f1)
echo ""
echo -e "${GREEN}✓ Backup completed successfully!${NC}"
echo " File: ${BACKUP_FILE}"
echo " Size: ${BACKUP_SIZE}"
echo ""
# List recent backups
echo "Recent backups:"
ls -lht "${BACKUP_DIR}"/*.dump 2>/dev/null | head -5 | awk '{print " " $9 " (" $5 ")"}'
else
echo ""
echo "ERROR: Backup failed!"
exit 1
fi