docker的资源限制参数设置错误,导致的clickhouse性能瓶颈

使用场景

  • 我们使用docker作为服务的虚拟化工具,服务都部署在docker里
  • 我们使用docker-compose管理所有docker服务的配置文件
  • 针对某些服务,我们要限制这个docker占用的资源数量,例如,cpu和内存
  • 在进行配置时,网上搜了一些文章,进行了设置,导致了本次错误
  • 由于是公司测试环境,主要做一些功能测试,不用于性能测试,故只设置了很小的资源
  • 针对clickhouse数据库的docker配置如下:
yml 复制代码
  clickhouse:
    image: yandex/clickhouse-server
    container_name: clickhouse
    ports:
      - 8123:8123
      - 9000:9000
    ulimits:
      nofile:
        soft: 262144
        hard: 262144
    deploy:
      resources:
        limits:
          cpus: "0.6"
          memory: 2G
    volumes:
      - ./volumes/ck/data:/var/lib/clickhouse
      - ./volumes/ck/log/:/var/log/clickhouse-server/
      - ./volumes/ck/etc/:/etc/clickhouse-server/
      - /etc/localtime:/etc/localtime
    restart: on-failure

问题现象

  • 之前是把clickhouse部署在服务器上,使用了近一年,没什么问题
  • 前段时间,为了统一部署环境,将clickhouse使用docker部署
  • 在写入和查询并发量不大的情况下,发现clickhouse查询较慢
  • 查看了query_log,发现10万条数据,就用了600ms,很不应该

解决处理

  • 和同事交流后,发现cpus参数设置不合理
  • 我之前看着网上的一些文章和翻译,以为这个数字要取小数,是一个比值,是 "服务器cpu总数量 x 比值",为该docker容器使用的cpu数量
  • 在同事建议下,去看了官方英文文档,果然,我理解错了,这个就是简单的指 cpu数量
  • 官方文档地址:https://docs.docker.com/compose/compose-file/deploy/#cpus

cpus configures a limit or reservation for how much of the available CPU resources, as number of cores, a container can use.

  • 核心是这句number of cores,很明确,就是数量
  • 还有一点需要说明的是,clickhouse的内存使用限制,要大于16G,否则也可能存在性能瓶颈和各种意外的报错
  • 仍然贴一篇官方文档:https://clickhouse.com/docs/en/operations/tips#ram

danger

If your system has less than 16 GB of RAM, you may experience various memory exceptions because default settings do not match this amount of memory. The recommended amount of RAM is 32 GB or more. You can use ClickHouse in a system with a small amount of RAM, even with 2 GB of RAM, but it requires additional tuning and can ingest at a low rate.

  • 优化后配置为

    复制代码
     deploy:
        resources:
          limits:
            cpus: "8.0"
            memory: 16G
  • 查询飞快,问题解决了

  • 当然,针对生产环境,这个配置就不够用了。要针对自己的业务量,进行一个预估,申请足够的cpu和内存配置的服务器

相关推荐
杨浦老苏35 分钟前
音乐和有声读物播放器AudioDock
docker·群晖·多媒体·音乐·有声读物
青春不流名1 小时前
Portainer CE(社区版)部署 & 运行
云原生·eureka
gordon~91 小时前
Windows 11 wsl 中安装的Ubuntu-24.04 中装docker
windows·ubuntu·docker
进击切图仔2 小时前
Docker + tmux + ROS:持久化的机器人开发环境
docker·容器·机器人
春日见5 小时前
E2E自驾规控30讲:环境搭建
开发语言·驱动开发·matlab·docker·计算机外设
.生产的驴6 小时前
1Panel实战|SpringColud微服务部署生产环境一键部署Docker+Nacos+MySQL 数据定时备份 控制台 安全高效易维护
服务器·后端·mysql·spring cloud·docker·微服务·信息可视化
Exquisite.7 小时前
Docker容器技术
docker·容器·eureka
ai产品老杨7 小时前
异构计算时代的架构突围:基于 Docker 的 AI 视频平台如何实现 X86/ARM 与 GPU/NPU 全兼容(源码交付)
人工智能·docker·架构
Riemann~~7 小时前
dockerfile解析
docker·dockerfile
Sephiroth.Ma7 小时前
Mac 提示“Docker 已损坏,无法打开”?我这样排查后 10 分钟修好
macos·docker·容器