Docker sched_setscheduler() failed: Operation not permitted解决方案

Docker容器在默认运行的时候由于安全原因,限制了一些功能,如果需要开启需在运行时进行配置。

要使用实时调度需要 --cpu-rt-runtime 来运行容器。

sched_setscheduler()函数要求sys_nice能力,Docker容器在运行的时候默认是不开启的。

所以需要在运行的时候运行:docker run -ti --cpu-rt-runtime=95000 --ulimit rtprio=99 --cap-add=sys_nice ubuntu

在使用上述命令是可能会遇到错误cpu-rt-runtime写入失败,原因是cgroup parent 的cpu-rt-runtime比你要修改的小。

运行 docker run -it --privileged --pid=host ubuntu nsenter -t 1 -m

cd /sys/fs/cgroup/cpu/docker 

查看 cpu.rt_runtime_us是多少

cat cpu.rt_runtime_us

将它修改为950000

echo 950000>cpu.rt_runtime_us

紧接着再运行

docker run -ti --cap-add=sys_nice --cpu-rt-runtime --ulimit rtprio=99  ubuntu

就搞定啦

参考文章:https://github.com/moby/moby/pull/23430

https://github.com/moby/moby/issues/22380

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`sched_setscheduler` 是 Linux 系统调度程序的一个函数,它允许进程设置自己的调度策略和优先级。该函数可以用于实时进程或非实时进程。它的原型如下: ```c int sched_setscheduler(pid_t pid, int policy, const struct sched_param *param); ``` 其中,`pid` 是要设置的进程的 ID,`policy` 是调度策略,可以是 `SCHED_FIFO`、`SCHED_RR` 或 `SCHED_OTHER` 中的一个,`param` 是一个指向 `sched_param` 结构的指针,包含了进程的优先级等信息。 - `SCHED_FIFO`:先进先出调度策略。进程按照它们加入运行队列的顺序进行调度。如果一个进程一直保持在运行状态,那么它将一直占用 CPU 资源,其他进程可能得不到运行机会。 - `SCHED_RR`:时间片轮转调度策略。每个进程被分配一个时间片,当时间片用完后,进程被放回队列尾部,等待下一次调度。这种策略确保每个进程都有机会执行,并且可以防止某个进程长时间占用 CPU。 - `SCHED_OTHER`:普通调度策略。这是默认的调度策略,它不保证任何特定的调度行为。 `param` 结构包含了以下字段: ```c struct sched_param { int sched_priority; // 进程优先级 }; ``` `sched_priority` 字段用于设置进程的优先级。在 `SCHED_FIFO` 和 `SCHED_RR` 策略中,较高的优先级意味着进程更容易获得 CPU 时间片。在 `SCHED_OTHER` 策略中,该值不起作用。 调用 `sched_setscheduler` 函数后,相应的进程将按照指定的调度策略和优先级进行运行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值