# time sosreport
(补充:这里以显示 sosreport 命令所需执行时间为例)
# time sosreport
(补充:这里以显示 sosreport 命令所需执行时间为例)
watchdog: Bug: soft lockup - CPU......
当 CPU 的负载过高时,一个 CPU 在运行某一个进程时,在内核模式下超过 20 秒没有回应,则看门狗程序会将系统所有 CPU 软锁住,然后会让这些 CPU 显示各自正在运行的进程堆栈跟踪
# echo 20 > /proc/sys/kernel/watchdog_thresh
(补充:这里以将看门狗的值延长到 20 为例,也可以根据自己的需求延长更多,默认值为 10)
# echo "kernel.watchdog_thresh = 20" >> /etc/sysctl.conf
(补充:这里以将看门狗的值延长到 20 为例,也可以根据自己的需求延长更多,默认值为 10)
# sysctl -p /etc/sysctl.conf
开启 Kdump,等此报错再次发生时分析 Kdump 在内核崩溃时搜集信息 vmcore
作者:朱明宇
名称:批量比较服务器所有正在运行进程的变化
作用:批量比较服务器所有正在运行进程的变化
1. 服务器清单 $server_list 每台服务器占用 1 行
2. 在此脚本的分割线内写入相应的内容,并和此脚本放在同一目录下
3. 给此脚本添加执行权限
4. 执行此脚本
5. 此脚本执行完成后,会将运行结果写入当前目录下的 $compare_file 里
server_list=server_list.txt #服务器清单
first_time=first_time #存储第一次检结果的目录
second_time=second_time #存储第二次检查结果的目录
compare_file=comparison_results.txt #存储比较结果的文件
此脚本执行前必须要先保证执行本脚本的用户能无密码 ssh 远程这些远程服务器
#!/bin/bash
####################### Separator ########################
server_list=server_list.txt
first_time=first_time
second_time=second_time
compare_file=comparison_results.txt
####################### Separator ########################
mkdir $first_time &> /dev/null
mkdir $second_time &> /dev/null
echo > $compare_file
read -p "Please input first second or compare now: " choice
check(){
for server_name in `cat $1`
do
ssh -t $server_name "ps -A" | awk '{print $4}' > $2/$server_name
done
}
compare(){
for server_name in `cat $1`
do
echo $server_name >> $4
for process in `cat $2/$server_name`
do
grep $process $3/$server_name &> /dev/null
if [ $? -ne 0 ];then
echo $process >> $4
fi
done
echo >> $4
done
}
if [ $choice == first ];then
check $server_list $first_time
fi
if [ $choice == second ];then
check $server_list $second_time
fi
if [ $choice == compare ];then
compare $server_list $first_time $second_time $compare_file
fi
进程的真正优先级越小,则此进程则越能优先被执行
进程的真正优先级 = 进程默认优先级 + 修正值(nice 值)
从 -20 到 +19
# nice -n <correction value> <command>
或者:
# nice --adjustment=<correction value> <command>
或者:
# nice -<correction value> <command>
# nice -n 10 top
或者:
# nice --adjustment=10 top
或者:
# nice -10 top
(注意:这里的 -10 不是指负数 10 而是指正数 10)
(补充:这里以修正值为 10 启动 top 命令为例)
# top
或者:
# ps -ef
(
补充:
1) PRI 代表进程默认的优先级
2) NI 代表进程的修正值(nice 值)
3) 进程的真正优先级 = PRI + NI
4) 如果多个进程的真正优先级一样,则 root 用户的进程被优先执行
)
# vim /root/12456.sh
创建以下内容:
#!/bin/bash
for i in {1..5}
do
echo $i
done
(补充:这里以创建 /etc/root/for.sh 脚本为例)
# vim /etc/systemd/system/12456.service
创建以下内容:
[Unit]
Description=12345
After=default.target
[Service]
Type=oneshot
ExecStart=/root/12456.sh
[Install]
WantedBy=default.target
(补充:这里以创建 /etc/systemd/system/12456.service 来管理 ExecStart=/root/12456.sh 为例)
# systemctl daemon-reload
# chmod u+x /etc/systemd/system/12456.service
# systemctl start 12456.service
# systemctl stop 12456.service
# systemctl restart 12456.service
# systemctl enable 12456.service