运维工作常用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`
相关推荐
IvanCodes几秒前
七、Sqoop Job:简化与自动化数据迁移任务及免密执行
大数据·数据库·hadoop·sqoop
Clownseven8 分钟前
SSH/RDP无法远程连接?腾讯云CVM及通用服务器连接失败原因与超全排查指南
服务器·ssh·腾讯云
ricky_fan9 分钟前
window下配置ssh免密登录服务器
运维·服务器·ssh
tonexuan10 分钟前
MySQL 8.0 绿色版安装和配置过程
数据库·mysql
JohnYan18 分钟前
工作笔记- 记一次MySQL数据移植表空间错误排除
数据库·后端·mysql
地衣君39 分钟前
Ubuntu 配置使用 zsh + 插件配置 + oh-my-zsh 美化过程
linux·运维·ubuntu
2401_8582861141 分钟前
OS11.【Linux】vim文本编辑器
linux·运维·服务器·编辑器·vim
AWS官方合作商44 分钟前
Amazon RDS on AWS Outposts:解锁本地化云数据库的混合云新体验
云原生·云计算·aws
我最厉害。,。1 小时前
Windows权限提升篇&数据库篇&MYSQL&MSSQL&ORACLE&自动化项目
数据库·mysql·sqlserver
朱包林1 小时前
day27-shell编程(自动化)
linux·运维·服务器·网络·shell脚本