While doing a MySQL dump is easy enough, I have a live dedicated MySQL server that I am wanting to setup replication on. To do this, I need dumps of the databases to import
1) first you need to see about your MySQL version. use at least 5.7 so it supports mult thread. Old versions use only 1 thread and is not a good idea at the same time using DB and doing mysqldump if you have large database.
2) Prefer to build your backup not in the same DB disc, because performanace of read/write, or maybe you need RAID 10.
3) mysqlbackup from MySQL Enterprise is better, but is paid, I dont know if it is an option to you.
4) Sometimes many tables dont need transaction, so use transaction only on tables you need
5) Transaction generally is necessary, use InnoDB format to better performanance and not use lock tables.
6) Some cases is better to do one program, so you can create your transaction only to read your tables without lock anyone, and test with some sleeps, and not to freeze your service.
You can prefix the mysqldump command with the following:
ionice -c3 nice -n19 mysqldump ...
Which will run it at low IO and CPU priority so should limit the impact of it.
Note, this will only delay the time between MySQL executing. The scripts themselves will still be as intensive as they were before, just with a longer break between scripts.
Use nice and gzip command to execute the command at lowest priority.
nice -n 10 ionice -c2 -n 7 mysqldump db-name | gzip > db-name.sql.gz
I have very large databases with tens of thousands of tables some of which have up to 5GB of data in 10's of millions of entries. (I run a popular service)... I've always had headaches when backing up these databases. Using default mysqldump it quickly spirals the server load out of control and locks up everything... affecting my users. Trying to stop the process can lead to crashed tables and lots of downtime during recovery of those tables.
I now use...
mysqldump -u USER -p --single-transaction --quick --lock-tables=false DATABASE | gzip > OUTPUT.gz
The mysqldump reference at dev.mysql.com even says...
To dump large tables, you should combine the --single-transaction option with --quick.
Says nothing about that being dependent on the database being InnoDB, mine are myISAM and this worked beautifully for me. Server load was almost completely unaffected and my service ran like a Rolex during the entire process. If you have large databases and backing them up is affecting your end user... this IS the solution. ;)
If using InnoDB tables, use the --single-transaction and --quick options for mysqldump
Besides the already mentioned solution of using --single-transaction
and --quick
, I would not directly pipe the result in gzip but first dump it as a .sql file, and then gzip it. (Use && instead of | )
The dump itself will be faster so lower downtime. (for what I tested it was double as fast)
So I would go for "&& gzip" instead of "| gzip"
Important: check for free disk space first with df -h
! since you will need more then piping | gzip.
mysqldump --single-transaction --quick -u user -p my_db_name > dump_name.sql && gzip dump_name.sql
-> which will also result in 1 file called dump_name.sql.gz