核心代码:
#!/bin/bash check_process(){ tolprocess=`ps auxf|grep DisplayMa[nager]|wc -l` #if [ "$tolprocess" -lt "1" ];then if [ "$tolprocess" -ge "1" ];then echo 'process ok' else echo 'fail' fi } check_log(){ if [ -e /etc/syslog-ng/syslog-ng.conf ];then conlog=`cat '/etc/syslog-ng/syslog-ng.conf'|grep "10.70.72.253"|wc -l` if [ "$conlog" -ge "1" ];then echo 'syslog-ng ok' fi elif [ -e /etc/syslog.conf ];then conlog=`cat '/etc/syslog.conf'|grep "10.70.72.253"|wc -l` if [ "$conlog" -ge "1" ];then echo 'syslog ok' fi else echo 'log not find or error' fi } check_cpuidle(){ mincpu=`sar -u 2 10|grep all|awk '{print $NF}'|sort -nr|tail -1` if [ $(echo "${mincpu} < 20" | bc) = 1 ];then #if [ "$mincpu" -le "20" ];then echo 'cpu idle is less than 20% ,please check' else echo 'cpu idle is more than 20%, it is ok ' fi } check_mem(){ vmstat 2 10 } check_disk(){ chkdsk=`fdisk -l|egrep 'failed|unsynced|unavailable'|wc -l` if [ "$chkdsk" -ge "1" ];then echo 'fdisk check ok ' else echo 'fdisk check find error,please check your disk ' fi } check_io(){ util=`sar -d 2 10|egrep -v 'x86|^$|await'|awk '{print $NF}'|sort -nr|tail -1` await=`sar -d 2 10|egrep -v 'x86|^$|await'|awk '{print $(NF-2)}'|sort -nr|tail -1` if [ $(echo "${util} < 80" | bc) = 1 ] && [ $(echo "${await} < 100" | bc) = 1 ] ;then echo 'disk io check is fine' else echo 'disk io use too high ' fi } check_swap(){ tolswap=`cat /proc/meminfo|grep SwapTotal|awk '{print $2}'` #awk '/SwapTotal/{total=$2}/SwapFree/{free=$2}END{print (total-free)/1024}' /proc/meminfo useswap=`awk '/SwapTotal/{total=$2}/SwapFree/{free=$2}END{print (total-free)}' /proc/meminfo ` util=`awk 'BEGIN{printf "%.1f\n",'$useswap'/'$tolswap'}'` if [ $(echo "${util} < 0.3" | bc) = 1 ] || [ $(echo "${useswap} < 1024" | bc) = 1 ] ;then echo 'swap use is ok ' else echo "useswap: $useswap kb, swap util is $util" fi } check_dmesg(){ chkdm=`dmesg |egrep 'scsi reset|file system full'|wc -l` if [ "$chkdm" -ge "1" ];then echo 'dmesg test ok ' else echo 'dmesg check find error ' fi } check_boot(){ chkdm=`cat /var/log/boot.msg|egrep 'scsi reset|file system full'|wc -l` if [ "$chkdm" -ge "1" ];then echo 'boot check fine ' else echo 'boot check find error ' fi } check_inode(){ maxinode=`df -i|awk '{print $5}'|egrep -v 'IUse|-' |sed 's/%//g'|sort -nr|head -1` if [ $(echo "${maxinode} < 80" | bc) = 1 ];then echo 'inode check ok ' else echo 'inode used more than 80% ' fi } check_df(){ dfuse=`df -HT|awk '{print $6}'|grep -v Use|sed 's/%//g'|sort -nr|head -1` if [ $(echo "${dfuse} < 80" | bc) = 1 ];then echo 'disk used is less than 80% ,it is ok !' elif [ $(echo "${dfuse} > 80" | bc) = 1 ] && [ $(echo "${dfuse} < 90" | bc) = 1 ];then echo 'warning , disk used more than 80% and less than 90% ' else echo ' Critical, disk used more than 90% ' fi } echo '################### check process ###################' check_process echo '################### check syslog ####################' check_log echo '################### check cpuidle ###################' check_cpuidle echo '################### echo memory stat ################' check_mem echo '################### check fdisk #####################' check_disk echo '################### check io used ###################' check_io echo '################### check swap used #################' check_swap echo '################### check dmesg #####################' check_dmesg echo '################### check inode #####################' check_inode echo '################### check disk used #################' check_df
保存为/system/check_linux.sh
本文向大家介绍mysql巡检脚本(必看篇),包括了mysql巡检脚本(必看篇)的使用技巧和注意事项,需要的朋友参考一下 如下所示: 以上这篇mysql巡检脚本(必看篇)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持呐喊教程。
#在找工作求抱抱# #如何判断面试是否凉了# #找工作中的意难平# #2023届春招# TCP和UDP的区别 C++中多态的使用(期末考试即视感) C++中类和结构体的区别(答得不好) C++空类中有什么函数(满脑子big Five,5个,用的时候都记得,名字真背不全) 数据库没问 项目也没问…… 感觉真不怎么样
先做了四道MySQL的题,考了多表联查,函数,比较简单。 然后技术面,重点问了项目,然后是spring,mybatis,没有怎么问八股文。 没回答出来的的题: 1.mybatis一级缓存二级缓存 2.两个类互相调用,循环互斥 还问了IOC,AOP,spring常用注解,springMVC流程之类的 可能回答的还行,技术打个直接找了hr面,hr聊了一会又找了boss 公司最多给开2000,要求加班到
boss上投的,上海司睿杰建科,回复后第二天直接约面了,很爽快 腾讯会议30分钟,没开视频,都是常规八股 自我介绍,专门问了一下学校(吉尔大学🤣) 介绍一下你比较熟悉的数据结构:我提了一嘴跳表:对比哈希表什么情况下用跳表效果更好? 介绍项目,提问技术难点 go map的底层实现 go slice的底层实现 介绍一下innodb?你是怎么学习的? 通常情况下你会怎么去设计数据库?
1、自我介绍 2、KMP算法了解嘛,说一说 3、二叉树的遍历方式 4、为什么有了二叉平衡树还要红黑树 5、JVM了解嘛,说一说理解 6、什么情况下对象会到老年代 7、JVM调优经验有吗,说一说 8、Mysql索引结构了解吗,说一说 9、为什么B+树要在叶子节点放数据 10、Mysql的调优经验说一说 11、HashMap经典问 12、有发生过hash冲突的经验嘛,怎么解决(当时没get到面试官可能
我无法回显,因为它将是当前(子)项目的版本。我不能使用,因为我不知道可能有多少级继承。我尝试定义一个属性,硬编码到公司POM版本,但是当我发布公司POM时,发布插件不知道更新该属性(这是有道理的,它不是依赖版本,只是一个属性,发布版本不能知道更新它)。 理想情况下,我希望能够通过一个属性直接获取特定POM的版本,比如。这样的东西存在吗? 如果没有,在发布期间是否有一种方法可以用正在发布的项目的更新