较为全面的应用和主机巡检脚本

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 较为全面的应用和主机巡检脚本

脚本可能还有很多不足之处,请大家多提宝贵意见

#! /bin/bash

# Author zhh

NC='\033[0m'

GREEN='\033[0;32m'

RED='\033[0;31m'

YELLOW='\033[0;33m'

cyan='\033[0;36m'

yellow='\033[0;33m'

#Sectioning .........

echo -e "${YELLOW}---------------------------------------------------------------------------------------------------------------${NC}"

echo "Server details:"

echo -e "${YELLOW}---------------------------------------------------------------------------------------------------------------${NC}"

#fetching basic specs from the server(user,ip,os)

user=`whoami`

echo -e "${cyan}User:${NC} $user"

hostname=`hostname`

echo -e "${cyan}hostname:${NC} $hostname"

ip=`hostname -I`

echo -e "${cyan}IP address:${NC} $ip"

os=`cat /etc/os-release | grep 'NAME\|VERSION' | grep -v 'VERSION_ID' | grep -v 'PRETTY_NAME' | grep NAME`

echo -e "${cyan}OS:${NC} $os"

#Sectioning.....

echo -e "${YELLOW}---------------------------------------------------------------------------------------------------------------${NC}"

echo "Service status:"

echo -e "${YELLOW}---------------------------------------------------------------------------------------------------------------${NC}"

sleep 1

#checking tomcat status

echo -e "${yellow}1) Tomcat${NC}"

#grepping tomcat status from ps aux

pp=`ps aux | grep tomcat | grep "[D]java.util"`

if [[ $pp =~ "-Xms512M" ]];then

echo -e "  Status: ${GREEN}UP${NC}"

else

echo -e "  Status: ${RED}DOWN${NC}"

fi

echo ""

#function to check apache is running or not!

function apache(){

echo -e "${yellow}2) Apache-httpd${NC}"

#grepping apache status from ps aux

httpd=`ps aux | grep httpd | grep apache`

if [[ $httpd =~ "apache" ]];then

echo -e "  Status: ${GREEN}UP${NC}"

else

echo -e "  Status: ${RED}DOWN${NC}"

fi

}

#function to check elastic is running or not

function elastic(){

echo -e "${yellow}3) Elasticsearch${NC}"

#grepping elasticsearch status from ps aux

elastic=`ps aux | grep elasticsearch`

if [[ $elastic =~ "elastic+" ]];then

 echo -e "  Status: ${GREEN}UP${NC}"

else

echo -e "    Status: ${RED}DOWN${NC}"

fi

#function to check mysql is running or not

}

function mysql(){

echo -e "${yellow}4) Mysql${NC}"

#grepping mysql status from ps aux

mysql=`ps aux | grep mysqld`

if [[ $mysql =~ "mysqld" ]];then

echo -e "  Status: ${GREEN}UP${NC}"

else

echo -e "  Status: ${RED}DOWN${NC}"

fi

}

function tlq(){

echo -e "${yellow}5) tl${NC}"

tlq=`ps -ef | grep tl | grep -v grep | wc -l`

if [[ $tlq = 0 ]];then

echo -e "  Status: ${RED}DOWN${NC}"

else

echo -e "  Status: ${GREEN}UP${NC}"

fi

}

#calling functions

apache

echo ""

elastic

echo ""

mysql

echo ""

docker

echo ""

tlq

echo ""

#Sectioning............

#Fetching mem and cpu informations

echo -e "${YELLOW}---------------------------------------------------------------------------------------------------------------${NC}"

echo "Memory Details:"

echo -e "${YELLOW}---------------------------------------------------------------------------------------------------------------${NC}"

sleep 1

#view mem info

free -h

#get uptime details

uptime=$(uptime | awk '{print $3,$4}' | cut -f1 -d,)

echo -e "${cyan}System Uptime:${NC} :$uptime"

#Fetching the load average

loadaverage=$(top -n 1 -b | grep "load average:" | awk '{print $10 $11 $12}')

echo -e "${cyan}Load average:${NC}: $loadaverage"

echo -e "${cyan}The top 10 services with high resource usage are listed below.${NC}"

#Get top services with high resource utilization

ps -eo pid,ppid,cmd,%mem,%cpu --sort=-%mem | head

#sectioning...........

#Fetching server space details!

echo -e "${YELLOW}---------------------------------------------------------------------------------------------------------------${NC}"

echo "Server space Details:"

echo -e "${YELLOW}---------------------------------------------------------------------------------------------------------------${NC}"

#View disk space details

df -h

echo "----------------------------------------------------------------------------------------------------------------"

将该脚本转换为全局命令,将文件移动到 sbin 目录,并赋予执行权限。

mv /root/xunjian.sh /usr/sbin

chmod +x /usr/sbin/xunjian.sh

添加至别名里

cat /root/.bashrc

alias xunjian='sh /usr/sbin/xunjian.sh'

source .bashrc

这样就可以在 shell 的任何位置调用该脚本。

xunjian


如果能用得到,大家可以根据自己生产环境的实际情况进行修改,当然巡检后也可以输出text/html等文件格式便于查看。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3月前
系统巡检常用命令
系统巡检常用命令
|
4月前
|
运维 监控 Shell
利用Shell脚本编写局域网监控软件:实时监测主机连接情况
本文介绍了如何使用Shell脚本创建一个局域网监控工具,以实时检查主机连接状态。脚本包括扫描IP地址范围检测主机可达性及使用`netstat`监控ESTABLISHED连接。此外,还展示了如何每60秒将连接数数据自动提交到指定网站API,以便实时跟踪网络活动。这个自动化监控系统有助于提升网络安全性和故障排查效率。
277 0
|
监控
监控网卡实时流量脚本
监控网卡实时流量脚本
103 0
QGS
|
Oracle 关系型数据库 数据库
oracle数据库-简易巡检脚本
记oracle数据库-简易巡检脚本
QGS
272 0
oracle数据库-简易巡检脚本
QGS
|
关系型数据库 MySQL 数据库
mysql数据库巡检脚本
记mysql数据库巡检脚本
QGS
734 0
mysql数据库巡检脚本
|
监控 Shell
使用 Shell 脚本监控主机,实现主机性能监控
使用 Shell 脚本监控主机,实现主机性能监控
482 0
使用 Shell 脚本监控主机,实现主机性能监控
|
Python
python脚本基于主机系统探测信息搜集
python脚本基于主机系统探测信息搜集
189 0
python脚本基于主机系统探测信息搜集
|
监控 Shell
监控网卡实时流量shell脚本
监控网卡实时流量shell脚本
159 0
LXJ
|
监控
端口监控脚本
端口监控脚本
LXJ
127 0