Isilon PowerScale OneFS 8.2 і новіші версії: Уможливлено відмову від безкоштовних вузлів для нових вузлів, коли кеш заповнений
Summary: Дозволяє відмовитися від безкоштовних віртуальних вузлів (Vnodes) для нових Vnodes, коли кеш заповнений.
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.
Symptoms
Робота на низьких Vnodes визначається за допомогою бачення кількох
vlruwk Потоки виконуються:
/var/log/messages 2022-03-11T17:17:01-08:00 <0.4> Isilon-4(id4) /boot/kernel.amd64/kernel: [rbm_worker.c:350](pid 4738="kt: dxt1")(tid=102982) There are now 505 DXT threads, msg stats: READ_INODE: 1, callback stats: kernel:lk_lock_async_callback2+0: 502, wait stats: biord: 3, vlruwk: 507З журналу зауважте, що VNODE займає найбільше пам'яті:
vm.uma_zalloc_pigs: UMA Zalloc Pigs:
ZONE NAME SIZE LIMIT COUNT MEM USED
VNODE 000560, 00000000, 00830165, 00453996K
IFSINODE 000568, 00000000, 00777624, 00431338K
VM OBJECT 000240, 00000000, 00813154, 00190582K
lki_lin_ent 000208, 00000000, 00934988, 00189919K
lkc_gen_ent 000064, 00000000, 02235094, 00139693K
stat_cache 000176, 00000000, 00752869, 00129399K
lki_ref_ent 000105, 00000000, 00936379, 00096015K
lkc_lin_idds 000076, 00000000, 01012017, 00075110K
lkc_ref_idds 000068, 00000000, 01008047, 00066940K
mbuf_jumbo_p 004096, 00000000, 00016394, 00065576K
mbuf_cluster 002048, 00000000, 00026630, 00053260K
RADIX NODE 000144, 00000000, 00308743, 00043416K
ifm_attr_cac 000048, 00000000, 00770256, 00036105K
lki_mds_ent 000144, 00000000, 00255978, 00035996K
UMA Slabs 000080, 00000000, 00239085, 00018678K
Unshown zones account for 174014K
Total: 2200045KCause
Вузли можуть відчувати нестачу пам'яті (OOM) через неповернення вільних Vnodes. У OneFS 8.2 і новіших версіях з'явився новий systcl було реалізовано (vfs.vnlru_reuse_freevnodes), щоб дозволити відмовитися від безкоштовних Vnodes для нових Vnodes, коли кеш заповнений.
За замовчуванням vnlru_reuse_freevnodes вимкнено, тому що Isilon вважає за краще відкласти переробку Vnodes на vnlru_proc. Увімкнення vnlru_reuse_freevnodes Дозволяє getvnewvnode() для переробки доступних безкоштовних Vnodes, щоб звільнити місце для нових, коли кеш заповнений (але не переповнений). Це не дозволяє розподільникам Vnode спати та уникнути пробудження vnlru_proc.
Resolution
Обережність: Отримайте схвалення інженера, перш ніж вимкнути або ввімкнути
vfs.vnlru_reuse_freevnode. Усі кластери мають бути оцінені незалежно, навіть якщо вони є одноранговим кластером або кластером Disaster Recovery.
Процес:
- Перевірте, чи встановлено значення за допомогою наступної команди (за замовчуванням 0):
# isi_for_array sysctl vfs.vnlru_reuse_freevnodes
- Встановити
vfs.vnlru_reuse_freevnodesдо 1:
# isi_sysctl_cluster vfs.vnlru_reuse_freevnodes=1
- Переконайтеся, що значення встановлено, повторно виконавши команду:
# isi_for_array sysctl vfs.vnlru_reuse_freevnodesЩоб відстежувати після змін, використовуйте наведені нижче команди для моніторингу використання
vnode cache і vlurwk Теми:
# isi_for_array -s 'sysctl vfs.numvnodes kern.maxvnodes| xargs'; sleep 300 # isi_for_array -s sysctl kern.malloc_pigs|grep vlurwk
Additional Information
Article Properties
Article Number: 000173892
Article Type: Solution
Last Modified: 18 Jun 2025
Version: 17
Find answers to your questions from other Dell users
Support Services
Check if your device is covered by Support Services.