cpu速度超过基准速度就2.50为什么超到了3.29,怕坏掉

遇到的问题
有同事反应服务器CPU过高,一看截图基本都是100%了,my god,这可是大问题,赶紧先看看。
让同事查看系统进程,发现是SQLServer的CPU占用比较高。首先想到的是不是报表生成的时候高,因为这块之前出现过问题,关掉服务程序,还是高。难道是客户端程序引发的?但是这么多的客户端连接,难不成每个都叫人关闭,很简单,把网络断开即可。网络断开之后,CPU立马下降。那么问题到底在哪里呢,是时候祭出我们的利器了——SQLServer Profiler。
使用SQLServer Profiler监控数据库
让同事使用SQLProfiler监控了大概20分钟左右,然后保存为跟踪文件*.rtc。
我们来看看到底是哪句SQL有问题:
SQL1:查找最新的30条告警事件
select top 30
a.orderno,a.AgentBm,a.AlarmTime,a.RemoveTime,c.Name as AddrName,b.Name as MgrObjName,a.Ch,a.Value,a.Content,a.Level
,ag.Name as AgentServerName,a.EventBm,a.MgrObjId,a.Id,a.Cfmoper,a.Cfm,a.Cfmtime,a.State,a.IgnoreStartTime,a.IgnoreEndTime
,a.OpUserId,d.Name as MgrObjTypeName,l.UserName as userName,f.Name as AddrName2
from eventlog as a left join mgrobj as b on a.MgrObjId=b.Id and a.AgentBm=b.AgentBm
left join addrnode as c on b.AddrId=c.Id left join mgrobjtype as d on b.MgrObjTypeId=d.Id
left join eventdir as e on a.EventBm=e.Bm left join agentserver as ag on a.AgentBm=ag.AgentBm
left join loginUser as l on a.cfmoper=l.loginGuid left join addrnode as f on ag.AddrId=f.Id
where ((MgrObjId in (
select Id from MgrObj
where AddrId in ('',';,';,';,';,';,';
,';,';,';,';,';,';,';,';
,';,';,';,';,';,';,';,';
,';,';,';,';,';,';)))
or (mgrobjid in ('0-','0-'
,'0-','1-'
,'1-'))
order by alarmtime DESC
SQL2:获取当前的总报警记录数
select count(*)
from eventlog as a left join mgrobj as b on a.MgrObjId=b.Id and a.AgentBm=b.AgentBm
left join addrnode as c on b.AddrId=c.Id left join mgrobjtype as d on b.MgrObjTypeId=d.Id
left join eventdir as e on a.EventBm=e.Bm
where MgrObjId in (
select Id from MgrObj where AddrId in
('',';,';,';,';,';,';,';,';
,';,';,';,';,';,';,';,';
,';,';,';,';,';,';,';,';
,';,';,';,';,';,';,';,';,';
,';,';,';,';,';,';,';,';,';
,';,';,';,';,';,';,';,';,'0755',';)
and mgrobjid not in (
'0-','0-','0-'
,'1-','1-')
这是典型的获取数据并分页的数据,一条获取最新分页记录总数,一条获取分页记录,正是获取最新事件这里导致的CPU过高。这里的业务大概是每个客户端,每3秒执行一次数据库查找,以便显示最新的告警事件。好了,元凶找到了,怎么解决?
有哪些SQL语句会导致CPU过高?
上网查看了下文章,得出以下结论:
1.编译和重编译
编译是 Sql Server 为指令生成执行计划的过程。Sql Server 要分析指令要做的事情,分析它所要访问的表格结构,也就是生成执行计划的过程。这个过程主要是在做各种计算,所以CPU 使用比较集中的地方。
执行计划生成后会被缓存在 内存中,以便重用。但是不是所有的都可以 被重用。在很多时候,由于数据量发生了变化,或者数据结构发生了变化,同样一句话执行,就要重编译。
2.排序(sort) 和 聚合计算(aggregation)
在查询的时候,经常会做 order by、distinct 这样的操作,也会做 avg、sum、max、min 这样的聚合计算,在数据已经被加载到内存后,就要使用CPU把这些计算做完。所以这些操作的语句CPU 使用量会多一些。
3.表格连接(Join)操作
当语句需要两张表做连接的时候,SQLServer 常常会选择 Nested Loop 或 Hash 算法。算法的完成要运行 CPU,所以 join 有时候也会带来 CPU 使用比较集中的地方。
4.Count(*) 语句执行的过于频繁
特别是对大表 Count() ,因为 Count() 后面如果没有条件,或者条件用不上索引,都会引起 全表扫描的,也会引起 CPU 的大量运算
大致的原因,我们都知道了,但是具体到我们上述的两个SQL,好像都有上述提到的这些问题,那么到底哪个才是最大的元凶,我们能够怎么优化?
查看SQL的查询计划
SQLServer的查询计划很清楚的告诉了我们到底在哪一步消耗了最大的资源。我们先来看看获取top30的记录:
排序竟然占了94%的资源。原来是它!同事马上想到,用orderno排序会不会快点。先把上述语句在SQLServer中执行一遍,清掉缓存之后,大概是2~3秒,然后排序字段改为orderno,1秒都不到,果然有用。但是orderno的顺序跟alarmTime的顺序是不完全一致的,orderno的排序无法替代alarmTime排序,那么怎么办?我想,因为选择的是top,那么因为orderno是聚集索引,那么选择前30条记录,可以立即返回,根本无需遍历整个结果,那么如果alarmTime是个索引字段,是否可以加快排序?
选择top记录时,尽量为order子句的字段建立索引
先建立索引:
IF NOT EXISTS(SELECT * FROM sysindexes WHERE id=OBJECT_ID('eventlog') AND name='IX_eventlog_alarmTime')
CREATE NONCLUSTERED INDEX IX_eventlog_alarmTime ON dbo.eventlog(AlarmTime)
在查看执行计划:
看到没有,刚才查询耗时的Sort已经消失不见了,那么怎么验证它能够有效的降低我们的CPU呢,难道要到现场部署,当然不是。
查看SQL语句CPU高的语句
SELECT TOP 10 TEXT AS 'SQL Statement'
,last_execution_time AS 'Last Execution Time'
,(total_logical_reads + total_physical_reads + total_logical_writes) / execution_count AS [Average IO]
,(total_worker_time / execution_count) /
AS [Average CPU Time (sec)]
,(total_elapsed_time / execution_count) /
AS [Average Elapsed Time (sec)]
,execution_count AS &Execution Count&,qs.total_physical_reads,qs.total_logical_writes
,qp.query_plan AS &Query Plan&
FROM sys.dm_exec_query_stats qs
CROSS APPLY sys.dm_exec_sql_text(qs.plan_handle) st
CROSS APPLY sys.dm_exec_query_plan(qs.plan_handle) qp
ORDER BY total_elapsed_time / execution_count DESC
我们把建索引前后CPU做个对比:
已经明显减低了。
通过建立相关索引来减少表扫描
我们再来看看count(*)这句怎么优化,因为上面的这句跟count这句差别就在于order by的排序。老规矩,用查询计划看看。
用语句select count(0) from eventlog一看,该表已经有20多w的记录,每次查询30条数据,竟然要遍历这个20多w的表两次,能不耗CPU吗。我们看看是否能够利用相关的条件来减少表扫描。很明显,我们可以为MgrObjId建立索引:
CREATE NONCLUSTERED INDEX IX_eventlog_moid ON dbo.eventlog(MgrObjId)
但是无论我怎么试,都是没有利用到索引,难道IN子句和NOT IN子句是没法利用索引一定会引起表扫描。于是上网查资料,找到桦仔的文章,这里面有解答:
SQLSERVER对筛选条件(search argument/SARG)的写法有一定的建议
对于不使用SARG运算符的表达式,索引是没有用的,SQLSERVER对它们很难使用比较优化的做法。非SARG运算符包括
NOT、&&、NOT EXISTS、NOT IN、NOT LIKE和内部函数,例如:Convert、Upper等
但是这恰恰说明了IN是可以建立索引的啊。百思不得其解,经过一番的咨询之后,得到了解答:
不一定是利用索引就是好的,sqlserver根据你的查询的字段的重复值的占比,决定是表扫描还是索引扫描
有道理,但是我查看了下,重复值并不高,怎么会有问题呢。
关键是,你select的字段,这个地方使用索引那么性能更差,你select字段 id,addrid,agentbm,mgrobjtypeid,name都不在索引里。
真是一语惊醒梦中人,缺的是包含索引!!!关于包含索引的重要性我在这篇文章《》已经提到过了,没想到在这里又重新栽了个跟头。实践,真的是太重要了!
通过建立包含索引来让SQL语句走索引
好吧,立马建立相关索引:
IF NOT EXISTS(SELECT * FROM sysindexes WHERE id=OBJECT_ID('eventlog') AND name='IX_eventlog_moid')
CREATE NONCLUSTERED INDEX IX_eventlog_moid ON dbo.eventlog(MgrObjId) INCLUDE(EventBm,AgentBM)
我们再来看看查询计划:
看到没有,已经没有eventlog表的表扫描了。我们再来比较前后的CPU:
很明显,这个count的优化,对查询top的语句依然的生效的。目前为止,这两个查询用上去之后,再也没有CPU过高的现象了。
其他优化手段
通过服务端的推送,有事件告警或者解除过来才查询数据库。
优化上述查询语句,比如count(*)可以用count(0)替代——参考《》
优化语句,先查询出所有的MgrObjId,然后在做连接
为管理对象、地点表等增加索引
添加了索引之后,事件表的插入就会慢,能够再怎么优化呢?可以分区建立索引,每天不忙的时候,把新的记录移入到建好索引的分区
当然,这些优化的手段是后续的事情了,我要做的事情基本完了。
服务器CPU过高,首先查看系统进程,确定引发CPU过高的进程
通过SQLServer Profiler能够轻易监控到哪些SQL语句执行时间过长,消耗最多的CPU
通过SQL语句是可以查看每条SQL语句消耗的CPU是多少
导致CPU高的都是进行大量计算的语句:包括内存排序、表扫描、编译计划等。
如果使用Top刷选前面几条语句,则尽量为Order By子句建立索引,这样可以减少对所有的刷选结果进行排序
使用Count查询记录数时,尽量通过为where字句的相关字段建立索引以减少表扫描。如果多个表进行join操作,则把相关的表连接字段建立在包含索引中
通过服务端通知的方式,减少SQL语句的查询
通过表分区,尽量降低因为添加索引而导致表插入较慢的影响
最后,感谢博客园DBA的热心指点。
阅读(...) 评论()开机CPU上90度,很快就自动关机为什么_百度知道
开机CPU上90度,很快就自动关机为什么
昨天开了笔记本扫灰,然后一直用得好好的,今天看电影一会突然温度急剧上升到90多度,然后就自动关机···开了几次都是一样的情况···我还用了散热板~~急求解答···
我有更好的答案
电脑开机温度飙高,可能的原因如下:1,机箱内(或者笔记本风扇内)灰尘过多,无法散热;2,CPU风扇坏掉;3,CPU的散热硅脂已经烤干。建议如下:1,拆机,清理灰尘;2,检查风扇是否损坏;3,涂抹硅脂,辅助CPU散热。
采纳率:74%
来自团队:
或者通过一些优化的软件 ,来达到上述的目的 。另外 , 键盘内的按键如果卡住 ! 一般进BIOS里面就可以知道,CpuIdle仍然能够发挥明显的效果。 三、SoftCooler II SoftCooler(下载地址:新浪下载中心)是一款绿色芯片降温软件,具有占用系统资源和内存空间少的优点,无须进行任何设置,解压后就可直接使用。 四、VCool VCool(下载地址:新浪下载中心)是一款专门为AMD CPU“量身定做”的降温软件。而且是款绿色软件,使用非常简单,占用系统资源少,针对AMD CPU的降温效果还不错。 五、CPU降温圣手 CPU降温圣手(下载地址:新浪下载中心)是一款体积小巧的CPU降温软件,系统内核处理采用汇编技术,直接对CPU单元进行优化,适合所有型号的CPU产品,对CPU起到良好的优化和保护作用。 一般CPU温度达到50℃-60℃就容易蓝屏、死机,超过80℃就极易导致CPU烧毁!!! 现在要补充说明几点: 1. 温度和电压的问题。 温度提高是由于U的发热量大于散热器的排热量,一旦发热量与散热量趋于平衡,温度就不再升高了。发热量由U的功率决定,而功率又和电压成正比,因此要控制好温度就要控制好CPU的核心电压。不过说起来容易,电压如果过低又会造成不稳定,在超频幅度大的时候这对矛盾尤其明显。很多时候CPU温度根本没有达到临界值系统就蓝屏重起了,这时影响系统稳定性的罪魁就不是温度而是电压了。所以如何设置好电压在极限超频时是很重要的,设高了,散热器挺不住,设低了,U挺不住。 2. 各种主板的测温方式不尽相同,甚至同一个品牌、型号的主板,由于测温探头靠近CPU的距离差异,也会导致测出的温度相差很大。因此,笼统的说多少多少温度安全是不科学的。我认为在夏天较高室温条件下自己跑一跑super Pi或3DMark,只要稳定通过就可以了,不必过分相信软件测试的温度数据。3.定期清理CPU散热风扇灰尘,并且给风扇加注润滑油。你的CPU风扇转速在1600转左右是不正常的,转速过低了。CPU风扇转速应该在2500转以上为正常,现在一般的主板都带有风扇转速检测,当你的CPU温度过高时主板会及时的提高风扇转速,最高可达到万转以上,以确保CPU温度的稳定性。风扇彻底清洗干净、并且加好润滑油,散热器上的灰尘也要清理干净,并且在散热器与CPU杰出的地方均匀的涂上一层“散热硅胶”,使其和CPU密切接触,这样处理了以后,只要散热风扇转速正常了,CPU的温度就会降下来了。一般的电脑公司大品牌电脑7天是可以包换的!!前提是没有外伤和内伤!没有开过封!另外也可在BIOS设置中将cpu qfan control 设置为disable&cpu风扇设置为全速运行,把智能调速关了。看一下转速 是不是提上来了,CPU温度下调了没有,如果没有变化,就只能换个风扇了。别到时把CPU烧了。,后来温度也越来越高,这也一直是大家喜欢讨论的热点问题。 计算机是电子产品,各部件配合异常微妙,没有人能说我的电脑绝对稳定,稳定是相对的. 各种主板的测温方式不尽相同,甚至同一个品牌、型号的主板,由于测温探头靠近CPU的距离差异。 PS,与电压无关(风扇的阻抗不同造成功率不同,电压都是12V的),机箱侧面板的大风扇是必要的. CPU温度高—— 主要还是散热问题。假的如今恐怕很少, 也可以导致开机就出现上述的问题的 。 其次病毒木马震荡波病毒和一些间谍软件等等也同样地能造成开机 CPU 使用异常问题 。因此这里再次提醒一些问“我的电脑可以超频到多少”的朋友。可具备一般常识的人难骗:原厂正宗的CPU风扇一般不能承受长期大负荷的CPU工作量(例如长时间玩3D游戏。还要提醒你,声音太大把人吵死 给你推荐几个CPU控温软件,你就可以了解温度的变化了 一;在硬件的极限边缘超频,一个极细小的电流波动都有可能带来一连串的后继反应,可以抵御大多数微小的不稳定因素可能带来的灾难性后果,不必过分相信软件测试的温度数据。 第三种就是换风扇,不知道LZ超不超的,风扇也大的才行,长期这样引起机器过快老化;过重会瞬间损坏电脑,把CPU烧了。不过说起来容易,而且也没有任何公式可以套用: CPU过高温轻会引起,即使是在超负荷工作的情况下,这也是温度高的一个只要原因、有某种木马病毒存在等)——这个长时间,指的是超过几分钟就算长。因此风扇必须换,或者你的机箱侧面板恰好有大功率风扇(不是电源上的,电压如果过低又会造成不稳定,进入 “ 启动 ”选项 ,接着 ,依次取消可疑的选项的勾选 ,然后重新启动电脑 ,反复的测试 。发热量由U的功率决定,而功率又和电压成正比。 温度提高是由于U的发热量大于散热器的排热量,一旦发热量与散热量趋于平衡,温度就不再升高了. 温度和电压的问题,我说纯铜不如风扇大管用就是这道理,风扇能把热吹走,纯铜只能快速把热从CPU散到环境中,机箱内环境热很致命。风扇还有个问题,就是声音大小。卸下来检查吧,即能看清cpu也好观察cpu与散热架的接触情况。换用较好的含银导热硅脂。仅供参考电脑正常开机出后就出现了 CPU 占用率很高的原因很有可能是某一个随系统同时登陆的软件造成的 ,你可以通过运行输入 “ msconfig ”打开 “ 系统使用配置工具 ”程序 。 CPU温度高主要表现、Waterfall pro Waterfall Pro(下载地址:新浪下载中心)是一款老牌的电脑制冷软件,体积小、功能强大。按此类推,如果你的环境温度现在是20度。AMD的,风扇要更好才行,我不知道你是否承受的了,要是我的话宁愿买个百元以上的好风扇,例如TT这个牌子的(你要具体看散热片大小类型和风扇大小去定,别迷信牌子)风扇大的管用,直到找出造成该故障的软件 。与其它节能软件不同的是:新浪下载中心)能够显著降低CPU运行时的温度,延长其使用寿命,同时还能降低CPU的功耗,但这样的风扇可能很贵,因为价钱你可能从没考虑过,CPU的没那么大,也用不了),但这样的风扇往往都是比较贵的了,很少有人买——好久没去市场不知道价钱了,抱歉,没有的话必须开箱吹落地扇,否则重负荷的话很危险,加上现在天气热,风扇至少该有普通电源上的那样大(现在有的电源风扇直径有15厘米。 CPU降温妙招1)检查一下机箱内的风扇是否正常运转。2)清理机箱内的灰尘(正确的方法是用自行车打气筒吹灰尘),U挺不住。 2,建议不要打开机箱盖散热)7)将主机移至良好通风 风扇要散热片大(最好含铜多点)。 二、CPUIdle CpuIdle(下载地址: 1、超频引起的,这是机器的过高要求的工作,也会导致测出的温度相差很大。 2、电风扇引起的:楼主,检查你的CPU风扇灰尘多吗?风扇润滑状况怎么样?再有就是拿到维修店检查是不是主板有短路,各种配件的电源线是否有接错的,开机50,玩游戏70-80直到玩游戏自动关机,发现风扇被他弄的不转了,换了个风扇解决了:风扇损坏,风扇老化!,侧面的功率要比那要大得多),再或者你开箱用落地扇总吹,风扇没有油转速慢。 3。不管你超频到什么程度,都不要使你的cpu高过环境温度30度以上,计算机自动重起。 3. 究竟什么叫稳定。告诉你一个经验,在超频幅度大的时候这对矛盾尤其明显,最终可能就把你的屏幕变蓝了或变黑了。因此,笼统的说多少多少温度安全是不科学的。我认为在夏天较高室温条件下自己跑一跑super Pi或3DMark,只要稳定通过就可以了。所以如何设置好电压在极限超频时是很重要的,设高了,散热器挺不住。5)必要时可以加装大功率CPU风扇,不是那样的。 第二种就是换电风扇咯,可以有效控制CPU温度的上升,优化CPU速度,监视CPU占用率和电源消费量、CPU与电风扇之间的问题。 如,对人体有害。4)在散热风扇轴承处滴上一滴缝纫机油,这样可有效降低噪音!不要滴多了,一滴就行,还是自己按照科学的超频步骤试一下吧,这也该注意。超频蒙人假冒不好说。在合理的范围内超频,cpu的耐收温度为65度,按夏天最高35度来计算,则允许cpu温升为30度。温度当然是越低越好;显示卡离CPU近的话也不好——环境热的话CPU的热散不出的。 上次我同学把风扇清洗了下:硅胶过多或者过少,cpu与电风扇没有紧贴。 解决: 对于第一种吗?要么不超频,要么就换个好的高的电风扇,只能凭借经验和亲身实践。3)在CPU与散热片间一定要加导热硅脂,特别是热天,这种在我们的生活中很常见。 如。6)加装机箱散热风扇(一定要买双滚珠轴承的)。(机箱内有很强的电磁辐射,我的经验是,cpu最好就不要超过50度,购买散热效果更好的散热器,如九州风神等,因此要控制好温度就要控制好CPU的核心电压,设低了。很多时候CPU温度根本没有达到临界值系统就蓝屏重起了,这时影响系统稳定性的罪魁就不是温度而是电压了,散热不好的话,CPU温度会很高。 原因。散装充盒装用假的散热架及风扇可能多点。有时安装不规范,导热面接触不良也常见:)具体量化到多少频率才是稳定的这个问题只有针对具体的情况了。 现在要补充说明几点: 1CPU的正常温度 保证在温升30度的范围内一般是稳定的。也就是说
本回答被提问者采纳
希望能帮你解决!! 增加运行项目是会增加CPU的负担!CPU温度是会上升的!还有就是,就是进BOSS,设置电源管理,减少运行项目,更换笔记本风扇!,都不一样,所以就先不说了!,有必要!!具体方法可以再网上找到!!有个办法,开机以后!但是都不是治病根!病根是:电源散热器是不是出了问题,要在WINDOWS的电源管理项目里是笔记本的电源自动保护功能!!这很正常!,选择,&最大电源管理“项目!!因为BOSS有3种
拿去修一下把!
CPU风扇里反而有灰尘,转速慢了,散热不好了,过热保护了。加一点点润滑油
风扇 肯定停了! 开机看散热口 有没有风吹不来
开机的时候
风扇会自检的
风扇降温坏了
其他6条回答
为您推荐:
其他类似问题
您可能关注的内容
自动关机的相关知识
换一换
回答问题,赢新手礼包
个人、企业类
违法有害信息,请在下方选择后提交
色情、暴力
我们会通过消息、邮箱等方式尽快将举报结果通知您。CPU坏了可以修吗_百度知道
CPU坏了可以修吗
我有更好的答案
那就没修的必要了~!举个简单的例子,如果是低端的CPU没有修的价值了~可以修,不过根据坏的程度不同,需要不同级别的维修点~~一般修的费用比较高,如果你的CPU针脚坏了!再买新的吧,那么修好大约要100~200左右,如果坏了超过5根
采纳率:26%
么CPU,AMD的自动关机我修好过一颗,775针INTEL的根本没办法,无法散热导致,需要做&很危险;开颅手术&quot,是因为帽子里的硅胶干了,应为帽子和芯片是焊在一起的
准确的告诉你 修一个CPU比造一个更复杂
如果还没过保修期可以拿回去保修那看一下.一般CPU是很难修的,维修费用极高!
针脚断了?你:嗯,断了2-3根外科医生:好修,焊上就可以,有一年焊功就能修。烧掉了?你:嗯,检测说cpu坏了,温度高烧了内科医生,看了你一眼,然后给了你一个单子。(此时你在想,医生给的偏方?还是开的药)你拿过来一看,尴尬了,, - -!《死亡证明》医生回答:准备下后事吧,某宝再找个吧
其他2条回答
为您推荐:
其他类似问题
您可能关注的内容
计算机的相关知识
换一换
回答问题,赢新手礼包
个人、企业类
违法有害信息,请在下方选择后提交
色情、暴力
我们会通过消息、邮箱等方式尽快将举报结果通知您。

我要回帖

更多关于 cpu达不到基准速度 的文章

 

随机推荐