Linux【实操篇】—— Shell函数、Shell编程综合案例(定时备份数据库)_shell 函数实例

1. 系统函数

2. 自定义函数

二、Shell 编程综合案例


一、函数

Shell 编程中的函数与其他语言一样,有系统函数和自定义函数两种。

1. 系统函数

函数一:basename - 返回完整路径最后一个 / 后的部分,常用于获取文件名。基本格式为:

basename pathname suffix

  • pathname 路径名,其实就是一个字符串,basename 命令会删除掉路径的所有前缀包括最后一个 / ,然后将字符串显示出来;
  • suffix 后缀,如果 suffix 被指定了,basename 会将路径名中的后缀也去掉;

案例:返回 /home/aaa/test.txt 的 test.txt 部分;

basename /home/aaa/test.txt

此时没有指定后缀,所以直接输出 test.txt;

若我们指定后缀 .txt,则路径名后的 .txt 会被去掉;

函数二:dirname - 返回完整路径最后一个 / 前面的部分,常用于返回路径部分。基本格式为:

dirname 文件绝对路径

  • 从给定的包含绝对路径的文件名中去除文件名,返回剩下的路径部分。

案例:返回 /home/aaa/test.txt 中的 /home/aaa;

dirname /home/aaa/test.txt

结果如下:

2. 自定义函数

自定义函数语法格式和调用方式如下;

#基本语法
function 函数名(){
    程序;
    return int;
}

#调用
函数名 实参值

案例:输入两个参数,计算它们的和;

#!/bin/bash
#定义函数
function getSum() {
        sum=$[$n1+$n2]
        echo "两数之和为:$sum"
}

#用户输入两个数
read -p "请输入n1:" n1
read -p "请输入n2:" n2

#调用函数
getSum $n1 $n2

运行结果如下:

二、Shell 编程综合案例

案例要求:

  1. 每天凌晨 6:30 备份数据库 mjjlinux 到 /data/backup/db 中;
  2. 备份开始和结束都要给出提示信息;
  3. 文件备份后以备份时间为文件名,并打包成 .tar.gz 格式,如 2022-5-31_223564.tar.gz;
  4. 在备份的同时,检查是否有 10 天前备份的数据库文件,有则将其删除。

实现步骤:

首先我们在 Linux 系统的 MySQL 数据库中建库 mjjlinux 和表 myolder,此处过程省略,结果如下;

为了便于 root 用户操作,我们在 /usr/sbin 目录下进行。进入 /usr/sbin 目录;

新建 shell 文件 mysql_db_backup.sh;

[root@majinjian bin]# vim mysql_db_backup.sh

编写程序,实现需求的各项基本功能;

#!/bin/bash

#备份目录
BACKUP=/data/backup/db

#获取当前时间
DATETIME=$(date +%Y-%m-%d_%H%M%S)
echo "当前时间:$DATETIME"

#数据库的地址
HOST=localhost
#数据库的用户名
DB_USER=root
#数据库密码
DB_pwd=majinjian
#要备份的数据库
DATABASE=mjjlinux


为了做好运维面试路上的助攻手,特整理了上百道 **【运维技术栈面试题集锦】** ,让你面试不慌心不跳,高薪offer怀里抱!

这次整理的面试题,**小到shell、MySQL,大到K8s等云原生技术栈,不仅适合运维新人入行面试需要,还适用于想提升进阶跳槽加薪的运维朋友。**

![](https://img-blog.csdnimg.cn/img_convert/9a447c9dba3421938c7cf7be23c9c7b8.png)

本份面试集锦涵盖了

*   **174 道运维工程师面试题**
*   **128道k8s面试题**
*   **108道shell脚本面试题**
*   **200道Linux面试题**
*   **51道docker面试题**
*   **35道Jenkis面试题**
*   **78道MongoDB面试题**
*   **17道ansible面试题**
*   **60道dubbo面试题**
*   **53道kafka面试**
*   **18道mysql面试题**
*   **40道nginx面试题**
*   **77道redis面试题**
*   **28道zookeeper**

**总计 1000+ 道面试题, 内容 又全含金量又高**

*   **174道运维工程师面试题**

> 1、什么是运维?

> 2、在工作中,运维人员经常需要跟运营人员打交道,请问运营人员是做什么工作的?

> 3、现在给你三百台服务器,你怎么对他们进行管理?

> 4、简述raid0 raid1raid5二种工作模式的工作原理及特点

> 5、LVS、Nginx、HAproxy有什么区别?工作中你怎么选择?

> 6、Squid、Varinsh和Nginx有什么区别,工作中你怎么选择?

> 7、Tomcat和Resin有什么区别,工作中你怎么选择?

> 8、什么是中间件?什么是jdk?

> 9、讲述一下Tomcat8005、8009、8080三个端口的含义?

> 10、什么叫CDN?

> 11、什么叫网站灰度发布?

> 12、简述DNS进行域名解析的过程?

> 13、RabbitMQ是什么东西?

> 14、讲一下Keepalived的工作原理?

> 15、讲述一下LVS三种模式的工作过程?

> 16、mysql的innodb如何定位锁问题,mysql如何减少主从复制延迟?

怎么选择?

> 8、什么是中间件?什么是jdk?

> 9、讲述一下Tomcat8005、8009、8080三个端口的含义?

> 10、什么叫CDN?

> 11、什么叫网站灰度发布?

> 12、简述DNS进行域名解析的过程?

> 13、RabbitMQ是什么东西?

> 14、讲一下Keepalived的工作原理?

> 15、讲述一下LVS三种模式的工作过程?

> 16、mysql的innodb如何定位锁问题,mysql如何减少主从复制延迟?

> 17、如何重置mysql root密码?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值