运维工作常用Shell脚本(Commonly Used Shell Scripts for Operation and Maintenance Work)

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。

本人主要分享计算机核心技术:系统维护、数据库、网络安全、自动化运维、容器技术、云计算、人工智能、运维开发、算法结构、物联网、JAVA 、Python、PHP、C、C++等。
不同类型针对性训练,提升逻辑思维,剑指大厂,非常期待和您一起在这个小小的网络世界里共同探索、学习和成长。

运维工作常用Shell脚本------建议收藏备用

Shell脚本是一种用于自动化执行Linux/Unix系统命令的程序脚本。它类似于Windows下的批处理脚本,但功能更强大,效率更高。Shell脚本通过将一系列命令预先放入一个文件中,方便一次性执行,主要用于系统管理和自动化任务‌。

Shell脚本的基本概念和用途

Shell脚本是一种命令语言和程序设计语言的结合体。它既可以交互式地解释和执行用户输入的命令,也可以作为程序设计语言使用,包含变量、参数和控制结构等‌。Shell脚本主要用于自动化完成以下任务:

  • ‌自动化安装和部署‌:如安装部署LAMP架构服务。
  • ‌系统管理‌:如批量添加用户。
  • ‌备份‌:如数据库定时备份。
  • ‌自动化分析‌:处理和分析数据等‌。

Shell脚本的执行方式

Shell脚本有两种执行方式:

  1. ‌交互式(Interactive)‌:用户输入一条命令,Shell解释执行一条。
  2. ‌批处理(Batch)‌:用户事先写一个Shell脚本,其中包含多条命令,Shell一次性执行完这些命令‌。

Shell脚本的常见用途和实例

Shell脚本广泛应用于系统管理、自动化任务、数据分析等领域。例如,自动化安装部署、系统备份、日志分析等。通过Shell脚本,可以大大提高工作效率,减少重复劳动‌。

Shell脚本的常见类型

常见的Shell解释器程序包括:

  • ‌bash‌:大多数Linux系统的默认Shell。
  • ‌ash‌:轻量级的Shell。
  • ‌ksh‌:Korn Shell,功能强大。
  • ‌csh‌:C Shell,适用于需要大量管道操作的场景。
  • ‌zsh‌:Z Shell,功能丰富‌。
    作为一名优秀的运维,掌握Shell脚本可是基操。今天就分享一些运维工作会用到的Shell脚本,开箱即用,太好用了~

1.Linux系统发送告警脚本

# yum install mailx

复制代码
`# vi /etc/mail.rc``set [email protected] smtp=smtp.163.com``set [email protected] smtp-auth-password=123456``set smtp-auth=login`2.MySQL数据库备份单循环
复制代码
`#!/bin/bash``DATE=$(date +%F_%H-%M-%S)``HOST=localhost``USER=backup``PASS=123.com``BACKUP_DIR=/data/db_backup``DB_LIST=$(mysql -h$HOST -u$USER -p$PASS -s -e "show databases;" 2>/dev/null``|egrep -v "Database|information_schema|mysql|performance_schema|sys")``for DB in $DB_LIST; do``BACKUP_NAME=$BACKUP_DIR/${DB}_${DATE}.sql``if ! mysqldump -h$HOST -u$USER -p$PASS -B $DB > $BACKUP_NAME 2>/dev/null;``then``echo "$BACKUP_NAME 备份失败!"``fi``done`3.查看网卡实时流量脚本
复制代码
`#!/bin/bash``NIC=$1``echo -e " In ------ Out"``while true; do``OLD_IN=$(awk '$0~"'$NIC'"{print $2}' /proc/net/dev)``OLD_OUT=$(awk '$0~"'$NIC'"{print $10}' /proc/net/dev)``sleep 1``NEW_IN=$(awk '$0~"'$NIC'"{print $2}' /proc/net/dev)``NEW_OUT=$(awk '$0~"'$NIC'"{print $10}' /proc/net/dev)``IN=$(printf "%.1f%s" "$((($NEW_IN-$OLD_IN)/1024))" "KB/s")``OUT=$(printf "%.1f%s" "$((($NEW_OUT-$OLD_OUT)/1024))" "KB/s")``echo "$IN $OUT"``sleep 1``done`
相关推荐
伤不起bb20 分钟前
MySQL 高可用
linux·运维·数据库·mysql·安全·高可用
whgjjim2 小时前
docker迅雷自定义端口号、登录用户名密码
运维·docker·容器
tmacfrank3 小时前
网络编程中的直接内存与零拷贝
java·linux·网络
Yushan Bai5 小时前
ORACLE RAC环境REDO日志量突然增加的分析
数据库·oracle
躺着听Jay5 小时前
Oracle-相关笔记
数据库·笔记·oracle
瀚高PG实验室6 小时前
连接指定数据库时提示not currently accepting connections
运维·数据库
QQ2740287566 小时前
Soundness Gitpod 部署教程
linux·运维·服务器·前端·chrome·web3
淡忘_cx6 小时前
【frp XTCP 穿透配置教程
运维
qwfys2006 小时前
How to configure Linux mint desktop
linux·desktop·configure·mint
南方以南_6 小时前
Ubuntu操作合集
linux·运维·ubuntu