好用的mysql备份工具(二)

日期: 2008-11-05 作者:扶凯 来源:TechTarget中国 英文

  mysqlhotcopy 备份出来的是整个数据库目录,使用时可以直接拷贝到 mysqld 指定的 datadir (在这里是 /var/lib/mysql/)目录下即可,同时要注意权限的问题,如下例:

    shell> cp -rf db_name /var/lib/mysql/

    shell> chown -R mysql:mysql /var/lib/mysql/ (将 db_name 目录的属主改成 mysqld 运行用户)

    本套备份策略只能恢复数据库到最后一次备份时的状态,要想在崩溃时丢失的数据尽量少应该更频繁的进行备份,要想恢复数据到崩溃时的状态请使用主从复制机制(replication)。


    小技巧:

    不想写密码在shell中的话,可以在root的home目录下建立一个.my.cnf文件,以便让mysqlhotcopy从中读取用户名/密码。
    [mysqlhotcopy]
    user=root
    password=YourPassword
    然后安全起见,chmod一下。
    chmod 600 ~/.my.cnf

    附:mysqlhotcopy常用参数:

    ·     –allowold  如果目标存在不放弃(加上一个_old后缀重新命名它)。
    ·     –checkpoint=db_name.tbl_name 在指定的db_name.tbl_name插入检查点条目。
    ·     —debug   启用调试输出。
    ·     –dryrun,-n  报告动作而不执行它们。
    ·     –flushlog  所有表锁定后刷新日志。
    ·     –keepold   完成后不删除以前(重新命名的)的目标。
    ·     — method=command  复制方法(cp或scp)。
    ·     –noindices  备份中不包括全部索引文件。这样使备份更小、更快。可以在以后用myisamchk -rq重新构建索引。
    ·     –password=password,-p password 当连接服务器时使用的密码。请注意该选项的密码值是不可选的,不象其它MySQL程序。
    ·     –port=port_num,-P port_num 当连接本地服务器时使用的TCP/IP端口号。
    ·     –quiet,-q  除了出现错误时保持沉默。
    ·     –regexp=expr  复制所有数据库名匹配给出的正则表达式的数据库。
    ·     –socket=path,-S path 用于连接的Unix套接字文件。
    ·     –suffix=str  所复制的数据库名的后缀。
    ·     –tmpdir=path  临时目录(代替/tmp)。
    ·     –user=user_name,-u user_name 当连接服务器时使用的MySQL用户名。

    mysqlhotcopy从选项文件读取[client]和[mysqlhotcopy]选项组。要想执行mysqlhotcopy,你必须可以访问备份的表文件,具有那些表的SELECT权限和RELOAD权限(以便能够执行FLUSH TABLES)。

我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。

我原创,你原创,我们的内容世界才会更加精彩!

【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】

微信公众号

TechTarget微信公众号二维码

TechTarget

官方微博

TechTarget中国官方微博二维码

TechTarget中国

电子邮件地址不会被公开。 必填项已用*标注

敬请读者发表评论,本站保留删除与本文无关和不雅评论的权力。

作者

扶凯
扶凯

相关推荐