Docker 全栈体系(八)

Docker 体系(高级篇)

六、Docker轻量级可视化工具Portainer

1. 是什么

  • Portainer 是一款轻量级的应用,它提供了图形化界面,用于方便地管理Docker环境,包括单机环境和集群环境。

2. 安装

bash 复制代码
docker run -d -p 8000:8000 -p 9000:9000 --name portainer     --restart=always     -v /var/run/docker.sock:/var/run/docker.sock     -v portainer_data:/data     portainer/portainer
  • 第一次登录需创建admin,访问地址:xxx.xxx.xxx.xxx:9000
    • 用户名,直接用默认admin
    • 密码记得8位,随便你写
  • 设置admin用户和密码后首次登陆
  • 选择local选项卡后本地docker详细信息展示

七、Docker容器监控之 CAdvisor+InfluxDB+Granfana

1. 原生命令

  • 操作
  • docker stats命令的结果
  • 问题
    • 通过docker stats命令可以很方便的看到当前宿主机上所有容器的CPU,内存以及网络流量等数据,一般小公司够用了。。。。
    • 但是,docker stats统计结果只能是当前宿主机的全部容器,数据资料是实时的,没有地方存储、没有健康指标过线预警等功能。

2. 是什么

2.1 容器监控3剑客

  • CAdvisor监控收集+InfluxDB存储数据+Granfana展示图表
    • CAdvisor
    • InfluxDB
  • Granfana

2.2 总结

3. compose容器编排,一套带走

3.1 新建目录

3.2 新建3件套组合的 docker-compose.yml

yaml 复制代码
version: '3.1'
 
volumes:
  grafana_data: {}
 
services:
 influxdb:
  image: tutum/influxdb:0.9
  restart: always
  environment:
    - PRE_CREATE_DB=cadvisor
  ports:
    - "8083:8083"
    - "8086:8086"
  volumes:
    - ./data/influxdb:/data
 
 cadvisor:
  image: google/cadvisor
  links:
    - influxdb:influxsrv
  command: -storage_driver=influxdb -storage_driver_db=cadvisor -storage_driver_host=influxsrv:8086
  restart: always
  ports:
    - "8080:8080"
  volumes:
    - /:/rootfs:ro
    - /var/run:/var/run:rw
    - /sys:/sys:ro
    - /var/lib/docker/:/var/lib/docker:ro
 
 grafana:
  user: "104"
  image: grafana/grafana
  user: "104"
  restart: always
  links:
    - influxdb:influxsrv
  ports:
    - "3000:3000"
  volumes:
    - grafana_data:/var/lib/grafana
  environment:
    - HTTP_USER=admin
    - HTTP_PASS=admin
    - INFLUXDB_HOST=influxsrv
    - INFLUXDB_PORT=8086
    - INFLUXDB_NAME=cadvisor
    - INFLUXDB_USER=root
    - INFLUXDB_PASS=root

3.3 启动docker-compose文件

  • docker-compose up

3.4 查看三个服务容器是否启动

3.5 测试

  • 浏览cAdvisor收集服务,http://ip:8080/
    • 第一次访问慢,请稍等
    • cadvisor也有基础的图形展现功能,这里主要用它来作数据采集
  • 浏览influxdb存储服务,http://ip:8083/
  • 浏览grafana展现服务,http://ip:3000
    • ip+3000端口的方式访问,默认帐户密码(admin/admin)
    • 配置步骤
      • 配置数据源
      • 选择influxdb数据源
    • 配置细节


    • 配置面板 panel





  • 到这里cAdvisor+InfluxDB+Grafana容器监控系统就部署完成了
相关推荐
java1234_小锋7 分钟前
Spring AI 2.0 开发Java Agent智能体 - Spring AI项目调用本地Ollama模型
java·人工智能·spring·spring ai2.0
二哈赛车手7 分钟前
新人笔记---多策略搭建策略执行链实现RAG检索后过滤
java·笔记·spring·设计模式·ai·策略模式
PESS ABIN8 分钟前
JavaWeb项目打包、部署至Tomcat并启动的全程指南(图文详解)
java·tomcat
AI进化营-智能译站14 分钟前
ROS2 C++开发系列15-模板实现通用算法|宏定义ROS2调试开关|一次编码适配多平台
java·c++·算法·ai
刀法如飞17 分钟前
Java数组去重的20种实现方式——指导AI解决不同问题的思路
java·算法·面试
薪火铺子27 分钟前
SpringMVC请求处理流程源码解析(第1篇):请求入口与处理器映射
java·后端·spring
ch.ju27 分钟前
Java程序设计(第3版)第二章——参数(实参 形参)
java
椰猫子28 分钟前
SpringMVC(SpringMVC简介、请求与响应(请求映射路径、请求参数、日期类型参数传递、响应json数据))
java·前端·数据库
海兰30 分钟前
【开篇】Spring AI、OpenClaw 和Hermes
java·人工智能·spring·spring ai
bzmK1DTbd38 分钟前
微服务架构设计:Spring Cloud Gateway与Nacos集成
java·spring·微服务