当前位置:首页 > CN2资讯 > 正文内容

shell脚本导出mysql指定表 shell脚本导入数据mysql

1天前CN2资讯


这是一个简单的MySQL数据库备份shell脚本,适用于单台Linux服务器或者VPS的mysql数据库备份工作,

工作原理是使用mysql的mysqldump工具来导出数据库为.sql文件,然后将所有导出的文件打包归档。

然后我们在shell脚本中使用 scp命令把备份文件复制到另外一台备份机器,由于scp每次传送文件要密码

因此我们需要使用 expect插件或者利用密钥。在这里介绍采用生成密钥对的方法。

1,生成密匙对,我用的是rsa的密钥。使用命令 "ssh-keygen -t rsa"

 生成的过程中提示输入密钥对保存位置及密码,直接回车,接受默认值就行了。  

其中公共密钥保存在 ~/.ssh/id_rsa.pub,私有密钥保存在 ~/.ssh/id_rsa 。

2,然后修改 .ssh 目录权限,chmod 755 ~/.ssh 。最后把 公共密钥复制到你要访问

的机器上去,并保存为:~/.ssh/authorized_keys 。

scp -P 1110 ~/.ssh/id_rsa.pub daniel@*.*.*.*:/home/daniel/.ssh/authorized_keys

(注意这里- P 为大写, 表示目标机器daniel 的ssh端口为1110,小写的p为源ssh端口,

修改ssh端口在文件/etc/ssh/sshd_config下 。)这里完成scp 脚本免密钥的方法介绍。

最后使用crontab定时执行脚本即可!

脚本如下:

#!/bin/bash # description: MySQL buckup shell script # author: Daniel # web site: http://home.ustc.edu.cn/~danewang/blog/ st=$(date +%s) USER="root" PASSWORD="*****"#用户名 DATABASE="myblogdb" #数据库用户密码 MAIL="abcd@"#mail BACKUP_DIR=/home/daniel/data_backup/ #备份文件存储路径 LOGFILE=/home/daniel/data_backup/data_backup.log #日志文件路径 DATE=`date +%Y%m%d-%H%M`#用日期格式作为文件名 DUMPFILE=$DATE.sql ARCHIVE=$DATE.sql.tar.gz OPTIONS="-u$USER -p$PASSWORD $DATABASE" #判断备份文件存储目录是否存在,否则创建该目录 if [ ! -d $BACKUP_DIR ] then mkdir -p "$BACKUP_DIR" fi #开始备份之前,将备份信息头写入日记文件 echo " ">> $LOGFILE echo "--------------------" >> $LOGFILE echo "BACKUP DATE:" $(date +"%y-%m-%d %H:%M:%S") >> $LOGFILE echo "-------------------" >> $LOGFILE #切换至备份目录 cd $BACKUP_DIR mysqldump $OPTIONS > $DUMPFILE #判断数据库备份是否成功 if [[ $? == 0 ]] then tar czvf $ARCHIVE $DUMPFILE >> $LOGFILE 2>&1 echo "[$ARCHIVE] Backup Successful!" >> $LOGFILE rm -f $DUMPFILE #删除原始备份文件,只需保留备份压缩包 # 把压缩包文件备份到其他机器上。 scp -P 1110 $BACKUP_DIR$ARCHIVE ubuntu@*.*.*.*:/home/user/data_backup/ >> $LOGFILE 2>&1 else echo "Database Backup Fail!" >> $LOGFILE #备份失败后向管理者发送邮件提醒 mail -s "database:$DATABASE Daily Backup Fail!" $MAIL fi echo "Backup Process Done" #删除3天以上的备份文件 #Cleaning find $BACKUP_DIR -type f -mtime +2 -name "*.tar.gz" -exec rm -f {} \;

修改/etc/crontab

#vi /etc/crontab


在下面添加:


00 02 * * * user /data/backup/ # user 为当前系统的用户


注意/data/backup/为脚本的存放位置.

表示每天2点钟执行备份。

重新启动crond

# /etc/rc.d/init.d/crond restart



当scp备份到其他机器出现问题时 查看/var/log下的cron日志,/如果var/log下没有cron日志,

则需要:修改rsyslog,命令:sudo vim /etc/rsyslog.d/50-default.conf ,cron.* /var/log/cron.log

#将cron前面的注释符去掉 ,重启rsyslog ,命令:sudo service rsyslog restart,可以查看crontab

日志。


less /var/log/cron.log , crontab问题定位。

注意命令,格式:command > file 2>&1

2>&1 是将错误输出重定向到标准输出。 然后将标准输入重定向到文件file。&1 表示的是文件描述1,

表示标准输出,如果这里少了&就成了数字1,就表示重定向到文件1。

 这句命令的意思:首先是command > file将标准输出重定向到file中, 2>&1 是标准错误拷贝了标准

输出,也就是同样被重定向到file中,最终结果就是标准输出和错误都被重定向到file中。









    你可能想看:

    扫描二维码推送至手机访问。

    版权声明:本文由皇冠云发布,如需转载请注明出处。

    本文链接:https://www.idchg.com/info/19871.html

    分享给朋友:

    “shell脚本导出mysql指定表 shell脚本导入数据mysql” 的相关文章

    香港虚拟主机CN2是什么牌子?解析优质香港虚拟主机的选择

    在全球化的今天,互联网已经成为商业和个人生活的indispensable工具。对于想要在香港或国际市场发展的企业或个人来说,选择一台高性能、高稳定的虚拟主机是至关重要的。而在众多虚拟主机品牌中,香港虚拟主机CN2因其卓越的性能和优质的网络连接而备受推崇。香港虚拟主机CN2到底是什么牌子?它又有哪些独...

    选择最佳Gigabit VPS托管服务指南

    当我第一次听说Gigabit VPS时,我很快意识到它不仅是一个技术术语,而是一个可以极大改进在线业务性能的工具。那么,Gigabit VPS究竟是什么呢?简而言之,Gigabit VPS意指那些配备每秒10千兆位网络连接的虚拟专用服务器。这种高带宽的连接速度,显然适合那些需要流畅流媒体、快速文件传...

    选择台湾VPS的优势与实用技巧分析

    在当今互联网迅速发展的时代,虚拟专用服务器(VPS)成为了众多企业和个人不二的选择。台湾VPS作为一个相对新兴的产品,凭借自己独特的地理位置和优异的技术性能,逐渐在市场上占据了一席之地。身为个人或企业,在选择服务器时,了解台湾VPS的基本概念及其优势无疑是一个明智的开始。 什么是VPS? VPS,即...

    如何查看域名是否被墙:检测工具与方法指南

    域名被墙是一个对很多网站管理员和用户来说都比较陌生的概念。简单来说,当一个网站的内容被认为敏感或者违反某些规定时,防火墙就会把这个域名屏蔽。即使用户通过输入域名试图访问,DNS 解析也许正常,但实际上网站却无法顺利加载。在国内用户访问国外网站或者国外用户尝试访问国内网站时,情况尤为明显,就好像在国际...

    如何使用DigitalOcean优惠码获取200美元免费额度

    DigitalOcean是一家备受赞誉的云计算服务提供商,专门致力于为开发者和初创公司提供一流的云基础设施解决方案。通过其简单易用的界面和高效的性能,DigitalOcean帮助用户轻松地部署和扩展应用程序。我在使用DigitalOcean时,深刻感受到了它为开发者量身定制的便捷性,毫无疑问,这使得...

    解决Windows无法使用复制粘贴功能的实用方法

    在计算机使用中,Windows的复制粘贴功能是我们高效工作与学习的得力助手。从文字处理到文件管理,无论是在文档编辑中提取关键信息,还是将图片或文件快速转移到其他地方,复制粘贴都简化了许多操作。它轻松地帮助我们完成任务,节省了宝贵的时间。 我经常在工作中使用复制粘贴,特别是在撰写报告或为项目汇总资料时...