啥叫sched-domain

这周问过公司里专家,说cpu-load是说CPU的计算能力,但是从代码实在不知道cpu-load说的是啥!

SD_SHARE_CPUPOWER 0X8000  domain的成员共享cpu power!

SD_SHARE_PKG_RESOURCES  domain成员共享pkg resource!

为什么要引入rt scale down的问题?

e9e9250bc78e7f6342517214c0178a529807964b

这个commit中的解释是:

sched: scale down cpu_power due to RT tasks

keep an average of amount of time spent on RT time and use the fraction to scale down the cpu_power for regular task,这个是

-------------------------------

sched_rt_avg_update 的巧妙计算方法:

static inline void sched_rt_avg_update(struct rq *rq, u64 rt_delta)

{

  rq->rq_avg += rt_data;

  sched_avg_update(rq);

}

void sched_avg_update(struct rq *rq)

{

  s64 period = sched_avg_period();

  while(s64(rq->clock - rq->age_stamp) > pereriod)) {

    rq->age_stamp += period;

    rq->rt_avg /= 2;

}

详细分析下上面的公式发生了啥,

while循环不断在把age_stamp往rq->clock上靠,但是

}

--------------------------------

这个值在初始化sched-group的时候用的最多,是说smt关系的看看cpu的能力到底是多少吗?

http://cache.baiducontent.com/c?m=9d78d513d98210fc06ba837f7d01d0120e55f0237ac0d16568d3e75f9214191c0231a3af60624e0b89833a2516ae3a41f7b57337200357e3d1cb8b4ccabbe57478ce3a77230b863711c419d9cb4523c023934de9d84aa6f8ba&p=993dc64ad4934eaf5be7e6291c7a93&newp=8f368d0a86cc41ac52fec7710f00c4231610db2151d4da01298ffe0cc4241a1a1a3aecbf21241406d3c2786206ae4e5deef034743d0034f1f689df08d2ecce7e3c&user=baidu&fm=sc&query=scale%5Frt%5Fpower&qid=ed7985e500042b74&p1=7

该函数用于计算指定CPU上可用于完全公平调度的CPU POWER统计值。

比如把整个CPU的Power 看为 SCHED_LOAD_SCALE,

该CPU上用于运行实时进程平均时间为rq->rt_avg.

那么可用于完全公平调度的时间就为 available = total - rq->avg.

然后 ( available / total ) * SCHED_LOAD_SCALE就是该CPU可用于运行非实时进程的Power值。

unsigned long scale_rt_power(int cpu)

{

struct rq *rq = cpu_rq(cpu);

u64 total, available;

sched_avg_update(rq);

total = sched_avg_period() + (rq->clock - rq->age_stamp);

available = total - rq->rt_avg;

if (unlikely((s64)total < SCHED_LOAD_SCALE))

total = SCHED_LOAD_SCALE;

total >>= SCHED_LOAD_SHIFT;

return div_u64(available, total);

}

时间: 2024-10-18 09:55:47

啥叫sched-domain的相关文章

Linux 内核引导参数简介

概述 内核引导参数大体上可以分为两类:一类与设备无关.另一类与设备有关.与设备有关的引导参数多如牛毛,需要你自己阅读内核中的相应驱动程序源码以获取其能够接受的引导参数.比如,如果你想知道可以向 AHA1542 SCSI 驱动程序传递哪些引导参数,那么就查看 drivers/scsi/aha1542.c 文件,一般在前面 100 行注释里就可以找到所接受的引导参数说明.大多数参数是通过"__setup(... , ...)"函数设置的,少部分是通过"early_param(..

Extjs event domain 研究

Listeners and Event Domains In Ext JS 4.2, the MVC event dispatcher was generalized with the introduction of event domains. These event domains intercepted events as they were fired and dispatched them to controllers controlled by selector matching.

跨域cors方法(jsonp,document.domain,document.name)及iframe性质

这里说的js跨域是指通过js在不同的域之间进行数据传输或通信,比如用ajax向一个不同的域请求数据,或者通过js获取页面中不同域的框架中(iframe)的数据.只要协议.域名.端口有任何一个不同,都被当作是不同的域. 下表给出了相对 http://store.company.com/dir/page.html 同源检测的结果: 要解决跨域的问题,我们可以使用以下几种方法: 1.通过jsonp跨域[解决ajax跨域] 在js中,我们直接用XMLHttpRequest请求不同域上的数据时,是不可以的

python的sched模块--延时调度

我们经常需要定时的执行某个任务,在Linux下我们有强大的crontab,但是在Python这个粒度(定时执行函数),如何处理呢?除了第三方的模块外,标准库为我们提供了sched模块和Timer类. 先说sched模块,准确的说,它是一个调度(延时处理机制),每次想要定时执行某任务都必须写入一个调度.使用步骤如下:(1)生成调度器:s = sched.scheduler(time.time,time.sleep)第一个参数是一个可以返回时间戳的函数,第二个参数可以在定时未到达之前阻塞.可以说sc

Python标准库笔记(5) — sched模块

事件调度 sched模块内容很简单,只定义了一个类.它用来最为一个通用的事件调度模块. class sched.scheduler(timefunc, delayfunc)这个类定义了调度事件的通用接口,它需要外部传入两个参数,timefunc是一个没有参数的返回时间类型数字的函数(常用使用的如time模块里面的time),delayfunc应该是一个需要一个参数来调用.与timefunc的输出兼容.并且作用为延迟多个时间单位的函数(常用的如time模块的sleep). 下面是一个列子: imp

https: could not reliably determine the server&#39;s fully qualified domain name, using localhost.localdomain.

1. 用记事本打开 将里面的 #ServerName localhost:80 注释去掉即可. 再执行 然后可以通过浏览器访问 http://localhost:80 ,如果页面显示 "It works!" ,即表示apache已安装并启动成功. 或者使用 curl http://localhost:80 参考:http://www.cnblogs.com/52linux/archive/2012/03/24/2415637.html https: could not reliably

网络yum 安装 httpd 出现的问题Could not reliably determine the server&#39;s fully qualified domain name

Could not reliably determine the server's fully qualified domain name 在使用网络yum源安装httpd的时候出现了上面的报错,进入配置文件httpd.conf [[email protected] ~]# cd /etc//httpd/conf [[email protected] conf]# ls httpd.conf  magic [[email protected] conf]#vim httpd.conf 276 #

Active Directory Domain Service

AD DS Design Single forest single domain is preferred Time is important (PDC) Implement multiple/backup domain controllers 2,150,000,000 objects per domain FQDN less than 64 characters FSMO (Flexible single master operation) Forest level To make chan

weblogic管理1——创建 和 删除一个domain

说明本文环境  WLS_HOME=/home/weblogic/Oracle/Middleware 创建一个domian   第一种方法通过console 创建> [[email protected] Middleware]$ cd /home/weblogic/Oracle/Middleware/wlserver_10.3/common/bin[[email protected] bin]$ lltotal 112-rwxr-x---. 1 weblogic weblogic 22872 No

Lind.DDD.Domain.IOwnerBehavor对实体的意义

回到目录 对于Lind.DDD架构,我之前写了不少文章,对于它的Domain模式也介绍了不少,像之前的IEntity,ILogicDeleteBehavor,IModifyBehavor,IStatusBehavor和ISortBehavor都有自己的功能,只要实体实现对外的接口,就具有了某种特性或者某种功能,而今天主要说一下拥有者接口,IOwnerBehavor,它主要用在管理系统的实体中,如一个员工资产表,当这个员工离职后,它对应资产将被进行转移,转移到一个新的用户身上,而这个用户就是这个资