Post

Backup & Restore a database

Backup & Restore a database

MySQL

Docker

Backup with mysqldump

👉 Backup the database from the local Docker container:

1
2
3
4
5
6
docker exec [mysql_container_id] sh -c 'exec mysqldump -u[user] -p[password] [database_name]' > backup-$(date +%y%m%d%H%M%S).sql

# example
# container name: 127c93385edc
# user: root, password: 123456, database name: db_test
docker exec 127c93385edc sh -c 'exec mysqldump -uroot -p123456 db_test' > /Users/lamngockhuong/develop/backup-$(date +%y%m%d%H%M%S).sql

👉 Backup the database from the remote MySQL database server:

1
2
3
4
docker exec [mysql_container_id] sh -c 'exec mysqldump -h[remote_host] --port=[port] -u[user] -p[password] [database_name]' > backup-$(date +%y%m%d%H%M%S).sql

# example
docker exec 127c93385edc sh -c 'exec mysqldump -h172.1.100.110 --port=3306 -uroot -p123456 db_test' > /Users/lamngockhuong/develop/backup-$(date +%y%m%d%H%M%S).sql

Restore with mysql

👉 Restore the database to the local Docker container:

1
2
3
4
docker exec -i [mysql_container_id] sh -c 'exec mysql -u[user] -p[password] [database_name]' < [file_name].sql

# example
docker exec -i 127c93385edc sh -c 'exec mysql -uroot -p123456 db_test' < /Users/lamngockhuong/develop/db_backup.sql

👉 Restore the database to the remote MySQL database server:

1
2
3
4
docker exec -i [mysql_container_id] sh -c 'exec mysql -h[remote_host] --port=[port] -u[user] -p[password] [database_name]' < [file_name].sql

# example
docker exec -i 127c93385edc sh -c 'exec mysql -h172.1.100.110 --port=3306 -uroot -p123456 db_test' < /Users/lamngockhuong/develop/db_backup.sql

PostgreSQL

Local PSQL

Backup with pg_dump

Example:

1
2
3
4
5
# Output: sql file
pg_dump -h 172.1.100.110 -p 5432 -U postgres_user -d database_name --no-owner --no-acl --inserts > db-backup-$(date +%y%m%d%H%M%S).sql

# Output: tar file
pg_dump -h 172.1.100.110 -p 5432 -U postgres_user -W -F tar database_name --no-owner --no-acl > db-backup-$(date +%y%m%d%H%M%S).tar

Restore with pg_restore

Example:

1
2
3
pg_restore -h 172.1.100.110 -p 5432 -U postgres_user -d database_name_new -f db-backup-240813063846.sql

pg_restore -h 172.1.100.110 -p 5432 -U postgres_user -d database_name_new db-backup-240813094030.tar

Docker

Backup with pg_dump

👉 Backup the database from the local Docker container:

1
2
3
4
docker exec -t --user [user] [postgresql_container_id] pg_dump -U [user] [database_name] > dump_$(date +%y%m%d%H%M%S).sql

# example
docker exec -t --user postgres 127c93385edc pg_dumpall -U postgres db_test > dump_$(date +%y%m%d%H%M%S).sql

👉 Backup the database from the remote PostgreSQL database server:

1
2
3
4
5
6
docker exec [postgresql_container_id] sh -c 'export PGPASSWORD='\''[password]'\'' && exec pg_dump -h [remote_host] -p [port] -U [user] -d [database_name]' > backup-$(date +%y%m%d%H%M%S).sql

# example
# container name: 127c93385edc
# user: root, password: AbC{4@8Z>)}mHutq, database name: db_test, host: 172.1.100.110, port: 5432
docker exec 127c93385edc sh -c 'export PGPASSWORD='\''AbC{4@8Z>)}mHutq'\'' && exec pg_dump -h 172.1.100.110 -p 5432 -U root -d db_test' > backup-$(date +%y%m%d%H%M%S).sql

Restore with psql

👉 Restore the database to the local Docker container:

1
2
3
4
cat [file_name].sql | docker exec -i [postgresql_container_id] psql -U [user] -d [database_name]

#example
cat dump.sql | docker exec -i 127c93385edc psql -U postgres -d db_test

👉 Restore the database to the remote PostgreSQL database server:

1
2
3
4
5
6
cat [file_name].sql | docker exec -i [postgresql_container_id] sh -c 'PGPASSWORD='\''[password]'\'' && exec psql -h [remote_host] -p [port] -U [user] -d [database_name]'

# example
# container name: 127c93385edc
# user: postgres, password: AbC{4@8Z>)}mHutq, database name: db_test, host: 172.1.100.110, port: 5432
cat dump.sql | docker exec -i 127c93385edc sh -c 'PGPASSWORD='\''AbC{4@8Z>)}mHutq'\'' && exec psql -h 172.1.100.110 -p 5432 -U postgres -d db_test'
This post is licensed under CC BY 4.0 by the author.