zkoumání vnitřní míry růstu SCN

Publikováno dne: 10 červenec 2018 Autor: Bastiaan Bak Kategorie: Vývoj a provoz IT

před chvílí jsme měli varování o vnitřním růstu SCN (číslo změny systému) v našem souboru výstrah databáze Oracle 12.2. Tato situace nastala několikrát během několika týdnů.

„varování: vnitřní rychlost růstu SCN byla trvale
vyšší než výchozí systém 16384 za sekundu. za posledních 60 minut.
aktuální rychlost vnitřního růstu SCN je 25867 za sekundu, zas 200fffff!
aktuální hodnota SCN je 46747726691, hodnota SCN Compat je 1 “

moje počáteční reakce byla, že SCN souvisí s commity, takže buď zatížení databáze bylo velmi vysoké, nebo by měla být změněna aplikační logika. Další možností bylo, že odevzdání bylo provedeno po každé aktualizaci, namísto použití dávkových odevzdání.

ukázalo se, že je to trochu komplikovanější, než jsem čekal. Kde se díváte, když chcete najít vztah mezi SCN a commity? A jak vážné je toto varování vůbec? Tento blog bude o různých způsobech, jak jsem tento problém prozkoumal a identifikoval potenciální dopad.

Poznámky k podpoře Oracle

první místo, kde se hledají informace o varováních v souboru upozornění, je webová stránka podpory Oracle. Našel jsem několik souvisejících poznámek:

  • ora-19706 a související zprávy záznamu upozornění (Doc ID 1393360.1)
    tato poznámka naznačuje, že skutečná zpráva je specifická pro verzi databáze 12.2, ale ve starších verzích můžeme mít podobná varování ,jako “ varování: světlá výška SCN pro tuto databázi je pouze NN dny!“
    pokud narazíte na zprávu záznamu upozornění, jako je kterákoli z těchto položek, doporučujeme postupovat podle pokynů v ID 1388639.1 a přihlásit požadavek na službu s podporou Oracle.
    důkazy, které je třeba shromáždit při hlášení problémů s „vysokou mírou SCN“ podpoře Oracle (Doc ID 1388639.1)
  • tato poznámka poskytuje informace o tom, jaké informace byste měli poskytnout při protokolování požadavku na službu.
  • číslo změny systému (SCN), světlá výška, zabezpečení a informace o opravě (Doc ID 1376995.1)
    tato poznámka poskytuje více informací o použití SCN. Číslo změny systému (SCN) je logické interní časové razítko používané databází Oracle. SCNs objednává události, které se vyskytují v databázi. Databáze používá SCN k dotazování a sledování změn. Když se transakce zaváže, databáze zaznamená SCN pro toto odevzdání.
    existuje horní limit, kolik SCN může databáze Oracle použít. Limit je v současné době 281 bilionů (2^48) hodnot SCN.
    vzhledem k tomu, že existuje horní limit, je důležité, aby žádná daná databáze Oracle nevyčerpala dostupné SCN.
    poznámka také vysvětluje, kdy je varování zvýšeno. Databáze Oracle vypočítá limit „nepřekročit“ pro počet SCN, který může databáze v současné době používat, na základě počtu sekund od roku 1988 vynásobeného 16384. Tím je zajištěno, že databáze Oracle budou v průběhu času rozdělovat SCN.

jak závažné je toto varování?

varování se zvyšuje rychlostí 2^14 = 16384 SCN za sekundu za posledních 60 minut.
maximální SCN je 2^48 = 281.474.976.710.656.

při rychlosti 16348 SCN za sekundu budeme mít 2^(48-14) sekund nebo 544 let, abychom dosáhli tohoto maxima. To by mělo stačit v normální situaci, ale horní hranice 2^48 je pouze maximální absolutní hodnota, kterou může databáze uložit.
limit souvisí také s počtem sekund od roku 1988. Limit 2^48 je maximální v roce 2532 (1988+544). Ale v roce 2018 je maximum (2018-1988)*365*24*60*60*2^14 = 1.550.057.472.000.

varování by nemělo být ignorováno. Když dosáhnete limitu, dostanete chyby ora-600, ale když dosáhnete absolutní horní hranice SCN, databáze přestane fungovat.

dobrou zprávou je, že v naší situaci varování uvedlo, že rychlost růstu SCN byla 25867 za sekundu v této konkrétní hodině, takže v této hodině jsme se trochu přiblížili (25867-16384=9483) k limitu. Nepřibližujeme se k limitu každou hodinu; normální tempo růstu je nižší než 16384.

Podpora Oracle

zavolali jsme podporu Oracle a řekli nám, že vývoj Oracle v současné době pracuje na tomto problému.
Podpora Oracle potvrdila, že světlá výška SCN vypadá dobře. Na základě zprávy AWR si Podpora Oracle všimla vysokého počtu commitů a navrhla, aby se u aplikačního týmu ověřilo, zda se zavazuje zvýšením velikosti transakce.

vyšetřování s AWR

varování v souboru výstrahy nám řeklo, že vnitřní rychlost růstu SCN byla trvale vyšší než výchozí nastavení systému: 16384 za sekundu za posledních 60 minut. Pokud se díváme na časový rámec hodiny, zpráva AWR by mohla být dobrým místem pro začátek. Máme AWR nakonfigurován tak, aby se snímky každou hodinu.

ve zprávě AWR jsem si všiml, že počet uživatelských commitů byl 210 za sekundu. Ano, To je hodně commitů, ale není to tak odlišné od normálního zatížení této databáze. A pokud commit souvisí s SCN, je také mnohem nižší než 16384 za sekundu.

zpráva AWR také obsahovala zjištění ADDM: čekání na událost „synchronizace souborů protokolu“ při provádění operací odevzdání a vrácení vyžadovalo značný čas v databázi. Prozkoumejte logiku aplikace pro možné snížení počtu operací odevzdání zvýšením velikosti transakcí.
toto snížení commitů ve zjištění ADDM bylo také navrženo podporou Oracle. Z mého pohledu to ale nebylo tak vysoké.

kratší časový rámec

protože mi AWR nepomáhalo najít příčinu, musel jsem prozkoumat kratší časový rámec. Chtěl jsem znát konkrétnější časový rámec, abych mohl vytvořit ASH zprávu. Výchozí hodnota pro popel je 15 minut.
takže další výzvou bylo najít 15 minutový časový rámec, ve kterém byla míra růstu SCN nejvyšší.
Doc ID 1388639.1 navrhl dotaz v$archived_log. Tento pohled obsahuje informace o všech přepínačích protokolu v databázi, včetně časového razítka a SCN. Ačkoli byste mohli mapovat časová razítka na SCN, není to opravdu lepší než zpráva AWR. Stále se držíme náhodných časových razítek; v tomto případě časové razítko logswitch.

pomocí funkce timestamp_to_scn

je lepší použít funkci timestamp_to_scn. Tato funkce vrací SCN na základě časového razítka, jako je aktuální časové razítko:

  1. SQL> vyberte timestamp_to_scn(sysdate) z duálního ;
  2. TIMESTAMP_TO_SCN (SYSDATE)
  3. -------------------------
  4. 91903104563
  5. SQL>

dalším krokem bylo vytvoření seznamu časových razítek spolu s odpovídajícím SCN a odpovídajícím horním limitem SCN na základě počtu sekund od roku 1988 vynásobeného 16 384.

zobrazuje časová razítka a SCN za poslední den:

  1. vyberte sysdate - (rownum/24) datetimestamp
  2. , timestamp_to_scn (sysdate - (rownum/24)) SCN
  3. , ((sysdate - (rownum/24)) - to_date ('01-01-1988', 'DD-MM-RRRR' ))
  4. * 24 * 60 * 60 * 16384 upper_lmt
  5. z duálního
  6. připojit pomocí rownum <= 24
  7. /
  1. DATETIMESTAMP SCN UPPER_LMT
  2. ------------------- -------------------- --------------------
  3. 09-07-2018-13:23:39 95423916508 15780233527296
  4. 09-07-2018-12:23:39 95380086165 15780174544896
  5. 09-07-2018-11:23:39 95338871931 15780115562496
  6. 09-07-2018-10:23:39 95303437600 15780056580096
  7. 09-07-2018-09:23:39 95265573942 15779997597696
  8. 09-07-2018-08:23:39 95226645452 15779938615296
  9. 09-07-2018-07:23:39 95186822906 15779879632896
  10. 09-07-2018-06:23:39 95147382509 15779820650496
  11. 09-07-2018-05:23:39 95115474008 15779761668096
  12. 09-07-2018-04:23:39 95079712219 15779702685696
  13. 09-07-2018-03:23:39 95041469231 15779643703296
  14. 09-07-2018-02:23:39 95006499794 15779584720896
  15. 09-07-2018-01:23:39 94975060529 15779525738496
  16. 09-07-2018-00:23:39 94945771055 15779466756096
  17. 08-07-2018-23:23:39 94907451372 15779407773696
  18. 08-07-2018-22:23:39 94875158341 15779348791296
  19. 08-07-2018-21:23:39 94838756696 15779289808896
  20. 08-07-2018-20:23:39 94800190958 15779230826496
  21. 08-07-2018-19:23:39 94757984611 15779171844096
  22. 08-07-2018-18:23:39 94724548846 15779112861696
  23. 08-07-2018-17:23:39 94685506947 15779053879296
  24. 08-07-2018-16:23:39 94646644945 15778994896896
  25. 08-07-2018-15:23:39 94605003069 15778935914496
  26. 08-07-2018-14:23:39 94572205685 15778876932096
  27. 24 vybrané řádky.

aktuální SCN je asi 0,57% aktuální horní hranice.

nalezení nejvyšší míry SCN

na základě této myšlenky jsem vytvořil dotaz, který mi dává 15 minutový časový rámec s nejvyšším růstem SCN za poslední 3 dny.

každou minutu začíná nový časový rámec, a protože máme 1440 minut za den, máme 4320 časových rámců k prozkoumání. Pro každou z nich musíme vypočítat růst SCN v tomto 15 minutovém časovém rámci.

chceme zobrazit pouze nejlepší výsledky, v tomto případě pouze časové rámce s rychlostí přes 14000 za sekundu.

  1. ALTER session SET nls_date_format='MM/DD/RR HH24:MI' ;
  2. s datelist jako
  3. ( vyberte sysdate - (rownum/1440) - (15/1440) starttime -- 15 minutový interval
  4. , sysdate - (rownum/1440) endtime
  5. z duálního
  6. připojit pomocí rownum <= (3*1440) -- 3 historie dnů
  7. )
  8. vyberte starttime
  9. , konec času
  10. , timestamp_to_scn (endtime) - timestamp_to_scn (starttime) scngrowth
  11. , round ((timestamp_to_scn (endtime) - timestamp_to_scn(starttime)) /
  12. (((24*60*60)*(endtime-starttime)))) scnrate
  13. z datelist
  14. kde kolo ((timestamp_to_scn (endtime) - timestamp_to_scn(starttime)) /
  15. (((24*60*60)*(endtime-starttime )))) >= 14000
  16. pořadí podle 4 DESC
  17. /
  1. STARTTIME ENDTIME SCNGROWTH SCNRATE
  2. -------------- -------------- -------------------- --------------------
  3. 07/06/18 18:09 07/06/18 18:24 12761928 14180
  4. 07/07/18 05:20 07/07/18 05:35 12742537 14158
  5. 07/09/18 13:59 07/09/18 14:14 12705077 14117
  6. 07/09/18 12:57 07/09/18 13:12 12672507 14081
  7. 07/09/18 07:06 07/09/18 07:21 12654287 14060

nyní jsme našli (někdy překrývající se) 15minutové časové rámce s nejvyšší rychlostí SCN (růst SCN za sekundu) za poslední 3 dny. A i v těchto časových rámcích je míra SCN stále pod 16384. Žádné varování v souboru upozornění Tento týden….

spuštění Ash reportu

formát data, který jsem použil ve výše uvedeném dotazu, je stejný jako použitý Ash report, takže stačí zkopírovat/vložit počáteční čas. Po dobu trvání zadáme 15 minut.

  1. SQL> @@$ORACLE_HOME/rdbms / admin / ashrpt.sql
  2. vzorky popela v tomto schématu úložiště pracovní zátěže
  3. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  4. nejstarší vzorek popela k dispozici: 01-Jul-18 00:00:01
  5. nejnovější vzorek popela k dispozici: 09-Jul-18 14:18:58
  6. uveďte časový rámec pro vygenerování zprávy ASH
  7. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  8. Zadejte čas začátku sestavy:
  9. -- platné vstupní formáty:
  10. -- Chcete-li určit absolutní čas začátku:
  11. -- ] HH24: MI
  12. -- příklady: 02/23/03 14:30:15
  13. -- 02/23 14:30:15
  14. -- 14:30:15
  15. -- 14:30
  16. -- Chcete-li zadat relativní čas začátku: (začněte znakem '-' )
  17. -- -MI
  18. -- příklady: -1:15 (SYSDATE-1 hod 15 min)
  19. -- -25 (SYSDATE-25 minut)
  20. Výchozí hodnota -15 minut
  21. zadejte hodnotu pro begin_time: 07/06/18 18:09
  22. zpráva začíná čas zadán: 07/06/18 18:09
  23. zadejte dobu trvání v minutách počínaje časem začátku:
  24. Výchozí hodnota SYSDATE-begin_time
  25. stisknutím klávesy Enter analyzovat do aktuálního času
  26. zadejte hodnotu pro dobu trvání: 15
  27. doba trvání zprávy je stanovena: 15
  28. použití 06-Jul-18 18: 09: 00 jako čas zahájení zprávy
  29. použití 06-Jul-18 18: 24: 00 jako čas ukončení zprávy
  30. zadejte název sestavy
  31. ~~~~~~~~~~~~~~~~~~~~~~~
  32. výchozí název souboru sestavy je ashrpt_1_0706_1824.html. Chcete-li použít tento název,
  33. stiskněte <návrat> pro pokračování, jinak zadejte alternativu.
  34. zadejte hodnotu pro název_ reportů:
  35. použití názvu sestavy ashrpt_1_0706_1824.html
  36. shrnutí všech uživatelských vstupů
  37. -------------------------
  38. formát: HTML
  39. DB Id : 2019395491
  40. Inst num : 1
  41. čas zahájení: 06-Jul-18 18:09:00
  42. čas ukončení: 06-Červenec-18 18:24:00
  43. šířka slotu: výchozí
  44. nahlásit cíle : 0
  45. název zprávy : ashrpt_1_0706_1824.html

nalezení SCN v AWR

zpráva AWR nám neukázala mnoho informací o aktuálním SCN, ale má nějaké informace o rychlosti růstu, pokud víte, kde ji najdete.

v části „statistiky aktivity Instance“ najdete počet „volání na kcmgas“. V dokumentaci Oracle je to popsáno jako „počet hovorů na rutinní kcmgas, aby získal nový SCN“.

hodnota těchto hovorů za sekundu ve zprávě AWR je velmi blízká rychlosti SCN vypočtené pomocí funkce timestamp_to_scn.

V $ SESSTAT view

počet „volání na kcmgas“ použitých k vytvoření nového SCN lze také nalézt v pohledech v$SESSTAT a V$SYSSTAT.

můžeme použít V$SESSTAT k nalezení relací, které způsobují vysokou míru SCN. Můžeme také otestovat dopad na SCN počet konkrétních akcí.

například, když dělám výběr na velkém stole, který je také používán jinými relacemi, Moje relace provede další 7 volání na kcmgas. Takže můj dotaz způsobí vyšší SCN. To je způsobeno konzistencí čtení databáze, která také používá SCN.

  1. SQL> připojit < uživatel> / <projít> @< služba>
  2. připojeno.
  3. SQL> vyberte ses.hodnota
  4. od v$sesstat ses
  5. , v$statname stat
  6. kde stat.statistika#=ses.statistika#
  7. a ses.sid v (vyberte sid z v$mystat)
  8. a stat.name = 'volání do kcmgas'
  9. /
  10. hodnota
  11. --------------------
  12. 2
  13. SQL> vyberte počet (*) z mybigtable ;
  14. počet(*)
  15. --------------------
  16. 12198814
  17. SQL> vyberte ses.hodnota
  18. od v$sesstat ses
  19. , v$statname stat
  20. kde stat.statistika#=ses.statistika#
  21. a ses.sid v (vyberte sid z v$mystat)
  22. a stat.name = 'volání do kcmgas'
  23. /
  24. hodnota
  25. --------------------
  26. 9
  27. SQL>

porovnáním míry SCN a odevzdání

s v$SESSTAT můžeme dotazovat statistiky pro všechny relace aktuálně připojené k databázi. Tímto způsobem můžeme najít relace, které jsou zodpovědné za vysokou míru SCN. Můžeme to porovnat s mírou odevzdání pro danou relaci.

výsledky níže uvedeného dotazu nám ukázaly, že v naší databázi byla vysoká míra SCN způsobena hlavně procesy na pozadí. U většiny uživatelských relací existuje vztah mezi vysokou mírou SCN a vysokou mírou odevzdání, u relací na pozadí je míra odevzdání vždy prázdná.

  1. vyberte ses.sid
  2. , decode (ses.username, NULL,'background',' user') session_type
  3. , (sysdate-logon_time) * 24 * 60 * 60 connect_seconds
  4. , sstat1.hodnota SCN#
  5. , sstat2.value COMMIT#
  6. , kole (sstat1.hodnota / ((sysdate-logon_time ) * 24 * 60 * 60),2) scn_rate
  7. , kolo (sstat2.hodnota / ((sysdate-logon_time ) * 24 * 60 * 60),2) commit_rate
  8. od v$sesstat sstat1
  9. , v$sesstat sstat2
  10. , v$statname sn1
  11. , v$statname sn2
  12. , v$session ses
  13. kde sstat1.statistika# = sn1.statistika#
  14. a sstat2.statistika# = sn2.statistika#
  15. a sn1.name = 'volání do kcmgas'
  16. a sn2.name = 'user commits'
  17. a ses.sid = sstat1.sid
  18. a ses.sid = sstat2.sid
  19. pořadí podle 6 DESC
  20. /
  21. SID SESSION_TY CONNECT_SECONDS SCN # COMMIT# SCN_RATE COMMIT_RATE
  22. ---------- ---------- --------------- ---------- ---------- ---------- -----------
  23. 8478 pozadí 459572 214506344 0 466.75 0
  24. 7551 souvislosti 452395 209729934 0 463.6 0
  25. 3776 souvislosti 290389 133863489 0 460.98 0
  26. 8496 souvislosti 121201 55685740 0 459.45 0
  27. 8729 souvislosti 286773 128180386 0 446.98 0
  28. 12009 souvislosti 290392 128867329 0 443.77 0
  29. 13173 souvislosti 196775 87268032 0 443.49 0
  30. 12004 souvislosti 103166 45681480 0 442.8 0
  31. 8735 pozadí 275980 121563094 0 440.48 0
  32. 3096 souvislosti 430810 185436599 0 430.44 0
  33. 8027 souvislosti 95990 40912187 0 426.21 0
  34. 7529 souvislosti 193218 81367643 0 421.12 0
  35. 2370 souvislosti 527978 219521415 0 415.78 0
  36. 14604 souvislosti 283216 117052382 0 413.3 0
  37. 14132 souvislosti 113965 46586388 0 408.78 0
  38. 7552 souvislosti 294009 119775077 0 407.39 0
  39. 13172 pozadí 182423 73865595 0 404.91 0
  40. 14592 souvislosti 74414 29767705 0 400.03 0
  41. 3802 souvislosti 268804 107486102 0 399.87 0
  42. 9910 souvislosti 117582 46596720 0 396.29 0
  43. 12021 souvislosti 49182 19321676 0 392.86 0
  44. 974 souvislosti 160816 59996495 0 373.08 0
  45. 12723 souvislosti 74450 25455559 0 341.91 0
  46. 3310 souvislosti 193215 65915175 0 341.15 0
  47. 12963 pozadí 49179 15687084 0 318.98 0
  48. 6111 souvislosti 3584090 1031139557 0 287.7 0
  49. 6829 uživatel 303 1267 1123 4.18 3.71
  50. 9665 uživatel 904 1845 1691 2.04 1.87
  51. 8022 uživatel 898 1677 1520 1.87 1.69
  52. 3323 uživatel 898 1406 1260 1.57 1.4
  53. 2839 uživatel 7503 10822 9813 1.44 1.31
  54. 11060 uživatel 3892 5334 4781 1.37 1.23
  55. 13184 uživatel 1765 2359 2038 1.34 1.15
  56. 9199 uživatel 898 1135 935 1.26 1.04
  57. 2130 UŽIVATEL 8105 9548 8518 1.18 1.05
  58. 11525 UŽIVATEL 898 1054 944 1.17 1.05
  59. 6130 UŽIVATEL 3895 4453 4199 1.14 1.08
  60. 8012 UŽIVATEL 7503 8576 7774 1.14 1.04
  61. 4497 UŽIVATEL 898 962 882 1.07 .98
  62. 5201 uživatel 7220 7551 6226 1.05 .86
  63. 11317 uživatel 12906 13371 11997 1.04 .93
  64. 1979 vybrané řádky.

závěr

uvědomte si, že existují limity SCN, takže když najdete varování v souboru upozornění, musíte problém prozkoumat. Pokud zjistíte problém, měli byste pracovat s podporou Oracle. Nahráním informací mohou zkontrolovat, zda je mezi aktuálním a maximálním SCN dostatek místa.

problémy mohou být způsobeny chybou, jako je 12371955: Hot Backup může způsobit zvýšenou rychlost růstu SCN vedoucí k chybám ora-600 (Doc ID 12371955.8).

pokud chcete najít přesný okamžik, kdy dochází k vysokému růstu SCN, musíte převést časová razítka na SCN. Nejlepší výsledky získáte pomocí funkcí SCN_TO_TIMESTAMP a TIMESTAMP_TO_SCN.

vysoká míra odevzdání je vždy spojena s uživatelskými procesy, ale SCN jsou také spojeny s procesy na pozadí. Dokonce i relace, které se nezavazují, mohou mít dopad na SCN.

Bastiaan Bak

o autorovi Bastiaan Bak

DBA s více než 15 let zkušeností. Zkušenosti v různých odvětvích, s několika moduly. Včetně: Databáze Oracle, Oracle RAC, Oracle EBS a PL / SQL.

více příspěvků od Bastiaan Bak

Napsat komentář

Vaše e-mailová adresa nebude zveřejněna.