运维工作常用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`
相关推荐
jackzhuoa4 分钟前
mysql数据库之三范式
数据库·sql·mysql
HEX9CF5 分钟前
【Anaconda】Anaconda3 下载与安装教程(Ubuntu 22.04)
linux·运维·ubuntu
Moshow郑锴37 分钟前
neo4j如何存储关于liquidity structure的层次和关联结构
数据库·区块链·neo4j
shuxunAPI41 分钟前
身份证 OCR 识别 API 接口的应用场景
云计算·ocr·api·csdn开发云
leo_厉锵1 小时前
数据库DCL与DQL
数据库·sql·oracle
joker D8881 小时前
【CUDA】CUDA Hierarchy
linux·cuda·c/c++·并行计算
Tassel_YUE1 小时前
openEuler 22.03 使用cephadm安装部署ceph集群
运维·ceph·学习笔记·openeuler·技术分享·服务部署
APItesterCris1 小时前
对于大规模的淘宝API接口数据,有什么高效的处理方法?
linux·服务器·前端·数据库·windows
加洛斯2 小时前
SpringBoot小知识(3):热部署知识
运维·服务器·spring boot
苹果醋32 小时前
Springboot入门教程系列HelloWorld
java·运维·spring boot·mysql·nginx