• mysql本地异地备份


    1.所有数据库一起备份

    数据库地址: 192.168.1.50

    异地服务器地址: 192.168.1.202


    192.168.1.50操作:

    生成ssh秘钥对

    ssh-keygen


    在192.168.1.202操作,确保192.168.1.50可以免密登录1.202

    scp root@192.168.1.50:/root/.ssh/id_rsa.pub /root/.ssh/

    cat /root/.ssh/id_rsa.pub >> /root/.ssh/authorized_keys

    rm -rf /root/.ssh/id_rsa.pub


    192.168.1.50操作:

    确保免密连接没问题

    ssh 192.168.1.202

    exit

    2.备份脚本

    mkdir -p /bak/mysqlbak

    cd /bak/mysqlbak

    vim bakmysql.sh

    #!/bin/bash
    #name:bakmysql.sh
    #This is a mysql backup
    #本地存放备份数据库目录
    backupdir=/bak/mysqlbak
    #如果文件夹不存在,创建文件夹
    if [ ! -d $backupdir ]; then
       mkdir $backupdir
    fi
    #定义时间
    time=` date +%Y%m%d%H `
    #备份所有数据库到本地
    /usr/local/mysql/bin/mysqldump  -uroot -pGZml136 --opt --all-databases  > $backupdir/$time-all.sql

    #备份单个数据库

    #mysqldump  -uroot –pGZml136  --databases auth  > $backupdir/$time-auth.sql
    #只保留7天前的数据
    find $backupdir -name "name_*.sql" -type f -mtime +7 -exec rm {} \; > /dev/null 2>&1
    #把数据备份到异机
    scp -r  $backupdir  root@192.168.1.202:/opt

    chmod +x  bakmysql.sh

    ./bakmysql.sh

    image

    3.登录数据库删除一个测试数据库

    mysql -uroot –p

    mysql> show databases;

    image

    里面是有表有数据的

    image

    删除 atuh 测试数据库

    4.还原数据库

    还原所有库

    mysql –uroot –pGZml136 < /bak/mysqlbak/2021122315-all.sql

    还原单个库

    mysql –uroot –pGZml136 auth  < /bak/mysqlbak/2021122315-auth.sql


    5.定时备份

    vim /etc/crontab

    30 2 * * * root  /bak/mysqlbak/bakmysql.sh

    或者

    crontab  -e

    30 2 * * * /usr/bin/sh /bak/mysqlbak/bakmysql.sh > /dev/null 2>&1

  • 相关阅读:
    设计模式-单列模式
    linux udp c/s
    linux 命令
    java String
    [转]Android进程间通信--消息机制及IPC机制实现
    Android入门:Activity四种启动模式
    CRT 重启Was
    jquery.cookie.js 使用
    div设置contentEditable="true"作为文本编辑器,定位光标解决办法
    居中展示图片
  • 原文地址:https://www.cnblogs.com/pengrj/p/15722540.html
Copyright © 2020-2023  润新知