shell编程实战之网站文件及数据库文件的备份

文件备份的重要性不言而喻,定期备份是个好习惯,不管是网站文件还是日常生活的照片、视频等。不然等到数据丢失了,你就能体会数据找不回来的那种绝望了。笔者亲身经历过几次,最严重的一次是个人博客7个多月的数据全部丢失,那真是种欲哭无泪的感觉。

今天和大家来讲下如何在服务器端编写备份网站目录及数据库文件的脚本。首先需要先补充几个知识:

tar命令,文件的压缩打包

find命令,查找文件

bzip2,文件压缩

为了节省空间,我们经常会对目录文件做压缩并打包的操作。bzip2命令可以对文件进行压缩,但它不能对目录进行压缩,对目录则可以使用tar命令压缩打包。

因为数据库文件就是一个单独的sql文件,所以可以使用bzip2命令对其压缩。

mysqldump -u用户名 -p密码 --all-databases | bzip2 > 备份目录/文件名

而网站文件则需要使用tar命令来进行压缩。

豆包AI编程 豆包AI编程

豆包推出的AI编程助手

豆包AI编程 483 查看详情 豆包AI编程

tar -jcpf 备份目录/文件名  需备份的目录

虽然我们每天都会进行备份,但是我们只想保存最近七天的备份记录,7天前的备份数据自动删除。这里我们就需要使用find命令来找出7天前的备份文件,然后将其删除。

find 备份目录 -mtime +7 -type f -exec rm -f {} ;

下面开始正式编写shell脚本。首先,我们需要定义备份目录,如果备份目录不存在,则需要先创建目录。

WWW_DIR=/home/wwwrootBAK_DIR=/root/bakif [ ! -d $BAK_DIR ];then    mkdir $BAK_DIRfi

接下来 ,就是进行网站目录以及数据库文件的备份了

tar -jcpf $BAK_DIR/www_$(date +%Y%m%d).tar.bz2 $WWW_DIR 2>/dev/nullmysqldump -uroot -p123456 --all-databases | bzip2 > $BAK_DIR/all_database_$(date +%Y%m%d).sql

最后,只要删除七天前的备份数据即可

find $BAK_DIR -type f -mtime +7 -exec rm -f {} ;

下面贴出完整代码:

#!/bin/bash# 备份数据库文件及网站文件WWW_DIR=/home/wwwrootBAK_DIR=/root/bakif [ ! -d $BAK_DIR ];then    mkdir $BAK_DIRfi# 备份网站文件及数据库文件tar -jcpf $BAK_DIR/www_$(date +%Y%m%d).tar.bz2 $WWW_DIR 2>/dev/nullmysqldump -uroot -pGuiyuan#520@1314 --all-databases | bzip2 > $BAK_DIR/all_database_$(date +%Y%m%d).sql # 删除7天前的备份数据find $BAK_DIR -type f -mtime +7 -exec rm -f {} ;

最后,还是希望大家能养成备份的习惯。除了服务器上的每日备份,另外还是建议一个星期,从服务器上拷贝一份数据到本地磁盘,保证数据万无一失。

以上就是shell编程实战之网站文件及数据库文件的备份的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/548456.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月9日 18:56:12
下一篇 2025年11月9日 18:57:08

相关推荐

  • Linux下Python脚本操作的高级技巧

    Linux下Python脚本操作的高级技巧,需要具体代码示例 Python语言是一种简单易学、功能强大的脚本语言,它在Linux系统中的应用非常广泛。本文将介绍一些Linux下使用Python脚本进行高级操作的技巧,并提供具体的代码示例,帮助读者更好地理解和应用这些技巧。 使用管道和过滤器 在Lin…

    2025年12月13日
    000
  • linux怎么执行php脚本_linux系统中执行PHP脚本的命令与配置

    首先确认PHP已安装,使用php -v检查版本;若未安装,在Ubuntu/Debian中用sudo apt install php-cli php,在CentOS/RHEL中用sudo yum install php或sudo dnf install php;创建test.php文件并写入PHP代码…

    2025年12月12日
    000
  • PHP 如何与 shell 命令互动?

    php 与 shell 命令交互方法:exec() 函数:执行命令并获取输出。shell_exec() 函数:在独立 shell 进程中执行命令。popen() 函数:通过管道与命令双向通信。proc_open() 函数:提供了更高级的控制,可指定命令流。 PHP 如何与 Shell 命令互动? 在…

    2025年12月9日
    000
  • shell脚本基本命令有哪些

    shell脚本基本命令:1、Shell的echo指令与PHP的echo指令类似,都是用于字符串的输出;2、printf命令模仿C程序库里的【printf()】程序;3、test命令用于检查某个条件是否成立。 本教程操作环境:linux7.3系统,DELL G3电脑。 shell脚本基本命令: 1、e…

    2025年12月5日
    000
  • linux shell怎么判断文件是否存在

    在linux shell中,可以利用if语句和“-e filename”表达式来判断文件是否存在,具体语法“if [-e filename]; then echo “文件存在”; else echo “文件不存在”; fi”。 本教程操作环境:linu…

    2025年12月4日
    000
  • 操作mysql数据库的Shell脚本

    创建建表语句 %ign%ignore_a_1%re_pre_1% 批量插入数据脚本 #!/bin/bash #create by oldboy 20110319 #qq:31333741 MysqlLogin=”mysql -uroot -poldboy” #→定义登陆mysql的命令,方…

    数据库 2025年12月3日
    000
  • linux下MySQL主从同步监控shell脚本

    说明: 操作系统:CentOS 目的:定时监控MySQL主从数据库是否同步,如果不同步,记录故障时间,并执行命令使主从恢复同步状态 1、创建脚本文件 vi /home/crontab/check_mysql_slave.sh   #编辑,添加下面代码 #!/bin/sh # check_mysql_…

    2025年12月2日
    000
  • 使用mysql在终端执行sql并把结果写入文件的方法

    在终端使用mysql执行语句时,我们一般先进入mysql,然后再在里面执行sql语句。 例如: mysql -urootmysql> use mydb;mysql> select * from user;… 如果我们需要进行某些表的监控,并保存执行后的查询结果,需要手动复制到文件,这…

    2025年12月2日
    000
  • SQL语言如何构建自动化备份脚本 SQL语言在数据容灾中的定时任务实现

    自动化备份脚本的核心是结合sql备份命令与操作系统或数据库调度器,通过编写脚本并配置定时任务实现;2. 不同数据库需使用对应工具:sql server用t-sql脚本配合sql server agent,mysql和postgresql用mysqldump与pg_dump配合shell/batch脚…

    2025年12月1日 数据库
    100
  • Linux ZSH 更便捷的 shell 环境

    简介 zsh 是为交互式使用而设计的,与 bash 兼容的 shell,尽管它也是一种强大的脚本语言。zsh 融合了 bash、ksh 和 tcsh 的许多有用特性,并引入了许多独特的功能。 相较于 bash,zsh 具有以下优势: Tab 补全功能强大,支持命令、命令参数和文件路径的补全。丰富的插…

    2025年11月29日 运维
    000
  • VSCode的终端支持哪些Shell?

    VSCode支持多平台Shell,Windows可选cmd、PowerShell、WSL等,macOS支持bash、zsh、fish等,Linux兼容所有注册Shell,通过“Terminal: Select Default Profile”或settings.json配置默认终端。 VSCode的…

    2025年11月29日 开发工具
    000
  • MongoDB学习(三)MongoDB shell 命令行的使用

    首先要启动MongoDB shell工具,即bin下的mongo.exe 常用shell命令如下: 1、查询本地所有数据库名称 show dbs; 2、切换至指定数据库环境(若无指定的数据库,则创建新的库) use dbtest; 切换至dbtest库或创建名为dbtest的库 3、查询当前库下的所…

    2025年11月28日
    000
  • win11怎么设置环境变量 Win11添加系统Path路径与用户变量

    首先通过系统属性、命令提示符或PowerShell设置环境变量,具体步骤包括:进入系统设置→高级系统设置→环境变量,编辑Path或新建变量;或使用setx命令在cmd中添加;或用[Environment]::SetEnvironmentVariable在PowerShell中配置。 如果您需要在Wi…

    2025年11月28日 系统教程
    000
  • Linux Shell怎么用ssh命令统计分布式集群信息

    一、统计分布式集群信息的思路 用免密的远程登陆命令,实现一台机器访问其他集群的机器。因此想要实现有几个重要步骤: 学会shh的使用方法 实现免密登录 编写shell程序 二、SSH加密原理 非对称加密技术是一种加密和解密用的不同密钥的加密方法。其中RSA和DSA就是非对称加密方法。当然非对称加密算法…

    运维 2025年11月28日
    100
  • linux中的shell命令如何使用

    在本文中,我们将介绍linux shell中使用的部分基本命令。 查看和跳转命令 (1)pwd 当打开终端时,如果需要自己目前在哪一个目录,可以使用pwd命令,它返回一个绝对的路径(从根“/”开始的路径)。  (2)ls 使用“ls”命令知道您所在的目录处,都有哪些文件和文件夹。可以使用命令“ls …

    2025年11月28日 运维
    000
  • linux统计appche站点IP访问量的shell脚本怎么写

    经常需要根据ip地址统计apache站点访问量,最基本的脚本. 根据ip访问量降序排列: 复制代码 代码如下: #!/bin/bash#script_name: access_countacc_log=/usr/local/apache2/logs/access_log/bin/awk &#8216…

    运维 2025年11月28日
    000
  • linux之shell实现图书管理系统实例详解

    本文主要介绍了shell实现图书管理系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能帮助到大家更好的学习shell。 本文实例为大家分享了shell实现图书管理系统的具体代码,供大家参考,具体内容如下 #!/bin/bash #author:zhanghongjun #version:…

    2025年11月27日
    000
  • MYSQL数据库自动本地/异地双备份/MYSQL增量备份[连载之构建百万访问量电子商务网站]

    mysql数据库自动本地/异地双备份/mysql增量备份[连载之构建百万访问量电子商务网站]出处:http://jimmyli.blog.51cto.com/我站在巨人肩膀上JimmyLi作者:JimmyLi mysql数据库自动本地/异地双备份/mysql增量备份[连载之构建百万访问量电子商务网站…

    2025年11月27日 数据库
    000
  • linux怎么创建用户,添加及修改shell

    1、创建用户 useradd -d /test -s /bin/bash -m test -d:指定用户的家目录 -s:用户的登录shell -m:创建用户家目录 创建密码: passwd test然后输入两遍新密码 2、查看创建的用户 vim /etc/passwd 此文件中记录着所有用户的信息,…

    2025年11月27日 运维
    000
  • linux中shell的含义是什么

    %ign%ignore_a_1%re_a_1%中shell是系统的用户界面,实际上是一个命令解释器,它提供了用户与内核进行交互操作的一种接口,用于接收用户输入的命令并把它送入内核去执行。Shell有自己的编程语言用于对命令的编辑,允许用户编写由shell命令组成的程序,Shell编程语言具有普通编程…

    2025年11月26日
    100

发表回复

登录后才能评论
关注微信