Linux(CentOS)运维脚本工具集合

使用说明

备份指定目录

# 备份指定目录文件到指定目录,备份文件名称为:备份目录最后一层目录+"_"+日期.tar.gz
# 第一个参数:backdir 第二参数:备份文件保存目录 第三个参数:备份目录/文件
sh script.sh backdir /root/ /home

查看CPU、磁盘、内存使用率

sh script.sh baseinfo

返回结果

2023-04-03 13:08:44 CPU usage: 0.0, Memory usage: 9.39%, Disk usage: 19%

显示基础信息-详细

sh script.sh info

查看进程pid,启动时间,持续执行时间

sh script.sh pstime 进程名/id

根据进程id查看工作目录

sh script.sh psdir 15008

清除Linux系统占用缓存

sh script.sh dropCache

查看端口是否使用

# 第一个参数脚本名称 ,第二个参数ip,第三个参数端口
sh scripte.sh pint-port

demo:

sh scripte.sh pint-port
> 端口 80 无法访问 127.0.0.1

查看进程使用的端口

sh scripte.sh processor-port 进程信息

demo

sh 1.sh processor-port 15008
-------------------------------------------------
所有进程ID:14746 14749 15008
-------------------------------------------------
进程ID:14746
进程 15008 没有占用任何端口。
-------------------------------------------------
进程ID:14749
进程 15008 没有占用任何端口。
-------------------------------------------------
进程ID:15008
进程 15008 占用的端口号:1234
12345
16798
25333
50052
5678
-------------------------------------------------

查看端口所在进程

sh scripte.sh processor-port 5678

demo

sh scripte.sh processor-port 5678
> 端口  对应的进程是 java,PID 是 15008。

查看目录下各目录占用空间以及最大文件或目录

 sh script.sh duh /var/lib

demo

# sh 1.sh duh /var/lib
28K     /var/lib/polkit-1
76K     /var/lib/systemd
692K    /var/lib/cloud
13M     /var/lib/yum
132M    /var/lib/rpm
25G     /var/lib
25G     /var/lib/clickhouse
占用存储空间最大的目录是:
25G     /var/lib/clickhouse

查看内存使用前十的进程

sh script.sh top-mem

查看CPU使用前十的进程

sh script.sh top-cpu

脚本内容

#!/bin/bash# 备份指定目录文件到指定目录,备份文件名称为:备份目录最后一层目录+"_"+日期.tar.gz
# 第一个参数:backdir 第二参数:备份文件保存目录 第三个参数:备份目录/文件
backdir(){# 备份文件保存目录BACKUP_DIR=`echo $2`# 备份目录SOURCE_DIR=`echo $3`FILE_NAME=`basename "$SOURCE_DIR"`# 备份文件名称BACKUP_FILE=$FILE_NAME\_$(date +%Y%m%d).tar.gz#如果备份文件保存目录不存在则创建if [ ! -d "$BACKUP_DIR" ]; thenmkdir -p $BACKUP_DIRfi# 创建备份文件tar -zcvPf $BACKUP_DIR/$BACKUP_FILE $SOURCE_DIR
}# 内存,cpu,磁盘使用
baseinfo(){# CPU usageCPU_USAGE=$(top -b -n 1 | grep "^%Cpu" | awk '{print $2}')# Memory usageMEM_USAGE=$(free | awk 'NR==2{printf "%.2f%%", $3/$2*100}')# Disk usageDISK_USAGE=$(df -h / | awk 'NR==2{print $5}')# Write results to log fileecho "$(date +"%Y-%m-%d %H:%M:%S") CPU usage: $CPU_USAGE, Memory usage: $MEM_USAGE, Disk usage: $DISK_USAGE" 
}# 开启防火墙
startFirewall(){# 获取 Linux 系统版本OS=$(awk -F= '/^NAME/{print $2}' /etc/os-release)# 根据系统版本执行相应的命令启动防火墙if [[ $OS == *"CentOS"* || $OS == *"Red Hat"* ]]; thensystemctl start firewalldsystemctl enable firewalldsystemctl start iptablessystemctl enable iptablessystemctl status iptablessystemctl status firewalldecho "Firewall has been started and enabled successfully."elif [[ $OS == *"Ubuntu"* || $OS == *"Debian"* ]]; thenufw enableecho "Firewall has been enabled successfully."elseecho "Unsupported operating system."exit 1fi
}
#关闭防火墙
stopFirewall(){# 获取 Linux 系统版本OS=$(awk -F= '/^NAME/{print $2}' /etc/os-release)# 根据系统版本执行相应的命令关闭防火墙if [[ $OS == *"CentOS"* || $OS == *"Red Hat"* ]]; thensystemctl stop firewalldsystemctl disable firewalldsystemctl stop iptablessystemctl disable iptablessystemctl status iptablessystemctl status firewalldecho "Firewall has been stopped and disabled successfully."elif [[ $OS == *"Ubuntu"* || $OS == *"Debian"* ]]; thenufw disableecho "Firewall has been disabled successfully."elseecho "Unsupported operating system."exit 1fi
}# 查看进程pid,启动时间,持续执行时间
pstime(){ps -eo pid,lstart,etime,cmd | grep $2
}# 根据进程ID查看进程工作目录
psdir(){ls -l /proc/$2/cwd 
}# 释放缓存
dropCache(){syncecho 3 > /proc/sys/vm/drop_caches
}# 第二个参数ip,第三个参数端口
pingPort(){# 定义IP地址和端口IP_ADDRESS=`echo $2`PORT=`echo $3`# 检查nc命令是否已经安装,如果未安装,则尝试安装if ! command -v nc &> /dev/null; thenif command -v apt-get &> /dev/null; thensudo apt-get update && sudo apt-get -y install netcatelif command -v yum &> /dev/null; thensudo yum install -y ncelseecho "无法自动安装nc命令,请手动安装后重试。"exit 1fifi# 使用nc命令检查IP地址和端口是否可用if nc -z -w 2 $IP_ADDRESS $PORT; thenecho "端口 $PORT 可以访问 $IP_ADDRESS"elseecho "端口 $PORT 无法访问 $IP_ADDRESS"fi
}# 查看进程使用的端口号
# 第二个参数出入安需要查询的进程,可以为pid,也可以为进程名称
catProcessorPort(){echo "-------------------------------------------------"PROCESS_NAME=`echo $2`# 使用pidof命令查找进程IDPID=$(pidof $PROCESS_NAME)# 如果找不到进程ID,则使用ps命令查找if [ -z "$PID" ]; thenPID=$(ps -ef | grep $PROCESS_NAME | grep -v grep | awk '{print $2}')fiecho 所有进程ID:$PID# 如果还是找不到进程ID,则输出错误信息并退出if [ -z "$PID" ]; thenecho "找不到进程 $PROCESS_NAME。"exit 1fifor PID2 in $PID; doecho "-------------------------------------------------"echo 进程ID:$PID2# 使用lsof命令查找进程占用的端口号PORTS=$(lsof -nP -p $PID2 | grep LISTEN | awk '{print $9}' | cut -d':' -f2 | sort -u)# 输出占用端口号if [ -n "$PORTS" ]; thenecho "进程 $PROCESS_NAME 占用的端口号:$PORTS"elseecho "进程 $PROCESS_NAME 没有占用任何端口。"fidoneecho "-------------------------------------------------"}# 查看使用端口的进程pid
# 第二个参数为端口号
catPortProcessor(){catPortProcessorPort=`echo $2`# 使用 lsof 命令查询端口号对应的进程pid=$(sudo lsof -t -i:$catPortProcessorPort)# 如果找到了进程,打印进程名称和 PIDif [ ! -z "$pid" ]; thenprocess_name=$(ps -p $pid -o comm=)echo "端口 $port 对应的进程是 $process_name,PID 是 $pid。"elseecho "端口 $port 没有被占用。"fi
}# 查看哪个目录占用磁盘空间大
# 第二个参数为:需要查看的目录
duh(){directory=`echo $2`# 遍历目录并计算大小du -h -d 1 $directory | sort -h# 输出占用存储空间最大的目录echo "占用存储空间最大的目录或文件是:"du -sh $directory/* | sort -hr | head -n 1
}# 使用内存最多的前十个进程
topMem(){echo "下面是 内存 占用率最高的前 10 个进程:"echosecho "进程ID 内存使用大小 启动命令"ps aux --sort=-%mem | head -n 11 | tail -n 10 | awk '{print $2,$6/1024"M",$11}'echos
}# 使用CPU最多的前十个进程
topCpu(){echo "下面是 CPU 占用率最高的前 10 个进程:"echosecho "进程ID cpu占用率 启动命令"ps aux --sort=-%cpu | head -n 11 | tail -n 10 | awk '{print $2,$3,$11}'echos
}# 查看有多少远程的 IP 在连接本机(不管是通过 ssh 还是 web 还是 ftp 都统计) 
# 使用 netstat ‐atn 可以查看本机所有连接的状态,‐a 查看所有,
# -t仅显示 tcp 连接的信息,‐n 数字格式显示
# Local Address(第四列是本机的 IP 和端口信息)
# Foreign Address(第五列是远程主机的 IP 和端口信息)
# 使用 awk 命令仅显示第 5 列数据,再显示第 1 列 IP 地址的信息
# sort 可以按数字大小排序,最后使用 uniq 将多余重复的删除,并统计重复的次数
connectIp(){echo "连接数量 来源IP端口"# 第一列是连接数量,第二列是连接ip:portnetstat -atn  |  awk  '{print $5}'  | awk  '{print $1}' | sort -nr  |  uniq -c
}# 查看网卡流量
iftop(){sudo yum -y install iftopecho "请手动输入命令查看流量:iftop -P"
}# 显示系统基础信息
info(){# 获取系统 CPU 数量cpu_logical_count=$(nproc)cpu_physical_count=$(grep "physical id" /proc/cpuinfo | sort -u | wc -l)# 获取系统内存总容量、已使用内存量和可用内存量mem_total=$(grep MemTotal /proc/meminfo | awk '{print $2}')mem_used=$(free -m | awk 'NR==2{print $3}')mem_available=$(free -m | awk 'NR==2{print $4}')# 获取系统磁盘总容量、已使用磁盘空间和可用磁盘空间disk_total=$(df -BG --total | awk 'END{print $2}')disk_used=$(df -BG --total | awk 'END{print $3}')disk_available=$(df -BG --total | awk 'END{print $4}')# 获取系统 CPU 使用率cpu_usage=$(top -bn1 | grep "Cpu(s)" | sed "s/.*, *\([0-9.]*\)%* id.*/\1/" | awk '{print 100 - $1"%"}')# 将容量单位转换为 GB#disk_total=$(echo "scale=2;$disk_total/1024" | bc)#disk_used=$(echo "scale=2;$disk_used/1024" | bc)# 显示基础监控信息echo "系统 CPU 数量(逻辑处理器数量):$cpu_logical_count"echo "系统 CPU 数量(物理处理器数量):$cpu_physical_count"echo "系统内存总容量:$((mem_total / 1024)) MB"echo "系统已使用内存量:$mem_used MB"echo "系统可用内存量:$mem_available MB"echo "系统磁盘总容量:$disk_total GB"echo "系统已使用磁盘空间:$disk_used GB"echo "系统可用磁盘空间:$disk_available GB"echo "系统 CPU 使用率:$cpu_usage"
}echos(){echo "-------------------------------------------------"
}case "$1" in'backdir')backdir $*;;'baseinfo')baseinfo;;'stopFirewall')stopFirewall;;'startFirewall')startFirewall;;'pstime')pstime $*;;'psdir')psdir $*;;'dropCache')dropCache;;'ping-port')pingPort $*;;'processor-port')catProcessorPort $*;;'port-processor')catPortProcessor $*;;'duh')duh $*;;'top-mem')topMem ;;'top-cpu')topCpu ;;'connect-ip')connectIp;;'iftop')iftop;;'info')info;;*)exit 1
esac

脚本一键应用

sudo curl -L http://linux.hadoop.wiki/jastool.sh -o /usr/bin/jastool && sudo chmod +x /usr/bin/jastool

调用方法

jastool inf

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/51031.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据可视化diff工具jsondiffpatch使用学习

1.jsondiffpatch 简介 jsondiffpatch 是一个用于比较和生成 JSON 数据差异的 JavaScript 库。它可以将两个 JSON 对象进行比较,并生成一个描述它们之间差异的 JSON 对象。这个差异对象可以用于多种用途,例如: 生成可视化的差异报告应用差异…

opencv-疲劳检测-眨眼检测

#导入工具包 from scipy.spatial import distance as dist from collections import OrderedDict import numpy as np import argparse import time import dlib import cv2FACIAL_LANDMARKS_68_IDXS OrderedDict([("mouth", (48, 68)),("right_eyebrow",…

matlab将数组值划分为两类

例如:大于0的处理为1,小于0的处理为-1. 当然,可以选择循环结构和选择结构,但是效率会很低。 这里直接使用逻辑语句完成。 % 不使用循环语句,将数组内值划分为两类 clc; clearvars; a[-0.1422 , -0.0433 , 0.1131 …

Leetcode每日一题:1267. 统计参与通信的服务器

原题 这里有一幅服务器分布图,服务器的位置标识在 m * n 的整数矩阵网格 grid 中,1 表示单元格上有服务器,0 表示没有。 如果两台服务器位于同一行或者同一列,我们就认为它们之间可以进行通信。 请你统计并返回能够与至少一台其…

基础论文学习(4)——CLIP

《Learning Transferable Visual Models From Natural Language Supervision》 CLIP的英文全称是Contrastive Language-Image Pre-training,即一种基于对比文本-图像对的预训练模型。CLIP是一种基于对比学习的多模态模型,与CV中的一些对比学习方法如moc…

【C语言练习】数组OJ题

目录 一.消失的数字思路1:思路2: 二.移除元素三.轮转数组四.删除有序数组中的重复项五.合并两个有序数组 一.消失的数字 题目: 思路1: 数组是从0加到N,所以把0到N的数加起来减去数组中的值,结果就是消失…

ssl卸载原理

SSL卸载,也称为SSL解密,是一种将SSL加密数据流卸成非加密的明文数据流的过程。SSL卸载通常在负载均衡器、代理服务器、WAF等设备中实现,可以提高传输效率和安全性。 SSL卸载的原理是将SSL数据流拦截下来,通过设备内置的证书进行解…

人工智能相关概念学习笔记

一.人工智能的概念 人工智能(artificial intelligence,AI)是利用数字计算机或者数字计算机控制的机器模拟,延伸和扩展人的智能,感知环境,获取知识并使用知识获取最佳结果的理论,方法技术及应用系统。人工…

多维时序 | MATLAB实现SCNGO-CNN-Attention多变量时间序列预测

多维时序 | MATLAB实现SCNGO-CNN-Attention多变量时间序列预测 目录 多维时序 | MATLAB实现SCNGO-CNN-Attention多变量时间序列预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 1.SCNGO-CNN-Attention超前24步多变量回归预测算法。 程序平台:无Attention适…

【MyBatis】:PageHelper分页插件与特殊字符处理

目录 一、PageHelper介绍 二、PageHelper使用 1. 导入pom依赖 2. Mybatis.cfg.xml 配置拦截器 3. 配置 Mapper.xml 4. 编写测试 三、特殊字符处理 1. 使用转义字符 2. 使用CDATA 区段 一、PageHelper介绍 PageHelper 是 Mybatis 的一个插件,这里就不扯了&a…

aardio的CS架构mysql数据表查询实例

import win.ui; /*DSG{{*/ var winform win.form(text"aardio form";right759;bottom479) winform.add( buttonAdd{cls"button";text"复制";left516;top442;right587;bottom473;z11}; buttonClose{cls"button";text"退出";…

多线程——学习记录2

目录 单例模式两种单例写法饿汉式和懒汉式的区别 RuntimeTimer 计时器两个线程间的通信关键点:wait()线程等待 和 notify()随机唤醒等待的线程; 三个或三个以上间的线程通信关键点:notifyAll()唤醒所有线程 线程间通信需要注意的问题JDK1.5的新特性互斥锁…

Java:ArrayList集合、LinkedList(链表)集合的底层原理及应用场景

ArrayList集合的底层原理及应用场景 LinkedList(链表)集合的底层原理及应用场景 单向链表 增加数据 删除数据 双向链表 LinkedList的应用场景之一:可以用来设计队列 入队 出队 LinkedList的应用场景之一:可以用来设计栈 压栈(push),addFirst…

Socket基本原理

一、简单介绍 Socket,又称套接字,是Linux跨进程通信(IPC,Inter Process Communication)方式的一种。相比于其他IPC方式,Socket牛逼在于可做到同一台主机内跨进程通信,不同主机间的跨进程通信。…

redis常用五种数据类型详解

目录 前言: string 相关命令 内部编码 应用场景 hash 相关命令 内部编码 应用场景 list 相关命令 内部编码 应用场景 set 相关命令 内部编码 应用场景 Zset 相关命令 内部编码 应用场景 渐进式遍历 前言: redis有多种数据类型&…

Spring Clould 网关 - Gateway

视频地址:微服务(SpringCloudRabbitMQDockerRedis搜索分布式) Gateway网关-网关作用介绍(P35) Spring Cloud Gateway 是 Spring Cloud 的一个全新项目,该项目是基于 Spring 5.0,Spring Boot 2…

BTP Integration Suite学习笔记 - (Unit4) Developing with SAP Integration Suite

详细指导还是要看官方文档 4. 云集成管理 4.1 云集成介绍 什么是云集成? 前三章讲了很多内容,但都不是最核心的,通常我们用CPI是让他实现原来PI/PO的功能的,是用来做集成的。这章才刚开始。 云集成有以下几个特性:…

【LeetCode-中等题】438. 找到字符串中所有字母异位词

题目 题解一&#xff1a;暴力排序 依次截取三为排序好的字符串拿出来比较 // 方法一&#xff0c;暴力排序List<Integer> res new ArrayList<Integer>();int n s.length();int k p.length();if (n < k) {return res;}char[] chars p.toCharArray();Arrays.s…

pdf太大怎么压缩大小?这样压缩文件很简单

工作和学习中&#xff0c;用到PDF文件的机会还是比较多的&#xff0c;但有时候PDF文件过大会给我们带来困扰&#xff0c;比如上传PDF文件时会因超出系统大小导致无法上传&#xff0c;这时候简单的解决方法就是压缩PDF文件&#xff0c;下面就来看看具体的操作方法吧~ 方法一&…

gradio使用transformer模块demo介绍1:Text Natural Language Processing

文章目录 文本生成 Text Generation自动完成 Autocomplete情感分析 Sentiment Analysis命名实体识别 Name Entity Recognition NER多语种翻译文本生成 Text Generation import gradio as gr from transformers import pipelinegenerator = pipeline(text-generation, model=&l…