亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

一個RESOURCE MANAGER引起的問題分析

發布時間:2020-08-11 19:46:42 來源:ITPUB博客 閱讀:425 作者:darren__chan 欄目:關系型數據庫



1.分析hanganalyze日志:

Chains most likely to have caused   the hang: 《《《最 阻塞源都是由于 resmgr:cpu quantum 引起。

 [a] Chain 1 Signature: ' resmgr:cpu quantum '<='buffer busy   waits'<='buffer busy waits'<='enq: TX - index contention'

     Chain 1 Signature Hash: 0xe7466825

 [b] Chain 2 Signature: ' resmgr:cpu quantum '<='buffer busy waits'

     Chain 2 Signature Hash: 0x23972dee

 [c] Chain 3 Signature: ' resmgr:cpu quantum '<='buffer busy waits'

     Chain 3 Signature Hash: 0x23972dee

====================================================================

Chain   1:

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

    Oracle session identified by:

    {

                instance: 1 (jfdb.jfdb1)

                   os id: 78941

              process id: 1240, oracle@XXX-JF-DB03

              session   id: 22 <<<< session 22

        session serial #: 32445

    }

    is waiting for 'enq: TX - index   contention' with wait info:

    {

                      p1:   'name|mode'=0x54580004

                      p2: 'usn<<16 |   slot'=0x1cb0015

                      p3: 'sequence'=0xf3fa7

            time in wait: 0.122389 sec

           timeout after: never

                 wait id: 199367

                blocking: 0 sessions

            wait history:

              * time between current wait and   wait #1: 0.000318 sec

             ………

    }

and is blocked by <<<< 被阻塞

 => Oracle session identified by:

{

                instance: 1 (jfdb.jfdb1)

                   os id: 1349

process   id: 2756, oracle@XXX-JF-DB03

session id: 3320 <<<<session 3320

        session serial #: 3849

}

which   is waiting for ‘buffer busy waits’ with wait info:

{

p1:   ‘file#’=0x8c

p2:   ‘block#’=0x286540

p3:   ‘class#’=0x1

time   in wait: 0.218850 sec

           timeout after: never

                 wait id: 51286

                blocking: 58 sessions

wait   history:

 ……….

}

     and is blocked by <<<< 被阻塞

 => Oracle session identified by:

    {

                instance: 1 (jfdb.jfdb1)

                   os id: 3182

              process id: 2975, oracle@XXX-JF-DB03

              session   id: 5658 <<<session 5658

        session serial #: 181

    }

    which is waiting for 'buffer busy waits'   with wait info:

    {

                      p1: 'file#'=0x8c

                      p2: 'block#'=0x285b1f

                      p3: 'class#'=0x1

            time in wait: 0.219271 sec

           timeout after: never

                 wait id: 38737

                blocking: 63 sessions

            wait history:

              。。。。。。

    }

    and is blocked by<<<< 被阻塞

 => Oracle session identified by:

    {

                instance: 1 (jfdb.jfdb1)

                   os id: 27602

              process id: 2384, oracle@XXX-JF-DB03

              session id: 334   《《《session 334

        session serial #: 757

    }

    which is waiting for 'resmgr:cpu quantum'   with wait info:

    {

                      p1: 'location'=0x2

                      p2: 'consumer group   id'=0x3259

                      p3: ' '=0x0

            time in wait: 0.040860 sec

           timeout after: never

                 wait id: 95941

                blocking: 114 sessions

            wait history:

            。。。。。。。

    }

 

Chain   1 Signature: 'resmgr:cpu quantum'<='buffer busy waits'<='buffer busy   waits'<='enq: TX - index contention'

Chain   1 Signature Hash: 0xe7466825

 

以上 hanganalyze 話進 行整理:

session : 334

阻塞114個會

阻塞了》

session : 5658

阻塞63個會

阻塞了》

session : 3320

阻塞 58 個會

阻塞了》

session id: 22

resmgr:cpu quantum

buffer busy waits

buffer busy waits

enq: TX - index contention

 

從以上 hanganalyze 日志可以看出, enq: TX - index contention buffer busy waits 的等待堆積最終的源頭是由于 resmgr:cpu quantum 等待引起,并且這些等待同時又阻塞了多個其他會話。

2.關于resmgr:cpu quantum等待事件解釋:

以下從文檔 ID 2097889.1 可以獲得該等待事件的說明:

WAITEVENT: "resmgr:cpu quantum" Reference   Note ( 文檔 ID 2097889.1)

·   Event   'resmgr: cpu quantum' is a standard event used by resource manager to control the allocation of   CPU to processes .   When a session waits for 'resmgr: cpu quantum' that session is waiting to be   allocated a quantum of CPU time.

等待事件 'resmgr cpu quantum' 資源管理器用來控制 CPU 分配給進程 的標準事件。   當會話等待 'resmgr cpu quantum' 時, 會話正在等待分配一個 CPU 時間額度

This wait occurs when the resource   manager is enabled and is throttling CPU consumption. To reduce the   occurrence of this wait event, increase the CPU allocation for the session's   current consumer   group .

當啟用資源管理器并限制 CPU 消耗時會發生此等待。 為了減少此等待事件的發生,請增加會話當前消費組的 CPU 分配

一個RESOURCE MANAGER引起的問題分析

      該等待事件存在的意義是當resource manager控制CPU調度時,需要控制對應進程暫時不使用CPU而進程到內部運行隊列中,以保證該進程對應的consumer group(消費組)沒有消耗比指定resource manager指令更多的CPU。此時session就會以” resmgr:cpu quantum ”的名義等待在內部運行隊列中,wait一段時間以減少對CPU的爭用,直到再次獲得CPU時該等待事件結束。

3.分析為何會出現資源管理:

11g: Scheduler Maintenance Tasks or Autotasks ( 文檔 ID 756734.1)

一個RESOURCE MANAGER引起的問題分析

 

      根據以上說明,可以發現在 Oracle 11g 中,在默認情況下會啟用自動化維護任務,數據庫會在工作日的每晚 22:00 到第二天的凌晨 2:00 ,周末的凌晨 6:00 到第二天的凌晨 2:00, 自動開啟自動化維護窗口對數據庫進行諸如優化器的統計信息收集、自動 SQL 的優化。在此期間數據庫中便由 resource manager 來控制 CPU 的調度,啟用資源管理計劃主要是為了保障維護窗口內的任務有充分的資源進行使用。

      從告警日志中可以看出, 4 1 6:00 啟動自動化維護窗口的信息:

Current log# 6 seq# 23750 mem# 0: +DG_DATA/jfdb/onlinelog/group_6.279.909112437

Sun Apr 01 05:51:29 2018

Archived Log entry 46019 added for thread   1 sequence 23749 ID 0x4d5ab97e dest 1:

Sun Apr 01 06:00:00 2018 《《《《 6 點整開啟自動化維護窗口

Setting Resource Manager plan   SCHEDULER[0x32DF]:DEFAULT_MAINTENANCE_PLAN via scheduler window

Setting Resource Manager plan   DEFAULT_MAINTENANCE_PLAN via parameter

Sun Apr 01 06:00:00 2018

Starting background process   VKRM 《《《啟動相應的進程

Sun Apr 01 06:00:00 2018

VKRM started with pid=361, OS id=48797

     

那么資源管理計劃是如何限制資源的呢? 需要了解 RESOURCE MANAGER 的機制。

 

4.關于RESOURCE MANAGER的機制:

    Oracle 開啟自動維護任務是使用的資源管理計劃是 DEFAULT_MAINTENANCE_PLAN 源管理 劃控制CPU方法是使用是默 EMPHASIS 法, 種方法是多 級計 劃,它以百分比形式指定CPU 如何在使用者 分布。CPU 占用率的分配 級別為 從1 到8, 級別 最高,將CPU  源在 級別 按指定的百分比分配,把 級別 上沒有使用的使用者 源可供下一 級別 的使用者 使用。在當前數據 中DEFAULT_MAINTENANCE_PLAN的 源管理 劃只用到了2個 級別

    在oracle 11g中, 實際 上CPU_P*的參數已 是失效了,而 應該 是MGMT_P*的參數,所以我 之前參考的是舊的參數,但 實際 是同 效果。


一個RESOURCE MANAGER引起的問題分析

一個RESOURCE MANAGER引起的問題分析

以下當前資源管理計劃所使用 MGMT_P* 情況:

一個RESOURCE MANAGER引起的問題分析

    源管理 劃DEFAULT_MAINTENANCE_PLAN中,主要存在四個CPU使用 1. ORA$AUTOTASK_SUB_PLAN ORA$DIAGNOSTICS 實際 是用于自 動維護 務的。

2. SYS_GROUP SYS SYSTEM 的初始使用者 組,組中的會話都是 sys system 賬號創建的會話。

3. OTHER_GROUPS 用于在活 動資 劃之外的所有使用者 組擁 有的會 話,即使其他業務用戶及個人用戶的會話。

    源管理 劃中MGMT_P* 置的百分比 并不是一個固定限制的 是一個在 緊張時 的限制 ,但在 源空 閑時 有可能超出

    例如,在DEFAULT_MAINTENANCE_PLAN中ORA$AUTOTASK_SUB_PLAN分配了25%,但此 如果數據 ,SYS_GROUP和OTHER_GROUPS等其他 沒有什么 源占用,ORA$AUTOTASK_SUB_PLAN 可能增 到50%,但如果此 時資 源比 較緊張 OTHER_GROUPS 且已 占用50%以上,ORA$AUTOTASK_SUB_PLAN 需下降到25%。

    因此,在 源管理 劃中,ORA$AUTOTASK_SUB_PLAN和ORA$DIAGNOSTICS 了MAX_UTILIZATION_LIMIT最大使用限制 90 這樣 即使cpu是空 的, 該組 劃也不能分配90%以上的cpu 源。

劃而言, 某個消耗 或者子 劃分配的份 若沒有使用,就可以被其他的消耗 或子 劃使用。

 

再次分析 源管理 劃DEFAULT_MAINTENANCE_PLAN,SYS_GROUP 最高在 級別 1 ,分配75%,在當 的情況,sys或system 建的會 占用的CPU 源并不一定達到了75%,其剩余的 分配 給級別 2 。在 級別 2 中ORA$AUTOTASK_SUB_PLAN和ORA$DIAGNOSTICS的自 動維護 緊張 的情況下用了30%,而其余70% 分配 了OTHER_GROUPS的 業務

源管理 劃中MGMT_P* 置的百分比 可以理解 依據CPU個數的百分比來 算, CPU 個數 來自CPU_COUNT參數 置的


一個RESOURCE MANAGER引起的問題分析
5.發現CPU_COUNT參數異常:

    在排查的過程中,發現當前數據庫的CPU_COUNT僅設置為8,而實際上這臺主機有32個CPU 核數,64個邏輯CPU。

CPU_COUNT:

一個RESOURCE MANAGER引起的問題分析

實際CPU Cores及邏輯cpu個數:

一個RESOURCE MANAGER引起的問題分析

在oracle 官方文檔中已說明CPU_COUNT是依據CPU cores 的數量來指定的,并且也說明很多組件包括Resource Manager都是依靠這個cpu個數的。 一個RESOURCE MANAGER引起的問題分析

一個RESOURCE MANAGER引起的問題分析

這說明了,在資源管理計劃開啟時,受CPU_COUNT 為8的限制,數據庫只能使用到了主機 32個CPU 核數中的8個,即為1/4。

分析故障期間主機的CPU 使用情況,發現在資源管理計劃開啟后,CPU使用率逐漸升高,但始終不超過25%,直到9:30后手工禁用了資源管理計劃,CPU資源被放開,CPU使用率則立即上升到45%左右。



     因此,可以看出,資 源管理 打開期間,由于CPU_COUNT的設置過小,導致了數據庫只能最多使用到了主機25%的CPU資源,并且受以上資源管理計劃控制CPU機制的影響,業務會話可能只能用到這25% CPU資源中的70%,這就是導致數據庫在4月1日高峰期時數據庫達到了CPU了資源瓶頸的原因。

 



向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

东海县| 阳原县| 牡丹江市| 扎囊县| 莒南县| 莆田市| 修武县| 淮南市| 扎兰屯市| 四平市| 台中市| 龙游县| 子长县| 浦城县| 高邑县| 竹山县| 崇文区| 安阳县| 申扎县| 东至县| 小金县| 波密县| 汤原县| 开封县| 新龙县| 独山县| 兴业县| 富源县| 咸丰县| 娄底市| 舟山市| 辛集市| 泾阳县| 栾川县| 孙吴县| 墨脱县| 泰安市| 卢龙县| 三原县| 克山县| 亚东县|