Boot+Cloud项目学习:macrozheng.com
我们在查看服务器运行状态时,除了使用命令行还是命令行。那么有什么办法可以不用命令行,直观地查看服务器的CPU、内存、网络、容器运行状态等信息呢?今天给大家分享一款好用的服务器监控工具Sampler,使用它能快速方便地查看这些信息,希望对大家有所帮助!
Sampler简介
Sampler是一款基于shell命令的可视化监控工具,通过简单的YAML文件来进行配置即可实现监控,目前在Github上已有12k+Star
。
下面是使用Sampler来进行服务器状态监控的效果图,看起来还是挺炫酷的!
安装
Sampler的安装非常简单,这里以Linux系统为例,使用如下命令下载Sampler的安装包;
# 下载sampler的安装包保存到/usr/local/bin目录下
sudo wget https://github.com/sqshq/sampler/releases/download/v1.1.0/sampler-1.1.0-linux-amd64 -O /usr/local/bin/sampler
# 给安装包添加执行权限
sudo chmod +x /usr/local/bin/sampler
安装完成后在 /usr/local/bin
目录下,就有一个可执行的sampler文件了。
这或许是一个对你有用的开源项目,mall项目是一套基于 SpringBoot3 + Vue 的电商系统(Github标星60K),后端支持多模块和 2024最新微服务架构 ,采用Docker和K8S部署。包括前台商城项目和后台管理系统,能支持完整的订单流程!涵盖商品、订单、购物车、权限、优惠券、会员、支付等功能!
Boot项目:https://github.com/macrozheng/mall Cloud项目:https://github.com/macrozheng/mall-swarm 视频教程:https://www.macrozheng.com/video/ 项目演示:
使用
Sampler的使用非常简单,只要在 yaml
文件中配置好监控脚本,然后使用如下命令执行即可;
# 配置文件需要添加可执行权限
chmod +x config.yml
# 然后通过配置文件启动Sampler
sampler -c config.yml
如果你想查看服务器CPU和可用内存情况,可以在 config.yml
文件中添加如下脚本,然后使用上面的命令来运行;
sparklines:
- title: CPU usage(%)
rate-ms: 200
scale: 0
sample: ps -A -o %cpu | awk '{s+=$1} END {print s}'
- title: RAM free(MB)
rate-ms: 200
scale: 0
sample: free -m| grep "Mem:" | awk '{print $4}'
执行命令后,显示效果如下:
如果你想查看服务器上Docker容器的运行状态,可以添加如下脚本;
textboxes:
- title: Docker containers stats
rate-ms: 500
sample: docker stats --no-stream --format "table {{.Name}}\t{{.CPUPerc}}\t{{.MemUsage}}\t{{.PIDs}}"
执行命令后,显示效果如下:
如果你想查看服务器的网络状态,例如UDP和TCP的收发情况,可以添加如下脚本;
barcharts:
- title: Local network activity
rate-ms: 500
scale: 0
items:
- label: UDP bytes in
sample: netstat -anu | awk '{sum += $2} END {print sum}'
- label: UDP bytes out
sample: netstat -anu | awk '{sum += $3} END {print sum}'
- label: TCP bytes in
sample: netstat -ant | awk '{sum += $2} END {print sum}'
- label: TCP bytes out
sample: netstat -ant | awk '{sum += $3} END {print sum}'
执行命令后,显示效果如下:
如果你想查看服务器的时间,可以添加如下脚本;
asciiboxes:
- title: CST time
rate-ms: 500
font: 2d
border: false
color: 43
sample: env TZ=Asia/Shanghai date +%r
执行命令后,显示效果如下:
我们再把上面这些监控信息组合起来,制作一个面板来看下效果,还是挺炫酷的;
这里使用的脚本如下,感兴趣的小伙伴可以尝试下!
runcharts:
- title: Search engine response time
position: [[0, 0], [45, 19]]
rate-ms: 500
triggers:
- title: Latency threshold exceeded
condition: echo "$prev < 0.8 && $cur > 0.8" |bc -l
actions:
terminal-bell: true
sound: true
visual: true
script: 'say alert: ${label} latency exceeded ${cur} second'
legend:
enabled: true
details: false
scale: 2
items:
- label: BAIDU
color: 178
sample: curl -o /dev/null -s -w '%{time_total}' https://www.baidu.com
- label: BING
sample: curl -o /dev/null -s -w '%{time_total}' https://www.bing.com
barcharts:
- title: Local network activity
position: [[45, 20], [35, 8]]
rate-ms: 500
scale: 0
items:
- label: UDP bytes in
sample: netstat -anu | awk '{sum += $2} END {print sum}'
- label: UDP bytes out
sample: netstat -anu | awk '{sum += $3} END {print sum}'
- label: TCP bytes in
sample: netstat -ant | awk '{sum += $2} END {print sum}'
- label: TCP bytes out
sample: netstat -ant | awk '{sum += $3} END {print sum}'
gauges:
- title: YEAR PROGRESS
position: [[45, 0], [35, 2]]
cur:
sample: date +%j
max:
sample: echo 365
min:
sample: echo 0
- title: DAY PROGRESS
position: [[45, 3], [35, 2]]
cur:
sample: date +%H
max:
sample: echo 24
min:
sample: echo 0
- title: HOUR PROGRESS
position: [[45, 6], [35, 2]]
cur:
sample: date +%M
max:
sample: echo 60
min:
sample: echo 0
- title: MINUTE PROGRESS
position: [[45, 9], [35, 2]]
triggers:
- title: CLOCK BELL EVERY MINUTE
condition: '[ $label == "cur" ] && [ $cur -eq 0 ] && echo 1 || echo 0'
actions:
sound: true
script: say -v samantha `date +%I:%M%p`
cur:
sample: date +%S
max:
sample: echo 60
min:
sample: echo 0
sparklines:
- title: CPU usage
position: [[0, 20], [22, 8]]
rate-ms: 200
scale: 0
sample: ps -A -o %cpu | awk '{s+=$1} END {print s}'
- title: RAM free(MB)
position: [[22, 20], [23, 8]]
rate-ms: 200
scale: 0
sample: free -m | grep "Mem:" | awk '{print $4}'
textboxes:
- title: Docker containers stats
position: [[0, 29], [45, 10]]
rate-ms: 500
sample: docker stats --no-stream --format "table {{.Name}}\t{{.CPUPerc}}\t{{.MemUsage}}\t{{.PIDs}}"
- title: Local weather
position: [[69, 31], [13, 7]]
rate-ms: 10000
sample: curl wttr.in?0ATQF
border: false
- title: New York weather
position: [[45, 31], [13, 7]]
rate-ms: 10000
sample: curl wttr.in/newyork?0ATQF
transform: echo 1
border: false
- title: San Francisco weather
position: [[56, 31], [13, 7]]
rate-ms: 10000
sample: curl wttr.in/sanfrancisco?0ATQF
border: false
asciiboxes:
- title: CST time
position: [[45, 12], [35, 7]]
rate-ms: 500
sample: env TZ=Asia/Shanghai date +%r
border: false
font: 2d
总结
今天给大家介绍了一款直观易用的服务器监控工具Sampler,使用它来查看服务器运行状态真的是一目了然。其实Sampler的功能不止于此,它还能用于监控MySQL、MongoDB、Kafka这类中间件的信息,该兴趣的小伙伴可以尝试下!
项目地址
https://github.com/sqshq/sampler
Github上标星60K
的电商实战项目mall,全套 视频教程 已更新完毕!全套教程约40小时,共113期
,通过这套教程你可以拥有一个涵盖主流Java技术栈的完整项目经验
,同时提高自己独立开发一个项目的能力
,下面是项目的整体架构图,感兴趣的小伙伴可以点击链接 mall视频教程 加入学习。
整套 视频教程 的内容还是非常完善的,涵盖了mall项目最佳学习路线、整体框架搭建、业务与技术实现全方位解析、线上Docker环境部署、微服务项目学习等内容,你也可以点击链接 mall视频教程 了解更多内容。