手动修改docker中oceanbase-ce容器cpu资源使用上限

##docker中oceanbase-ce 容器占用cpu100% 使用cgroup限制cpu使用上限

top - 16:30:22 up 36 min,  1 user,  load average: 7.34, 10.62, 8.99
Tasks: 400 total,   1 running, 399 sleeping,   0 stopped,   0 zombie
%Cpu(s):  3.5 us,  1.3 sy,  0.0 ni, 94.9 id,  0.1 wa,  0.0 hi,  0.1 si,  0.0 st
MiB Mem :  25977.1 total,  10481.9 free,  12087.6 used,   3407.6 buff/cache
MiB Swap:   2048.0 total,   2048.0 free,      0.0 used.  13603.8 avail MemPID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND16055 yym       20   0 9088776   5.1g 106264 S  100  20.2   6:15.66 observer

oceanbase-ce 的observer占用100%cpu,手动修改docker容器cpu资源使用上限

##ubuntu20 docker使用是cgroup驱动是cgroupfs

##cgroup挂载点如下

yym@ubuntu20:~$ mount | grep cgroup
tmpfs on /sys/fs/cgroup type tmpfs (ro,nosuid,nodev,noexec,mode=755,inode64)
cgroup2 on /sys/fs/cgroup/unified type cgroup2 (rw,nosuid,nodev,noexec,relatime,nsdelegate)
cgroup on /sys/fs/cgroup/systemd type cgroup (rw,nosuid,nodev,noexec,relatime,xattr,name=systemd)
cgroup on /sys/fs/cgroup/memory type cgroup (rw,nosuid,nodev,noexec,relatime,memory)
cgroup on /sys/fs/cgroup/hugetlb type cgroup (rw,nosuid,nodev,noexec,relatime,hugetlb)
cgroup on /sys/fs/cgroup/net_cls,net_prio type cgroup (rw,nosuid,nodev,noexec,relatime,net_cls,net_prio)
cgroup on /sys/fs/cgroup/cpu,cpuacct type cgroup (rw,nosuid,nodev,noexec,relatime,cpu,cpuacct)
cgroup on /sys/fs/cgroup/pids type cgroup (rw,nosuid,nodev,noexec,relatime,pids)
cgroup on /sys/fs/cgroup/rdma type cgroup (rw,nosuid,nodev,noexec,relatime,rdma)
cgroup on /sys/fs/cgroup/freezer type cgroup (rw,nosuid,nodev,noexec,relatime,freezer)
cgroup on /sys/fs/cgroup/perf_event type cgroup (rw,nosuid,nodev,noexec,relatime,perf_event)
cgroup on /sys/fs/cgroup/cpuset type cgroup (rw,nosuid,nodev,noexec,relatime,cpuset)
cgroup on /sys/fs/cgroup/blkio type cgroup (rw,nosuid,nodev,noexec,relatime,blkio)
cgroup on /sys/fs/cgroup/devices type cgroup (rw,nosuid,nodev,noexec,relatime,devices)
cgroup on /sys/fs/cgroup/misc type cgroup (rw,nosuid,nodev,noexec,relatime,misc)
yym@ubuntu20:~$ docker info | grep "Cgroup Driver"Cgroup Driver: cgroupfs

##ubuntu20 下 Docker 容器的 cgroup 限制文件目录/sys/fs/cgroup/<控制器>/docker/<容器ID>

cd /sys/fs/cgroup/cpu/docker/cd619119e81f9d499b74a80b9e16a94ce1db8ffbb2e98c82b12e6271172f743e

echo 100000 > cpu.cfs_period_us # 假设周期为100ms

echo 50000 > cpu.cfs_quota_us # 配额为周期的一半,即50%

yym@ubuntu20:/sys/fs/cgroup/cpu/docker/cd619119e81f9d499b74a80b9e16a94ce1db8ffbb2e98c82b12e6271172f743e$ cd /sys/fs/cgroup/cpu/docker/cd619119e81f9d499b74a80b9e16a94ce1db8ffbb2e98c82b12e6271172f743e
yym@ubuntu20:/sys/fs/cgroup/cpu/docker/cd619119e81f9d499b74a80b9e16a94ce1db8ffbb2e98c82b12e6271172f743e$ echo 100000 > cpu.cfs_period_us
-bash: cpu.cfs_period_us: Permission denied
yym@ubuntu20:/sys/fs/cgroup/cpu/docker/cd619119e81f9d499b74a80b9e16a94ce1db8ffbb2e98c82b12e6271172f743e$ su root
Password:
root@ubuntu20:/sys/fs/cgroup/cpu/docker/cd619119e81f9d499b74a80b9e16a94ce1db8ffbb2e98c82b12e6271172f743e# echo 100000 > cpu.cfs_period_us
root@ubuntu20:/sys/fs/cgroup/cpu/docker/cd619119e81f9d499b74a80b9e16a94ce1db8ffbb2e98c82b12e6271172f743e# echo 50000 > cpu.cfs_quota_us
root@ubuntu20:/sys/fs/cgroup/cpu/docker/cd619119e81f9d499b74a80b9e16a94ce1db8ffbb2e98c82b12e6271172f743e# exit

##改完之后oceanbase-ce 的observer进程使用cpu下降到50左右

top - 16:38:55 up 45 min,  1 user,  load average: 6.29, 6.63, 7.50
Tasks: 400 total,   2 running, 398 sleeping,   0 stopped,   0 zombie
%Cpu(s):  3.3 us,  1.0 sy,  0.0 ni, 95.5 id,  0.1 wa,  0.0 hi,  0.1 si,  0.0 st
MiB Mem :  25977.1 total,  10215.8 free,  12279.1 used,   3482.1 buff/cache
MiB Swap:   2048.0 total,   2048.0 free,      0.0 used.  13412.2 avail MemPID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND16055 yym       20   0 9090312   5.1g 106680 S  49.0  20.3  12:08.20 observer

##ubuntu22 下使用cgroup2 统一挂载点,Cgroup Driver: systemd

yym@ubantu22:/sys/fs/cgroup/system.slice/docker-e282c2cc4479a8ac7a6ec0b228cc6586d52593aae3c3cb7c5b3429384c2c8800.scope$ mount | grep cgroup
cgroup2 on /sys/fs/cgroup type cgroup2 (rw,nosuid,nodev,noexec,relatime,nsdelegate,memory_recursiveprot)
yym@ubantu22:/sys/fs/cgroup/system.slice/docker-e282c2cc4479a8ac7a6ec0b228cc6586d52593aae3c3cb7c5b3429384c2c8800.scope$ docker info | grep "Cgroup Driver"Cgroup Driver: systemd
yym@ubantu22:/sys/fs/cgroup/system.slice/docker-e282c2cc4479a8ac7a6ec0b228cc6586d52593aae3c3cb7c5b3429384c2c8800.scope$ su root
Password:
root@ubantu22:/sys/fs/cgroup/system.slice/docker-e282c2cc4479a8ac7a6ec0b228cc6586d52593aae3c3cb7c5b3429384c2c8800.scope# ##echo 50 > cpu.weight
root@ubantu22:/sys/fs/cgroup/system.slice/docker-e282c2cc4479a8ac7a6ec0b228cc6586d52593aae3c3cb7c5b3429384c2c8800.scope# echo 50000 100000 > cpu.max

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/15202.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前端菜鸡,对于35+程序员失业这个事有点麻了

“经常看到30岁程序员失业的新闻&#xff0c;说实话&#xff0c;有点麻。目前程序员供求关系并未失衡&#xff0c;哪怕是最基础的前端或者后台、甚至事务型的岗位也是足够的。 事实上&#xff0c;现在一个开出的岗位要找到一位尽职尽责能顺利完成工作的程序员并不是一件那么容…

Electron-1 electorn + vue3 + vite项目搭建,使用Electron-vite构建工具

文章目录 1.创建项目存在的问题 1.创建项目存在的问题 使用框架 : 现有的构建插件&#xff0c;使用也不错&#xff0c;但是封装过的&#xff0c;且各个版本不统一&#xff0c;想修改时会出现各种问题 比较不错的有如下几个 https://cn.electron-vite.org/guide/ https://www.el…

C++_string简单源码剖析:模拟实现string

文章目录 &#x1f680;1.构造与析构函数&#x1f680;2.迭代器&#x1f680;3.获取&#x1f680; 4.内存修改&#x1f680;5. 插入&#x1f680;6. 删除&#x1f680;7. 查找&#x1f680;8. 交换swap&#x1f680;9. 截取substr&#x1f680;10. 比较符号重载&#x1f680;11…

副业树洞聊天项目/树洞倾诉/陪陪系统源码/树洞源码下载搭建

随着社会的发展和人们生活水平的提高&#xff0c;越来越多的人在面临心理压力、情感困扰或生活困境时&#xff0c;需要一个可以宣泄、倾诉和寻求支持的平台。而传统的人际交往方式往往会遇到难以排解的问题&#xff0c;比如担心被他人知晓自己的隐私等&#xff0c;这就导致了人…

package.json中peerDependencies的使用场景

文章目录 peerDependencies 的使用场景peerDependencies 的使用案例为什么使用 peerDependencies需要注意的事项主要作用 ✍创作者&#xff1a;全栈弄潮儿 &#x1f3e1; 个人主页&#xff1a; 全栈弄潮儿的个人主页 &#x1f3d9;️ 个人社区&#xff0c;欢迎你的加入&#xf…

DNS服务的部署与配置(1)

一、DNS的定义 1、域名系统&#xff08;英文&#xff1a;Domain Name System&#xff0c;缩写&#xff1a;DNS&#xff09;是互联网的一项服务。 它作为将域名和IP地址相互映射的一个分布式数据库&#xff0c;能够使人更方便地访问互联网。 DNS使用UDP端口53。 当前&#xff0…

超简单白话文机器学习 - 回归树树剪枝(含算法介绍,公式,源代码实现以及调包实现)

1. 回归树 1.1 算法介绍 大家看到这篇文章时想必已经对树这个概念已经有基础了&#xff0c;如果不是很了解的朋友可以看看笔者的这篇文章&#xff1a; 超简单白话文机器学习-决策树算法全解&#xff08;含算法介绍&#xff0c;公式&#xff0c;源代码实现以及调包实现&#x…

BL121DT网关在智能电网分布式能源管理中的应用钡铼技术协议网关

随着全球能源结构的转型和智能电网技术的飞速发展&#xff0c;分布式能源管理系统在提高能源利用效率、促进可再生能源接入及保障电网稳定运行方面发挥着日益重要的作用。然而&#xff0c;分布式能源系统内设备种类繁多&#xff0c;通信协议各异&#xff0c;如何高效整合这些设…

如何从http免费升级到https

使用https协议开头是为了在用户访问网站时提供更安全的网络环境。相比http&#xff0c;使用https有数据加密、身份验证、保护隐私、搜索引擎优化等优势。一般获取https证书&#xff0c;则需要支付费用给证书颁发机构&#xff08;CA&#xff09;。还有一些免费的证书证书颁发机构…

PostgreSQL角色迁移原理简述

概述 本文描述PostgreSQL角色迁移的流程&#xff0c;基于该方案可通过Java、Python等语言开发PostgreSQL角色迁移工具。 使用pg_dumpall导出角色 通过PostgreSQL数据库提供的pg_dumpall命令可以导出roles定义。 $ pg_dumpall --roles only CREATE ROLE test_role; ALTER RO…

测试之Springboot应用

测试之Spring Boot应用 在软件开发过程中&#xff0c;测试是确保代码质量的重要环节。本文将介绍针对Spring Boot应用的单元测试、集成测试和端到端测试的策略&#xff0c;以及如何使用Mock对象和测试切片来模拟外部依赖。同时&#xff0c;我们将使用JUnit和Spring Test框架进…

简述分代垃圾回收器是怎么工作的?

分代垃圾回收器是一种用于管理和回收内存中垃圾对象的技术。它根据对象的存活时间将内存分为不同的代&#xff0c;并针对每个代应用不同的垃圾回收策略。 分代垃圾回收器的工作过程如下&#xff1a; 内存分代&#xff1a;首先&#xff0c;将内存分为不同的代&#xff0c;通常是…

解决 SpringBoot 的 Date、LocalDateTime 变成时间戳和数组的问题,创建自定义对象消息转换器

问题描述 SpringBoot 项目&#xff0c;当返回前端的数据类型为 Map 的时候&#xff0c;在 Map 中 put() 时间对象会出现以下问题&#xff1a; 传递的 Date 对象会变成时间戳传递的 LocalDateTime 对象会变成数组 问题复现 编写一个 Controller 方法&#xff0c;返回值为 Ma…

Java并发: 基于Unsafe的CAS实现无锁数据结构

在上一篇Java并发: 面临的挑战文章中说过CAS是解决原子性问题的方案之一。Unsafe提供了CAS的支持&#xff0c;支持实例化对象、访问私有属性、堆外内存访问、线程的启停等功能。 许多Java的并发类库都是基于Unsafe实现的&#xff0c;比如原子类AtomicInteger&#xff0c;并发数…

多线程(C++11)

多线程&#xff08;C&#xff09; 文章目录 多线程&#xff08;C&#xff09;前言一、std::thread类1.线程的创建1.1构造函数1.2代码演示 2.公共成员函数2.1 get_id()2.2 join()2.3 detach()2.4 joinable()2.5 operator 3.静态函数4.类的成员函数作为子线程的任务函数 二、call…

【Linux学习】深入探索进程等待与进程退出码和退出信号

文章目录 退出码return退出 进程的等待进程等待的方法 退出码 main函数的返回值&#xff1a;进程的退出码。 一般为0表示成功&#xff0c;非0表示失败。 每一个非0退出码都表示一个失败的原因&#xff1b; echo $&#xff1f;命令 作用&#xff1a;查看进程退出码。&#xf…

I.MX6ULL Linux C语言开发环境搭建(点灯实验)

系列文章目录 I.MX6ULL Linux C语言开发 I.MX6ULL Linux C语言开发 系列文章目录一、前言二、硬件原理分析三、构建步骤一、 C语言运行环境构建二、软件编写三、链接脚本 四、实验程序编写五、编译下载验证 一、前言 汇编语言编写 LED 灯实验&#xff0c;但是实际开发过程中汇…

Go语言的内存泄漏如何检测和避免?

文章目录 Go语言内存泄漏的检测与避免一、内存泄漏的检测1. 使用性能分析工具2. 使用内存泄漏检测工具3. 代码审查与测试 二、内存泄漏的避免1. 使用defer关键字2. 使用垃圾回收机制3. 避免循环引用4. 使用缓冲池 Go语言内存泄漏的检测与避免 在Go语言开发中&#xff0c;内存泄…

【已解决】C#设置Halcon显示区域Region的颜色

前言 在开发过程中&#xff0c;突然发现我需要显示的筛选区域的颜色是白色的&#xff0c;如下图示&#xff0c;这对我们来说不明显会导致我的二值化筛选的时候存在误差&#xff0c;因此我们需要更换成红色显示这样的话就可以更加的明显&#xff0c;二值化筛选更加的准确。 解…

java: 无法访问org.springframework.ldap.core.LdapTemplate

完整错误&#xff1a; java: 无法访问org.springframework.ldap.core.LdapTemplate错误的类文件: /E:/apache-maven-3.6.3/repository/org/springframework/ldap/spring-ldap-core/3.2.3/spring-ldap-core-3.2.3.jar!/org/springframework/ldap/core/LdapTemplate.class类文件具…