【云原生之Docker实战】使用Docker部署Ward服务器监控工具

简介: 【5月更文挑战第11天】使用Docker部署Ward服务器监控工具

@TOC

一、Ward介绍

1.1 Ward简介

Ward监控工具是一款专门用于监控Linux系统的工具。它可以实时监测系统的CPU、内存、I/O等资源的使用情况,以及系统的网络状态和服务运行状态等。

1.2 Ward特点

  • Ward 支持自适应设计系统。
  • Ward还支持深色主题。
  • Ward只显示服务器的主要信息。
  • Ward 在所有流行的操作系统上运行良好。

1.3 Ward使用场景

  1. 性能监控与优化:在大型企业或互联网公司的服务器集群中,Ward监控工具可以持续监控每一台Linux服务器的CPU使用率、内存占用、磁盘I/O等关键性能指标。当这些指标超过预设阈值时,它能立即发送警报,帮助运维团队快速定位到性能瓶颈所在,及时进行调优或扩容,确保业务平稳运行。

  2. 故障预警与排查:对于需要高可用性的在线服务,如电子商务平台、金融交易系统等,Ward能够实时监测服务的状态和网络连接情况。一旦发现服务异常终止、响应时间过长或是网络中断等问题,立即触发报警机制,帮助运维人员迅速介入,缩短故障处理时间,减少服务中断带来的损失。

  3. 资源利用率分析:在数据中心或云环境中,通过Ward长期收集和分析系统资源的使用数据,可以帮助管理员了解资源的分配和利用效率。这对于合理规划资源、避免资源浪费、优化成本结构十分关键。例如,通过分析报告可以决定是否需要调整虚拟机的配置,或者是否有必要将某些服务迁移到其他负载较低的服务器上。

  4. 容量规划:随着业务量的增长,提前预测并准备足够的系统资源变得尤为重要。Ward提供的历史监控数据和趋势分析功能,能够帮助企业进行准确的容量规划。通过分析高峰期的资源使用情况,预测未来可能需要的资源增长量,从而提前进行硬件升级或云资源的扩容,确保业务的持续扩展能力。

  5. 安全审计与合规性检查:虽然Ward主要聚焦于性能和状态监控,但其对系统活动的跟踪能力也能辅助进行安全审计。例如,通过监控异常的网络流量、不明的系统访问记录等,可以及早发现潜在的安全威胁,配合其他安全工具为系统的安全性提供多一层保障。

二、Docker介绍

2.1 Docker介绍

  • Docker简介

Docker是一个开源的应用容器引擎,可以轻松地将应用程序打包成一个可移植的容器,便于部署、测试和运行。Docker容器是轻量级、可移植和可重复使用的,具有良好的性能和资源利用率。
Docker利用操作系统级别的虚拟化技术,可以在同一台物理服务器上同时运行多个独立的容器,并且不会相互干扰。在构建和部署应用程序时,Docker容器提供了一个统一的开发、测试和生产环境,大大简化了整个应用程序生命周期的管理。
除了其强大的应用容器化功能之外,Docker还提供了一个强大的生态系统,包括容器仓库、镜像管理、容器编排等工具,让用户可以更加轻松地管理和扩展应用程序。同时,Docker的开放性和可扩展性也使得它可以与其他云计算和容器化技术无缝集成,成为云原生技术栈中不可或缺的一环。

2.2 Docker优点

  • Docker优点
  1. 简化应用部署:Docker可以将应用及其依赖项打包在一个容器中,使得应用在不同的环境中部署变得更加简单,避免了很多配置和依赖问题。

  2. 提高开发效率:Docker的容器化技术可以提高开发效率,因为开发人员可以在本地构建和测试容器,并且可以在不同的开发环境中轻松共享和重复使用这些容器。

  3. 更好的资源利用与隔离:Docker使用虚拟化技术来隔离应用及其依赖项,保证容器中的应用不会干扰其他应用并且提高资源利用率。

  4. 更快速的部署:将应用部署到Docker容器中后,部署时间可以被缩短到几秒钟的级别,避免了复杂的手动配置,提高了应用的可靠性和可移植性。

  5. 更快速的扩展:Docker容器可以快速地复制和扩展,并且可以自动负载均衡,提高了应用的可扩展性。

  6. 更加安全:Docker容器是安全的,因为它将应用隔离在一个独立的环境中,使得攻击者很难侵入应用的内部,从而保护了应用和其数据的安全。

三、本地环境介绍

3.1 本地环境规划

本次实践为个人测试环境,操作系统版本为centos7.6。

hostname IP地址 操作系统版本 Docker版本 ward版本
jeven 192.168.3.166 centos 7.6 20.10.17 v2.4.0

3.2 本次实践介绍

1.本次实践部署环境为个人测试环境,生产环境请谨慎;
2.在Docker环境下部署Ward服务器监控工具。

四、检查宿主机系统版本

4.1 检查操作系统版本

检查本地服务器操作系统版本,当前使用centos7.6版本。

[root@jeven ~]# cat /etc/redhat-release
CentOS Linux release 7.6.1810 (Core)

4.3 检查系统内核

检查操作内核版本,当前内核版本为3.10.0-957.el7.x86_64。

[root@jeven ~]# uname -r
3.10.0-957.el7.x86_64

五、检查本地Docker环境

5.1 检查Docker服务状态

检查当前Docker服务状态,确保Docker服务正常运行。

[root@jeven ~]# systemctl status docker
● docker.service - Docker Application Container Engine
   Loaded: loaded (/usr/lib/systemd/system/docker.service; enabled; vendor preset: disabled)
   Active: active (running) since Tue 2023-10-10 02:01:39 CST; 5h 32min ago
     Docs: https://docs.docker.com
 Main PID: 9566 (dockerd)
    Tasks: 13
   Memory: 378.6M
   CGroup: /system.slice/docker.service

5.2 检查Docker版本

检查Docker版本,当前Docker版本为20.10.17。

[root@jeven ~]# docker version
Client: Docker Engine - Community
 Version:           20.10.17
 API version:       1.41
 Go version:        go1.17.11
 Git commit:        100c701
 Built:             Mon Jun  6 23:05:12 2022
 OS/Arch:           linux/amd64
 Context:           default
 Experimental:      true

Server: Docker Engine - Community
 Engine:
  Version:          20.10.17
  API version:      1.41 (minimum version 1.12)
  Go version:       go1.17.11
  Git commit:       a89b842
  Built:            Mon Jun  6 23:03:33 2022
  OS/Arch:          linux/amd64
  Experimental:     false
 containerd:
  Version:          1.6.6
  GitCommit:        10c12954828e7c7c9b6e0ea9b0c02b01407d3ae1
 runc:
  Version:          1.1.2
  GitCommit:        v1.1.2-0-ga916309
 docker-init:
  Version:          0.19.0
  GitCommit:        de40ad0

5.3 开启IPv4 forwarding

执行以下操作,开启路由转发。

[root@node ~]# echo "net.ipv4.ip_forward=1" >>  /etc/sysctl.conf
[root@node ~]# systemctl restart network
[root@node ~]#  sysctl net.ipv4.ip_forward
net.ipv4.ip_forward = 1

5.4 检查Docker compose版本

检查docker compose 版本,当前版本为v2.6.0。

[root@jeven ~]# docker compose version
Docker Compose version v2.6.0

六、下载Ward镜像

在docker hub拉取Ward镜像

[root@jeven ~]# docker compose version
Docker Compose version v2.6.0
[root@jeven ~]# docker pull antonyleons/ward
Using default tag: latest
latest: Pulling from antonyleons/ward
44ba2882f8eb: Pull complete
2cabec57fa36: Pull complete
c20481384b6a: Pull complete
bf7b17ee74f8: Pull complete
38617faac714: Pull complete
b944bffad3f6: Pull complete
2c37ae828c28: Pull complete
Digest: sha256:29f6b3ca9ae85b4861cd60344d9621624671e1e7fbfc417c7f185d48f106329f
Status: Downloaded newer image for antonyleons/ward:latest
docker.io/antonyleons/ward:latest

七、部署Ward服务器监控工具

7.1 使用docker-cli方式部署

使用docker-cli方式部署ward

docker run --restart unless-stopped -it -d --name ward -p 4000:4000 -e WARD_PORT=4000 -e WARD_THEME=dark --privileged antonyleons/ward

7.2 使用docker compose方式部署

本次使用dockercompose方式部署ward

version: '3.3'
services:
    run:
        restart: unless-stopped
        container_name: ward
        ports:
            - '4000:4000'
        environment:
            - WARD_PORT=4000
            - WARD_THEME=dark
            - WARD_NAME=leons-server
        privileged: true
        image: antonyleons/ward

开始部署ward,创建ward容器。

docker compose up -d

在这里插入图片描述

7.3 检查ward容器状态

检查ward容器状态

[root@jeven ~]#  docker ps
CONTAINER ID   IMAGE              COMMAND                  CREATED          STATUS          PORTS                                       NAMES
0f91a8774d45   antonyleons/ward   "/bin/sh -c 'java -j…"   39 seconds ago   Up 38 seconds   0.0.0.0:4000->4000/tcp, :::4000->4000/tcp   ward

7.4 检查ward容器日志

检查ward容器日志。确保ward服务正常运行。

docker logs ward

在这里插入图片描述

八、访问ward首页

访问地址:http://192.168.3.166:4000/,将IP替换为自己服务器IP地址。

在这里插入图片描述

九、总结

使用Ward监控工具让我对Linux系统的运行状态了如指掌。它以直观的图表形式展示CPU、内存、I/O等资源的使用情况,让我可以实时观察系统的负载情况并及时做出调整。同时,它还能实时监测系统的网络状态和服务运行状态,让我可以及时发现并解决问题。作为一款轻量级监控工具,Ward满足了我对服务器的基本监控需求。

相关文章
|
1天前
|
域名解析 弹性计算 监控
使用云效将项目代码部署到云服务器ECS的体验评测
本文详述了使用阿里云云效和ECS搭建企业门户网站的解决方案,包括引导文档、部署流程、一键与手动部署的优缺点以及部署中可能遇到的问题。文中建议阿里云改进文档更新及时性,增强流程指引清晰度,提供更具体的错误信息,并增加实时监控、报警功能及性能优化建议。此外,呼吁建立更多用户交流平台以提升用户体验。
9 1
|
10天前
|
监控 NoSQL Redis
Redis哨兵,Redis哨兵核心功能如何一个云服务器完成6个节点的搭建-docker什么是docker是否可以把六个容器,都写到同一个ym配置中,一次都启动,不就直接保证互通问题了吗?
Redis哨兵,Redis哨兵核心功能如何一个云服务器完成6个节点的搭建-docker什么是docker是否可以把六个容器,都写到同一个ym配置中,一次都启动,不就直接保证互通问题了吗?
|
11天前
|
关系型数据库 应用服务中间件 数据库
编程入门(一)【Web服务器环境的部署】
编程入门(一)【Web服务器环境的部署】
28 1
|
12天前
|
Java 关系型数据库 MySQL
【JavaEE进阶】部署Web项目到Linux服务器
【JavaEE进阶】部署Web项目到Linux服务器
|
13天前
|
异构计算 弹性计算 并行计算
|
16天前
|
Java 应用服务中间件 nginx
服务器重置实例后的部署工作
该内容描述了一次服务器配置过程,包括使用`nginx`作为反向代理,通过`docker`运行两个项目环境(生产&测试)以及`redis`服务。`init.sh`脚本用于创建项目目录和安装`docker`、`unzip`、`nginx`。`step.sh`用于管理`java`项目的容器。在`nginx`配置中,设定了反向代理规则。最后,通过`systemctl restart nginx`重启服务,并提到项目部署自动化已集成到`jenkins`,只需更新服务器访问凭证即可。
|
21天前
|
存储 弹性计算 人工智能
【阿里云弹性计算】AI 训练与推理在阿里云 ECS 上的高效部署与优化
【5月更文挑战第25天】阿里云ECS为AI训练和推理提供弹性、可扩展的计算资源,确保高性能和稳定性。通过灵活配置实例类型、利用存储服务管理数据,以及优化模型和代码,用户能实现高效部署和优化。自动伸缩、任务调度和成本控制等策略进一步提升效率。随着AI技术发展,阿里云ECS将持续助力科研和企业创新,驱动人工智能新时代。
54 0
|
21天前
|
运维 监控 安全
构建高效自动化运维体系:Ansible与Docker的协同实战
【5月更文挑战第25天】 在当今快速迭代的软件发布环境中,自动化运维成为确保部署效率和可靠性的关键。本文通过深入分析Ansible和Docker技术,探索它们如何协同工作以构建一个高效的自动化运维体系。文章不仅介绍了Ansible的配置管理功能和Docker容器化的优势,还详细阐述了将两者结合的实践策略,旨在帮助读者理解并实现更智能、更灵活的基础设施管理。
|
19小时前
|
弹性计算
阿里云ECS使用体验
在申请高校学生免费体验阿里云ECS云服务器后的一些使用体验和感受。
|
1天前
|
弹性计算
阿里云ECS的使用心得
本文主要讲述了我是如何了解到ECS,使用ECS的一些经验,以及自己的感悟心得