linux怎么备份数据库

linux怎么备份数据库,第1张

一、 使用mysql相关命令进行简单的本地备份

1 mysqlldump命令

mysqldump 是采用SQL级别的备份机制,它将数据表导成 SQL 脚本文件,在不同的 MySQL 版本之间升级时相对比较合适,这也是最常用的备份方法。

使用 mysqldump进行备份非常简单,如果要备份数据库” db_backup ”,使用命令:

#mysqldump –u -p phpbb_db_backup > /usr/backups/mysql/db_backup2008-1-6sql

还可以使用gzip命令对备份文件进行压缩:

#mysqldump db_backup | gzip > /usr/backups/mysql/ db_backup2008-1-6sqlgz (备份后生成的sql不含建库语句!)

只备份一些频繁更新的数据库表:

## mysqldump sample_db articles comments links > /usr/backups/mysql/sample_dbart_comm_lin2008-1-6sql

上面的命令会备份articles, comments, 和links 三个表。

恢复数据使用命令:

#mysql –u -p db_backup </usr/backups/mysql/ db_backup2008-1-6sql

注意使用这个命令时必须保证数据库正在运行。

2 使用 SOURCE 语法

其实这不是标准的 SQL 语法,而是 mysql 客户端提供的功能,例如:

# SOURCE /tmp/db_namesql;

这里需要指定文件的绝对路径,并且必须是 mysqld 运行用户(例如 nobody)有权限读取的文件。

3 mysqlhotcopy备份

mysqlhotcopy 只能用于备份 MyISAM,并且只能运行在 linux 和Unix 和 NetWare 系统上。mysqlhotcopy 支持一次性拷贝多个数据库,同时还支持正则表达。以下是几个例子:

#mysqlhotcopy -h=localhost -u=goodcjh -p=goodcjh db_name /tmp

(把数据库目录 db_name 拷贝到 /tmp 下)

注意,想要使用 mysqlhotcopy,必须要有 SELECT、RELOAD(要执行 FLUSH TABLES) 权限,并且还必须要能够有读取 datadir/db_name 目录的权限。

还原数据库方法:

mysqlhotcopy 备份出来的是整个数据库目录,使用时可以直接拷贝到 mysqld 指定的 目录 (在这里是 /usr/local/mysql/data/)目录下即可,同时要注意权限的问题,另外首先应当删除数据库旧副本如下例:

# /bin/rm -rf /mysql-backup///old

关闭mysql 服务器、复制文件、查询启动mysql服务器的三个步骤:

# /etc/initd/mysqld stop

Stopping MySQL: [ OK ]

# cp -af /mysql-backup/// /var/lib/mysql /

# /etc/initd/mysqld start

Starting MySQL: [ OK ]

#chown -R nobody:nobody /usr/local/mysql/data/ (将 db_name 目录的属主改成 mysqld 运行用户)

二、使用网络备份

将MYSQL数据放在一台计算机上是不安全的,所以应当把数据备份到局域网中其他Linux计算机中。假设Mysql服务器IP地址是:19216813。局域网使用Linux的远程计算机IP地址是19216814;类似于windows的网络共享,UNIX(Linux)系统也有自己的网络共享,那就是NFS(网络文件系统),在linux客户端挂接(mount)NFS磁盘共享之前,必须先配置好NFS服务端。linux系统NFS服务端配置方法如下:

(1)修改 /etc/exports,增加共享目录

/export/home/sunky 19216814(rw)

/export/home/sunky1 (rw)

/export/home/sunky2 linux-client(rw)

1:打开的数据库的命令

mysql> use mysql

Database changed

2:查看数据库的命令

mysql> show databases;

3:查看数据库中表的命令

mysql> show tables;

4:查看表的详细结构

mysql> desc tablename;

5:新建数据库

mysql> create database school;

Query OK, 1 row affected (000 sec)

6:新建表

mysql> create table user01(

-> id varchar(20) NOT NULL,

-> userName varchar(10) NOT NULL,

-> age int(11) default'0',

-> sex char(2) NOT NULL default'm',

-> PRIMARY KEY (id)

-> )TYPE=InnoDB;

Query OK, 0 rows affected, 1 warning (002 sec)mysql>desc student;

7:插入

mysql> insert into student(id,stuName) values('1','tomcat');

Query OK, 1 row affected (000 sec)

8:删除

mysql> delete from student where id='1';

Query OK, 1 row affected (001 sec)

9:删除表中所有数据

mysql> truncate table student;

Query OK, 1 row affected (001 sec)

10:创建新用户并给予权限

mysql>grant all privileges on to dbsync@"127001" identified by "1234";

11:更改Mysql用户密码

c:\Mysql50\bin>mysqladmin -u root -p password 1234

Enter password:

备份数据库及表

我们用mysqldump命令来备份数据库

c:\mysql\bin\>mysqldump –u root –p 3306 mysql>d:\backupsql

执行此语句将把mydb 备份到D盘的backupsql文件中

备份多个数据库表

我现在负责的系统是每天打包数据库下的数据文件,scp到其他服务器上保存,一天一次;之前也考虑过用mysqldump来导出备份,不过这个会锁表,影响业务,而且时间比较长,占数据库IO,所以目前只有备份数据文件这个方法;仅供参考~有更好的方法也可以共享交流下~

以上就是关于linux怎么备份数据库全部的内容,包括:linux怎么备份数据库、在linux怎么备份数据库表、如何在linux下实现mysql数据库每天自动备份等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/10168201.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-06
下一篇 2023-05-06

发表评论

登录后才能评论

评论列表(0条)

保存