运维工作常用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 from=baojingtongzhi@163.com smtp=smtp.163.com``set smtp-auth-user=baojingtongzhi@163.com 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`
相关推荐
PAQQ10 小时前
解决 ubuntu 重启串口号变化
linux·运维·ubuntu
emma羊羊10 小时前
【SQL注入】延时盲注
数据库·sql·网络安全
dyxal11 小时前
linux系统安装wps
linux·运维·wps
啟明起鸣11 小时前
【网络编程】从与 TCP 服务器的对比中探讨出 UDP 协议服务器的并发方案(C 语言)
服务器·c语言·开发语言·网络·tcp/ip·udp
一叶飘零_sweeeet11 小时前
从 MySQL 到 TiDB:分布式数据库的无缝迁移与实战指南
数据库·mysql·tidb
大家的笔记本11 小时前
jetson orin super nano(arm linux系统)上读取大恒图像工业相机(型号MER-050-560U3C)教程
linux·arm开发·相机
九章云极AladdinEdu11 小时前
深度学习优化器进化史:从SGD到AdamW的原理与选择
linux·服务器·开发语言·网络·人工智能·深度学习·gpu算力
axban11 小时前
QT M/V架构开发实战:QStandardItemModel介绍
开发语言·数据库·qt
没学上了11 小时前
数据库建立库-Qt
数据库
Xxtaoaooo11 小时前
Nginx 502 网关错误:upstream 超时配置的踩坑与优化
运维·nginx·负载均衡·502错误·upstream超时