云数据库 RDS是阿里云提供的即开即用的关系型数据库服务,兼容了MySQL、SQL Server、PostgreSQL、PPAS(高度兼容Oracle)四种数据库引擎。在传统数据库的基础上,阿里云RDS提供了强大丰富的功能从而保证了高可用性、高安全性以及高性能。此外,RDS还提供了诸多便利功能提升了RDS的易用性。
如今数据对每个用户来说都是非常宝贵的财产,在使用阿里云RDS产品过程中,用户对数据库误操作引起的损失可以通过数据恢复功能最大程度地减少。接下来,我们会针对怎么恢复阿里云RDS数据库,进行做如下操作(以下操作以MySQL为列,不同引擎的操作方式请参考阿里云官方文档):
http://www.percona.com/downloads/XtraBackup/XtraBackup-2.0.6/RPM/rhel6/x86_64/percona-xtrabackup-2.0.6-521.rhel6.x86_64.rpm
yum -y install perl perl-devel libaio libaio-devel perl-Time-HiRes perl-DBD-MySQL mysql-devel
rpm -ivh percona-xtrabackup-2.0.6-521.rhel6.x86_64.rpm
4.将hins190855_xtra_20150312120203.tar.gz解压到指定目录(不会自动新建子目录,要先设计好)
mkdir /home/mysql/mysqldb cd /home/mysql/mysqldb
tar -izxvf hins190855_xtra_20150312120203.tar.gz
1.innobackupex --defaults-file=./backup-my.cnf --apply-log ./
2.删除此目录下的mysql,重新生成mysql系统库从而拥有数据库的root权限
rm -rf mysql (这里删除mysql目录是为了以后连接数据库权限)
chown -R mysql:mysql /home/mysql/mysqldb/ (备份文件所属目录) 并检查文件所属为mysql用户
注意:我们需要配置my.cnf ,如果说你之前linux服务器就已经有一个实例,那么现在你还要创建一个实例(也就是一台多个mysql服务) /usr/local/lnmp/mysql/bin/mysql_install_db --user=mysql --datadir=/mysql2/
default-character-set = utf8
mysqld = /usr/local/lnmp/mysql/bin/mysqld_safe
mysqladmin = /usr/local/lnmp/mysql/bin/bin/mysqladmin
datadir = /date/lnmp/mysql
pid-file = /date/lnmp/mysql/mysql1.pid
log-error = /date/lnmp/log1/mysql_error.log
socket = /tmp/mysql2.sock
pid-file = /mysql2/mysql.pid
log-error = /date/lnmp/log1/mysql_error2.log
innodb_data_file_path=ibdata1:200M:autoextend
innodb_log_files_in_group=2
innodb_log_file_size=1048576000
(注:最后三行很重要,可在/mysql2/mysql-my.cnf中复制过来即可,不然innodb表打不开) /usr/local/lnmp/mysql/bin/mysqld_multi --defaults-file=/etc/my.cnf start 1
/usr/local/lnmp/mysql/bin/mysqld_multi --defaults-file=/etc/my.cnf start 2
kill -9 `ps -ef | grep 3307 | grep -v grep | awk '{print $2}' | xargs`
mysql -uroot -proot -S /tmp/mysql2.sock
grant all on *.* to root@'localhost' identified by 'password'
4.以上第3步是针对一台多个实例,如果就一个实例的话就不需要那么麻烦,直接进行第3步,如下:
default-character-set = utf8
#password = your_password
socket = /wdzj/lnmp/mysql/mysql.sock
# Here follows entries for some specific programs
socket = /wdzj/lnmp/mysql/mysql.sock
read_rnd_buffer_size = 512K
myisam_sort_buffer_size = 8M
datadir = /home/mysql/mysqldb
innodb_data_file_path=ibdata1:200M:autoextend
innodb_log_files_in_group=2
innodb_log_file_size=1048576000
./bin/mysqladmin -u root password 'linux'
grant all on *.* to root@'localhost' identified by 'linux' WITH GRANT OPTION;
grant all on *.* to root@'%' identified by 'linux' WITH GRANT OPTION;
grant all privileges on test.test to test@localhost identified by 'test' ;)