Зміни в enable_background_device_scanner, API та журналі PowerFlex

Summary: У цій статті описані зміни в командах scli і REST API для включення фонового сканера в VxFlexOS після появи функції "консервативного" режиму в v3.0.0.2 HF1. Це дозволяє нам краще контролювати можливості звітності та визначати, які режими клієнт хоче активувати. У всіх попередніх версіях (аж до v3.0.1 включно) фоновий сканер мав два варіанти, device_only режим і comparison_mode (які також включали весь функціонал device_only режиму). ...

This article applies to This article does not apply to This article is not tied to any specific product. Not all product versions are identified in this article.

Instructions

Починаючи з ScaleIO v2.5, режим порівняння HF1 включав нову можливість пропустити виправлення помилок порівняння та повідомити про це у файл /opt/emc/scaleio/logs/comparison.0. Це також вимкнуло функцію зчитування, ремонту та звітування в режимі device_only, який був частиною режиму порівняння в нормальному стані. 

Поряд зі змінами в scli та API було додано деяке додаткове логування вузлів SDS, коли включено режим порівняння фонового сканера з v3.0.0.2 HF.

 

Зміни в журналі змін: /opt/emc/scaleio/sds/logs/comparison.x

 19/11 10:50:12.446570 Scanning combs for device be4c66a400000001, loop #1945 ended, #scanned combs=137, #sec combs (skipped)=69, #primary combs skipped=0, #scanned teeth=19418

Кроки для зменшення стандартної кількості файлів comparisons.x з 10 до меншої кількості:

 echo "tgt_comparison_file_history =2" >> /opt/emc/scaleio/sds/cfg/conf.txt ; pkill sds

Виконайте це на всіх SDS, де файли повинні бути зменшені. Нові вихідні файли CRC32 (містять хеш-вихід для 1 МБ даних користувача з PRI або SEC) для перевірки між основним і вторинним:

 /opt/emc/scaleio/sds/logs/{randomID}_compare_combID_offset_[pri/sec].log

ПРИКЛАД:

 /opt/emc/scaleio/sds/logs/1259357004_compare_71f2800001b5_18432_pri.log
Trace entry correlating in comparison.x:
13/11 14:03:54.470982 vtreeId a227e28500000000 Comb 71f2800001b5, offset 18432 - compare error - succeeded to fix the secondary by the primary, randId 1259357004.

Відповідні журнали sds/logs/trc.x:

trc.5:13/11 14:03:54.459658 0x7f598e35ddb8:mgStorageRegion_VerifyDataCRC:02769: primary and secondary checksums are different (pri=1025730551, sec=3956700141). will dump the error. randId 1259357004. combId:71f2800001b5,vTree:0xa227e28500000000,offsetVol:0x12da000,offsetInComb:18432,sizeInLbs:2048,phyToothIdx:2608,srcToothIdx:inv,dstToothIdx:inv New:(0,0) Requested:(3,1) volId:0
trc.5:13/11 14:03:54.470972 0x7f598e35ddb8:raidScan_FixSecondaryByPrimary:00295: comb:71f2800001b5,vTree:0xa227e28500000000,offsetVol:0x12da000,offsetTooth:0x0, Comb 71f2800001b5, offset 18432 - fix the secondary by the primary, randId 1259357004, rc = SUCCESS
trc.5:13/11 14:03:54.470988 0x7f598e35ddb8:raidScan_HandleComparisonError:01006: compare error - succeeded to fix the secondary by the primary. randId 1259357004. combId:71f2800001b5,vTree:0xa227e28500000000,offsetVol:0x12da000,offsetInComb:18432,sizeInLbs:2048,phyToothIdx:2608,srcToothIdx:inv,dstToothIdx:inv New:(0,0) Requested:(3,1) volId:0
trc.5:13/11 14:03:54.472246 0x7f598e35ddb8:raidScan_HandleComparisonError:01046: Sent a message to the MDM on compare error (randId 1259357004). combId:71f2800001b5,vTree:0xa227e28500000000,offsetVol:0x12da000,offsetInComb:18432,sizeInLbs:2048,phyToothIdx:2608,srcToothIdx:inv,dstToothIdx:inv New:(0,0) Requested:(3,1) volId:0

Перевірка двох вихідних файлів:

 -rw-rw-rw-. 1 root root     4096 Nov 13 14:03 1259357004_compare_71f2800001b5_18432_pri.log
-rw-r--r--. 1 root root     4096 Nov 19 11:10 1259357004_compare_71f2800001b5_18432_sec.log

diff 1259357004_compare_71f2800001b5_18432_pri.log 1259357004_compare_71f2800001b5_18432_sec.log
Binary files 1259357004_compare_71f2800001b5_18432_pri.log and 1259357004_compare_71f2800001b5_18432_sec.log differ


[root@localhost logs]# md5sum 1259357004_compare_71f2800001b5_18432_pri.log
d11924aadfe72dd1117f260f8b092caf  1259357004_compare_71f2800001b5_18432_pri.log
[root@localhost logs]# md5sum 1259357004_compare_71f2800001b5_18432_sec.log
620f0b67a91f7f74151bc5be745b7110  1259357004_compare_71f2800001b5_18432_sec.log

Стара команда

 scli --enable_background_device_scanner
Error: Either a valid Storage Pool ID or name must be specified

Usage: scli --enable_background_device_scanner (((--protection_domain_id  | --protection_domain_name ) --storage_pool_name ) | --storage_pool_id ) --scanner_mode  [--scanner_bandwidth_limit ] [--report_and_fix | --report_only]
Description: Enable background device scanner
Parameters:
    --protection_domain_id          Protection Domain ID
    --protection_domain_name      Protection Domain name
    --storage_pool_name           Storage Pool name
    --storage_pool_id               Storage Pool ID
    --scanner_mode                Scanner mode of operation where MODE can be one of the following:
                                        device_only - Perform read operations. Fix from peer on errors
                                        data_comparison - Perform the device_only test and compare the data content with peer. Not supported for fine granularity Storage Pools
    --scanner_bandwidth_limit           Bandwidth limit in KB per second per device. The given value should be between 10KB and 10MB. The default value is 3MB
    --report_and_fix                    Report errors and automatically fix them (default)
    --report_only                       Report errors without fixing them

Режим сканера

Дія

Результат

device_only

report_and_fix

Виявляються, повідомляються та виправляються лише помилки зчитування.

report_only

Виявляються та повідомляються лише про помилки зчитування (не виправляються)

Не вказано

Те саме, що report_and_fix (варіант 1)

data_comparison

report_and_fix

Виявляються та виправляються помилки як зчитування, так і порівняння.

report_only

Помилки читання та порівняння виявляються та повідомляються (не виправляються)

Не вказано

Те саме, що report_and_fix (варіант 3)

 

Нова команда

 
 Usage: scli --enable_background_device_scanner (((--protection_domain_id  | --protection_domain_name ) --storage_pool_name ) | --storage_pool_id ) --read_error_action  --compare_error_action  [--scanner_bandwidth_limit ]
Description: Enable background device scanner
Parameters:
    --protection_domain_id          Protection Domain ID
    --protection_domain_name      Protection Domain name
    --storage_pool_name           Storage Pool name
    --storage_pool_id               Storage Pool ID
    --read_error_action         Read error handling. Can be one of the following:
                                        report_and_fix - Perform read operations and automatically fix from peer on errors
                                        report_only    - Perform read operations and report errors without fixing them
    --compare_error_action      Compare error handling. Can be one of the following:
                                        no_compare     - Perform read operations without comparing data content with peer
                                        report_and_fix - Perform read operations, compare data content with peer, and automatically fix
                                                         Not supported for fine granularity Storage Pools
                                        report_only    - Perform read operations, compare data content with peer, and report mismatches without fixing them
                                                         Not supported for fine granularity Storage Pools
    --scanner_bandwidth_limit           Bandwidth limit in KB per second per device. The given value should be between 10KB and 10MB. The default value is 3MB

Режим помилки зчитування

Порівняйте режим помилок.

Результат

Відображення

 

no_scan

no_scan

Неприпустима комбінація - для цього є команда відключити.

Недійсний 1

scannerMode = NULL (не підтримується)

report_only

Неприпустима комбінація - не можна порівнювати без прочитання.

Недійсний 2

 

report_and_fix

Неприпустима комбінація - не можна порівнювати без прочитання.

Недійсний 3

 

report_only

no_scan

Виявляються та повідомляються лише про помилки зчитування (не виправляються)

2

Режим сканера = device_only

compareErrorAction = NULL

readErrorAction = report_only

 

report_only

Помилки читання та порівняння виявляються та повідомляються (не виправляються)

4

Режим сканера = data_comparison

compareErrorAction = report_only

readErrorAction = report_only

 

report_and_fix

Помилки читання та порівняння виявляються та повідомляються, але виправляються лише помилки порівняння.

Новий 1

Режим сканера = data_comparison

compareErrorAction = report_and_fix

readErrorAction = report_only

 

report_and_fix

no_scan

Виявляються, повідомляються та виправляються лише помилки зчитування.

1

Режим сканера = device_only

compareErrorAction = NULL

readErrorAction = report_and_fix

 

report_only

Помилки читання та порівняння виявляються та повідомляються, але виправляються лише помилки зчитування.

Новий 2

Режим сканера = data_comparison

compareErrorAction = report_only

readErrorAction = report_and_fix

 

report_and_fix

Помилки зчитування та порівняння виявляються, повідомляються та виправляються.

3

Режим сканера = data_comparison

compareErrorAction = report_and_fix

readErrorAction = report_and_fix

 

Affected Products

PowerFlex rack, ScaleIO
Article Properties
Article Number: 000275658
Article Type: How To
Last Modified: 22 Jan 2025
Version:  1
Find answers to your questions from other Dell users
Support Services
Check if your device is covered by Support Services.