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

溫馨提示×

溫馨提示×

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

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

pt-online-schema-change 使用異常處理及注意事項

發布時間:2020-08-10 18:11:07 來源:ITPUB博客 閱讀:287 作者:小亮520cl 欄目:MySQL數據庫

pt-online-schema-change最近使用pt-online-schema-change 做線上大表的在線DDL,發現幾個問題。
我使用的語句如下:
pt-online-schema-change --user=root --password="xxxxx" --host=192.168.xx.xx D=M_xx,t=T_xx  --alter "ADD Fxxxxx'" --charset=utf8 --no-check-replication-filters --alter-foreign-keys-method=auto --recursion-method=none --print --execute
在執行的過程中,有一個庫中斷了,錯誤信息如下:
Copying `table_01005`.`T_xxx`:  19% 16:30 remain
Copying `table_01005`.`T_xxx`:  21% 16:21 remain
Copying `table_01005`.`T_xxx`:  22% 16:58 remain
2014-11-04T18:20:25 Dropping triggers...
DROP TRIGGER IF EXISTS `table_01005`.`pt_osc_table_01005_T_xxx_del`;
DROP TRIGGER IF EXISTS `table_01005`.`pt_osc_table_01005_T_xxx_upd`;
DROP TRIGGER IF EXISTS `table_01005`.`pt_osc_table_01005_T_xxx_ins`;
2014-11-04T18:20:28 Dropped triggers OK.
2014-11-04T18:20:28 Dropping new table...
DROP TABLE IF EXISTS `table_01005`.`_T_xxx_new`;
2014-11-04T18:20:30 Dropped new table OK.
`table_01005`.`T_xxx` was not altered.
2014-11-04T18:20:25 Error copying rows from `table_01005`.`T_xxx` to `table_01005`.`_T_xxx_new`: Threads_running=199 exceeds its critical threshold 50。

然后就中斷了,這個Threads_running 是活動的線程數。根據這個錯誤提示,查了下percona的文檔,
簡單的根據錯誤提示查看bug列表,找到一個bug,根據現象說是工具本身的一個bug。也正好和我們使用的版本一致,
那我就升級版本,完了再來,然后又重現了,顯示不是bug這么簡單的事。還是再看錯誤信息,提示為Threads_running 超過了警告的閥值。既然是閥值,
那是不是可以設置了,找來官網文檔仔細瞅瞅,里面有一個參數需要注意,--critical-load 。文檔解釋如下:
--critical-load
type: Array; default: Threads_running=50
Examine SHOW GLOBAL STATUS after every chunk,
and abort if the load is too high. The option accepts a comma-separated list of MySQL status variables and thresholds.
An optional =MAX_VALUE (or :MAX_VALUE) can follow each variable. If not given,
the tool determines a threshold by examining the current value at startup and doubling it.
See --max-load for further details. These options work similarly,
except that this option will abort the tool’s operation instead of pausing it,
 and the default value is computed differently if you specify no threshold.
 The reason for this option is as a safety check in case the triggers on the
 original table add so much load to the server that it causes downtime.
 There is probably no single value of Threads_running that is wrong for
 every server, but a default of 50 seems likely to be unacceptably high
 for most servers, indicating that the operation should be canceled immediately.

大致的意思如下:
每次chunk操作前后,會根據show global status統計指定的狀態量的變化,默認是統計Thread_running。
目的是為了安全,防止原始表上的觸發器引起負載過高。這也是為了防止在線DDL對線上的影響。
超過設置的閥值,就會終止操作,在線DDL就會中斷。提示的異常如上報錯信息。

和這個參數有的類似的還有一個--max-load :
--max-load
type: Array; default: Threads_running=25
Examine SHOW GLOBAL STATUS after every chunk, and pause if any status variables are higher than their thresholds.
The option accepts a comma-separated list of MySQL status variables. An optional =MAX_VALUE (or :MAX_VALUE) can
follow each variable. If not given, the tool determines a threshold by examining the current value and increasing it by 20%.

For example, if you want the tool to pause when Threads_connected gets too high, you can specify “Threads_connected”,
 and the tool will check the current value when it starts working and add 20% to that value. If the current value is 100,
 then the tool will pause when Threads_connected exceeds 120, and resume working when it is below 120 again. If you want to
 specify an explicit threshold, such as 110, you can use either “Threads_connected:110” or “Threads_connected=110”.

The purpose of this option is to prevent the tool from adding too much load to the server. If the data-copy queries are
intrusive, or if they cause lock waits, then other queries on the server will tend to block and queue. This will typically
cause Threads_running to increase, and the tool can detect that by running SHOW GLOBAL STATUS immediately after each query finishes.
If you specify a threshold for this variable, then you can instruct the tool to wait until queries are running normally again. This will
not prevent queueing, however; it will only give the server a chance to recover from the queueing. If you notice queueing, it is best to decrease the chunk time.

--max-load 選項定義一個閥值,在每次chunk操作后,查看show global status狀態值是否高于指定的閥值。該參數接受一個mysql status狀態變量以及一個閥值,
如果沒有給定閥值,則定義一個閥值為為高于當前值的20%。
注意這個參數不會像--critical-load終止操作,而只是暫停操作。當status值低于閥值時,則繼續往下操作。
是暫停還是終止操作這是--max-load和--critical-load的差別。

參數值為列表形式,可以指定show global status出現的狀態值。比如,Thread_connect 等等。
格式如下:--critical-load="Threads_running=200"  或者--critical-load="Threads_running:200"。

根據參數要求,修改了Threads_runnings的閥值,成功執行了。所以文檔還是很重要的,在使用一個工具之前,文檔是必須要看的,
而不只是簡單的使用就完事,必須要對使用過程中可能出現的異常錯誤進行處理。

幾個注意事項:

The tool refuses to operate if it detects replication filters. See --[no]check-replication-filters for details.
The tool pauses the data copy operation if it observes any replicas that are delayed in replication. See --max-lag for details.
The tool pauses or aborts its operation if it detects too much load on the server. See --max-load and --critical-load for details.
The tool sets its lock wait timeout to 1 second so that it is more likely to be the victim of any lock contention, and less likely to disrupt other transactions. See --lock-wait-timeout for details.
The tool refuses to alter the table if foreign key constraints reference it, unless you specify --alter-foreign-keys-method.
The tool cannot alter MyISAM tables on “Percona XtraDB Cluster” nodes.


pt-online-schema-change 在線DDL工具,雖然說不會鎖表,但是對性能還是有一定的影響,執行過程中對全表做一次select。
這個過程會將buffer_cache中活躍數據全部交換一遍,這就導致活躍數據的請求都要從磁盤獲取,導致慢SQL增多,file_reads增大。


 

向AI問一下細節

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

AI

尼勒克县| 涟水县| 宁都县| 祥云县| 合作市| 儋州市| 双桥区| 松江区| 望江县| 嘉黎县| 公主岭市| 津南区| 西充县| 盐城市| 白玉县| 清河县| 江永县| 镇远县| 元氏县| 桓台县| 丹寨县| 深圳市| 商水县| 天全县| 治县。| 舞阳县| 南汇区| 满洲里市| 河津市| 通道| 来宾市| 太仆寺旗| 武邑县| 北安市| 元谋县| 井研县| 青冈县| 尖扎县| 珲春市| 浦东新区| 巴彦县|