Настройка файловой системы для настройки производительности Linux
Настройка файловой системы для настройки производительности Linux

напиши впереди


  • Организация заметок, связанных с экзаменами
  • Содержание блога включает в себя, файловую система Распространенные методы настройки
    • Анализ применимых сценариев для различных форматов файловой системы,Параметры формата,Настройка стратегии монтирования бревно
    • файловая система Разделение журналов и данных Конфигурация
    • fstrim освоение космоса
  • Если вы недостаточно понимаете, пожалуйста, помогите мне исправить это.

Не слишком запутывайтесь в настоящем и не беспокойтесь слишком сильно о будущем. Когда вы что-то испытываете, пейзаж перед вами уже не тот, что раньше. —— Харуки Мураками


Система Red Hat RHEL8 Файловая система по умолчанию для запуска: XFS,но Ext4 Это по-прежнему решение для файловой системы, которое можно использовать.

ext4 (Четвертое расширение файловая система): ext4 Это одна из наиболее часто используемых файловых систем в Linux, являющаяся усовершенствованием файловой системы ext3. Он поддерживает большие файлы и разделы большой емкости и обеспечивает лучшую производительность и надежность.

XFS: XFS是一个高производительностьизбревнофайловая система,Первоначально разработан и спроектирован SGI для поддержки больших файловых систем массового хранения данных.,широко используетсяБольшой сервер и высокая производительность вычисленийсреда。Он также поддерживает большую емкостьфайловая системный файл с высокой производительностью и масштабируемостью. относительно EXt4, Поддерживает большую емкость.

  • XFSподдерживать1PBизфайловая система,Размер отдельного файла ограничен8EB
  • Ext4поддерживать50TBизфайловая система,Размер отдельного файла ограничен16TB

Рекомендуемые сценарии файловой системы:

Сценарии, применимые к XFS:

  • Нет конкретного бизнес-сценария: XFS — это общий высокоуровневый система, подходящая для множества различных типов приложений и рабочих нагрузок.
  • Большие серверы: XFS хорошо работает при работе с большими серверами и средами с высокой нагрузкой. Одна из целей его разработки — удовлетворить большие требования к хранению данных.
  • Большие устройства хранения: XFS подходит для управления устройствами хранения большой емкости и может эффективно обрабатывать большие объемы данных.
  • Большие файлы: XFS очень эффективен для обработки больших файлов (таких как видеофайлы, файлы библиотек и т. д.) и может поддерживать отдельные файлы очень больших размеров.
  • Многопоточный ввод-вывод: XFS хорошо работает при обработке многопоточного ввода-вывода и может обрабатывать несколько одновременных операций чтения и записи одновременно.

ext4 применимые сценарии:

  • Небольшие файлы: ext4 хорошо работает при обработке небольших файлов и может быстро обрабатывать большое количество небольших файлов.
  • Однопоточный ввод-вывод: ext4 очень эффективен для однопоточных операций ввода-вывода (например, последовательного чтения и записи одним приложением).
  • Ограниченные возможности ввода-вывода: если возможности ввода-вывода системы ограничены (например, при более низком IOPS (операций ввода-вывода в секунду) или ограничениях пропускной способности), ext4 может обеспечить хорошую производительность.
  • Ограниченная пропускная способность: если пропускная способность системы ограничена (например, из-за ограничений сетевой передачи или устройств хранения), ext4 может эффективно использовать доступную пропускную способность.
  • Обязательность бизнеса ЦП: ext4 имеет хорошую производительность для бизнеса обязательности, который выполняется на конкретном ЦП (например, виртуализированные среды или контейнеры).
  • Поддержка автономного сокращения: ext4 поддерживает онлайн-файлы. система сжатия, что полезно, когда нужно освободить место для хранения данных

Фстрим освоение космоса

Когда система просит жесткий диск записать 3G данныечас,Жесткий диск фактически скопирует данные,Но удалите данные,тогда просто дайФайл помечен тегом(Итак, скопируйтеданныеочень медленно,Удаление данных чрезвычайно быстрое).

твердотельный накопительНужно стереть староеданныенаписать новыйданные,Новый SSD,Есть много свободного места,данные Скорость записи относительно высокая,Но по мере увеличения количества использования,Многие пользователи данных удалили его.,Но для контроллеров хранения,Эти данные все еще там,Когда вам нужно записать новые данные,сначала нужно стереть старую

использоватьfstrimМожетпереработкаужеустанавливатьизфайловая система Все вышеперечисленноеиспользоватьизкусок,XFSиext4Всеподдерживатьfstrim,fstrimЗаказ обычно необходимо запускать с правами суперпользователя (root).

RHEL поддерживает несколько методов переработки:

  • Batch discard:Вручную выполнить по мере необходимости fstrim Заказ fstrim /mountoint
  • Scheduled batch discard: использовать fstrim.timer Черновое выполнение запланированных задач fstrim Заказ, выполняемый во всех точках монтирования каждую неделю, должен запустить запланированный план. systemctl enable --now fstrim.timer
  • Online discard: mount устанавливатьфайловая система определяется, когда discard свойство,файловая системаонлайн реальныйчасзапускаться автоматическипереработка
    • mount -o discard /dev/device /mountpoint
    • fstab Конфигурация в dev/device /mountpoint xfs defaults,discard 0 0

Второй способ, /usr/sbin/fstrim -av Используется для одновременного освобождения пространства во всех смонтированных файловых системах. fstrim Заказ.

Язык кода:javascript
копировать
┌──[root@liruilongs.github.io]-[/var/lib/libvirt/images]
└─$systemctl   enable   --now    fstrim.timer
Created symlink /etc/systemd/system/timers.target.wants/fstrim.timer → /usr/lib/systemd/system/fstrim.timer.
┌──[root@liruilongs.github.io]-[/var/lib/libvirt/images]
└─$systemctl cat fstrim.timer
# /usr/lib/systemd/system/fstrim.timer
[Unit]
Description=Discard unused blocks once a week
Documentation=man:fstrim

[Timer]
OnCalendar=weekly
AccuracySec=1h
Persistent=true

[Install]
WantedBy=timers.target
┌──[root@liruilongs.github.io]-[/var/lib/libvirt/images]
└─$systemctl cat fstrim.service
# /usr/lib/systemd/system/fstrim.service
[Unit]
Description=Discard unused blocks

[Service]
Type=oneshot
ExecStart=/usr/sbin/fstrim -av
┌──[root@liruilongs.github.io]-[/var/lib/libvirt/images]
└─$

Red Hat рекомендует использовать запланированное задание для еженедельной переработки или выполнять операции по переработке вручную по мере необходимости.

Параметры форматирования файловой системы

XFS

inode size: Если вам нужно использовать Расширенные атрибуты XFS,Рекомендуется изменить индексный дескриптор 256 Байты по умолчанию. Изменить размер на 512 байт.

Язык кода:javascript
копировать
mkfs.xfs   -i  size=512   /dev/mydevice

block size: block size Значение по умолчанию: 4096 байт,увеличьте это значение Можетуменьшать I/O раз для улучшения производительности

Язык кода:javascript
копировать
mkfs.xfs -n size=8192 /dev/mydevice

RAID Alignment

d возможность указать файлы системаизразмер блока данных и ширина полосы данных блока

Язык кода:javascript
копировать
mkfs.xfs -d su=512k,sw=2 /dev/myraid

ext4

inode size: в случаенебольшие файлыСлучаи применения,и не требует использования расширенных атрибутов,но Можетуменьшатьinode значение размера, измените значение по умолчанию 256 байт

Язык кода:javascript
копировать

mkfs.ext4  -I  128   /dev/mydevice           //заглавная буква я

extra_isize

Включить расширение metadata,Он включен по умолчанию,еслиразмер инода меньше 256байт,Расширение не требуется,используйте заказ ниже, чтобы отключить эту функцию

Язык кода:javascript
копировать
mkfs.ext4  -O  ^extra_size   /dev/mydeivce

large_dir

Включение этой опции может увеличить количество файлов в каждом каталоге. По умолчанию эта опция не включена.

Язык кода:javascript
копировать
mkfs.ext4  -O  large_dir    /dev/mydevice

huge_file

Поддерживает файлы размером более 2 ТБ. Этот атрибут включен по умолчанию. Для сценариев приложений с небольшими файлами эту функцию можно отключить с помощью следующей команды.

Язык кода:javascript
копировать
mkfs.ext4  -O  ^huge_file     /dev/mydevice

RAID Alignment

Язык кода:javascript
копировать
mkfs.ext4  -E  stride=128,stripe-width=256   /dev/mydevice

Свойства монтирования файловой системы

Общие свойства монтирования

  • atime:Разрешить доступ к файлу обновления ядрачасмежду
  • relatime:если Файл или каталог был изменен,Затем обновите время доступа к файлу,в противном случае,Система обновляет время доступа один раз в сутки,вместо обновлений в реальном времени,Эта опция используется по умолчанию в XFS и ext4файловая. система включена.
  • noatime:Доступ к файлу не обновленчасмежду
  • nodiratime:Не обновлять каталогиздоступчасмежду

XFS Варианты крепления

По умолчанию некоторые параметры монтажа предопределены в RHEL, но есть еще некоторые параметры, которые необходимо включить в зависимости от конкретных сценариев применения.

  • inode64: Размещайте индексные дескрипторы рядом с данными, чтобы сократить время поиска на диске.
  • logbsize=32K:log buffer size,Значение по умолчанию:32KB,Может быть изменено на 64K, 128K, 256K.,logbsize=64K

ext4 Варианты крепления:

i_version:включать64Кусочекinodeподдерживать Функция,Полезно для расширения атрибутов данных элемента.,по умолчанию Долженсвойствоотключениз。journal_ioprio=: Определить журнал Приоритет ввода-вывода, диапазон 0–7, 0 имеет наивысший приоритет.

Управление журналами файловой системы

Файловая система журналов может повысить эффективность восстановления данных. Каждый раз, когда в файловой системе происходят изменения данных, журналы записываются, а записи журнала удаляются после завершения операции ввода-вывода.

Поэтому, когда компьютер внезапно теряет питание и необходимо выполнить восстановление данных, нам нужно проверить только журнал (при необходимости журнал можно использовать для восстановления данных) и часть файловой системы, на которую влияет журнал, не проверяя всю файловая система.

XFSфайловая системапредоставилnorecovery Варианты крепления,При сипользовании этой опции монтируется файловая система.,бревно будет забанен,устанавливатьXFSфайловая Отключите автоматический процесс восстановления, когда system. Если файловая данные системы не чисты (не cleanly),Будут проблемы с согласованностью данных.,Некоторые файлы или каталоги могут быть недоступны。использоватьnorecoveryПараметрыустанавливатьфайловая систему можно монтировать только для чтения.

Язык кода:javascript
копировать
mount -o norecovery,ro /dev/<device> <mountpoint>

Ext3/Ext4файловая системаизбревно,Можно разделить на три режима работы.,Можетсуществоватьmountустанавливатьчас,использоватьданные = параметры режимаопределять。Файл находится вext4файловая система Хранится в двух частях.:metadataиdata,metadataиdataизбревно Управляется отдельноиз。

Режим по умолчанию ordered

  • ordered:В этом режиме,Записывайте только краткую информацию о юанях.,без записи краткости данных。при продолжениифайловая системадействоватьчас,файловая система сначала запишет на диск данные, которые необходимо изменить.,Затем запишите соответствующий элемент бревно данных. Это гарантирует, что перед записью бревно данных элемента,Соответствующие данные были сохранены на диске. Эта модель обеспечивает лучшую согласованность данных и хорошую производительность.
  • writeback:В этом режиме,Записывайте только краткую информацию о юанях.,Вместо записи кратких данных. Отличается от заказанного режима,файловая системав ходе выполненияфайловая системадействоватьчас,Измененные данные сначала будут записаны в кеш памяти (а не записаны непосредственно на диск).,Затем запишите соответствующий элемент бревно данных. Данная модель имеет более высокую производительность.,Потому что данные быстрее записываются в кеш памяти.,Но это также снижает согласованность данных.,Потому что данные, возможно, еще не были записаны на диск.
  • journal:В этом режиме,Предоставим полные данные и краткие записи данных в юанях. Все новые данные сначала будут записываться кратко.,Затем напишите его конечное положение. согласованность данных является лучшей в этом режиме,Потому что в случае сбоя или сбоя системы,Бревно может быть воспроизведено для восстановления согласованности данных элемента данных. Однако,По сравнению с первыми двумя режимами,производительность в журнальном режиме хуже,Потому что каждая операция записи должна сначала записать бревно.

Разделение журналов и данных

по умолчаниюXFSиext4файловая системаодеялосоздаватьчас,бревнобудет размещен сфайловая система на связанных устройствах,Когда происходит большое количество случайных записей,дискиздавление ввода-выводаотносительно большой,нас Можетдобавивбревноиданныеразделениеиз Способ,来уменьшатьдискиздавление ввода-вывода,улучшатьданные Читай и пишипроизводительность。

Отсоединить при форматировании и монтаже

создаватьXFSфайловая системачас,Можетиспользоватьlogdevспецификация опциибревнооборудование:

Используйте -l (строчная L), чтобы указать параметр журнала, установите диск журнала на sdd1 через logdev и sdc1 в качестве основного диска файловой системы.

Язык кода:javascript
копировать
mkfs -t  xfs  -l  logdev=/dev/sdd1   /dev/sdc1

При монтировании также необходимо указать расположение лог-диска:

Язык кода:javascript
копировать
mount  -o  logdev=/dev/sdd1   /dev/sdc1  /mnt

Как файловая система Ext4 определяет независимые диски журналов:

В отличие от XFS, файловая система ext4 не может указывать независимое устройство журнала при монтировании.

Создать бревно диск,block размер 4 КБ

Язык кода:javascript
копировать
mkfs  -t  ext4  -O  journal_dev   -b  4096   /dev/sdd1   

Создайте основную файловую систему sdc1 и укажите устройство журнала как sdd1.

Язык кода:javascript
копировать
mkfs  -t  ext4  -J  device=/dev/sdd1   -b  4096   /dev/sdc1   

Уведомление:

ext4Расширятьбревнофайловая система Требовать,бревнофайловая системаиз block Размер должен соответствовать размеру файла владельца системаизblockтот же размер!Рекомендуется использовать лучшие практики при принятии решений.файловая Создать бревнофайловую систему одновременно с системой система。

Отдельные данные журнала в системе ext4, в которой уже есть журналы.

Предположим, что sdc1 — это диск данных 4G, а sdd1 — устройство регистрации 128 МБ.

将一个уже经存существоватьизext4в системеизбревно Преобразовать в автономныйизбревнооборудование,Сначала нужно проверить существующие файлы Размер блока системы:

tune2fs это инструмент для корректировки и изменения Ext2、Ext3 и Ext4 Инструмент командной строки для параметров файловой системы. Используя Tune2fs вы можете изменить файлы система различных атрибутов и опций для удовлетворения конкретных потребностей.

Язык кода:javascript
копировать
┌──[root@liruilongs.github.io]-[/var/lib/libvirt/images]
└─$tune2fs -l /dev/sdc1

… …
Block size:               4096
… …

Создайте файловую систему журнала того же размера, создайте файловую систему Ext4 на /dev/sdd1 и включите функцию журнала.

Язык кода:javascript
копировать
[root@serverX ~]# mkfs  -t  ext4  -O journal_dev   /dev/sdd1

Отключите файловую систему: это отключит файловую систему /dev/sdc1 для последующих настроек файловой системы.

Язык кода:javascript
копировать
[root@serverX ~]# umount   /dev/sdc1

Измените характеристики файловой системы: удалите существующие характеристики журнала из файловой системы /dev/sdc1, чтобы к ней можно было добавить новое устройство журнала.

Язык кода:javascript
копировать
[root@serverX ~]# tune2fs  -O  '^has_journal'   /dev/sdc1          

Добавьте устройство журнала. Добавьте устройство журнала в файловую систему /dev/sdc1 и используйте /dev/sdd1 в качестве устройства журнала.

Язык кода:javascript
копировать
[root@serverX ~]# tune2fs  -j  -J  device=/dev/sdd1   /dev/sdc1
#-j Добавить устройство бревно, -J Укажите параметры бревно устройства

Ссылка на часть сообщения в блоге

© Авторские права на ссылки в этой статье принадлежат оригинальному автору. Если есть какие-либо нарушения, пожалуйста, сообщите нам :)


《 Red Hat Performance Tuning 442 》


© liruilonger@gmail.com, 2018–2024. Все права сохранены. Attribution-NonCommercial-ShareAlike (CC BY-NC-SA 4.0).

boy illustration
Неразрушающее увеличение изображений одним щелчком мыши, чтобы сделать их более четкими артефактами искусственного интеллекта, включая руководства по установке и использованию.
boy illustration
Копикодер: этот инструмент отлично работает с Cursor, Bolt и V0! Предоставьте более качественные подсказки для разработки интерфейса (создание навигационного веб-сайта с использованием искусственного интеллекта).
boy illustration
Новый бесплатный RooCline превосходит Cline v3.1? ! Быстрее, умнее и лучше вилка Cline! (Независимое программирование AI, порог 0)
boy illustration
Разработав более 10 проектов с помощью Cursor, я собрал 10 примеров и 60 подсказок.
boy illustration
Я потратил 72 часа на изучение курсорных агентов, и вот неоспоримые факты, которыми я должен поделиться!
boy illustration
Идеальная интеграция Cursor и DeepSeek API
boy illustration
DeepSeek V3 снижает затраты на обучение больших моделей
boy illustration
Артефакт, увеличивающий количество очков: на основе улучшения характеристик препятствия малым целям Yolov8 (SEAM, MultiSEAM).
boy illustration
DeepSeek V3 раскручивался уже три дня. Сегодня я попробовал самопровозглашенную модель «ChatGPT».
boy illustration
Open Devin — инженер-программист искусственного интеллекта с открытым исходным кодом, который меньше программирует и больше создает.
boy illustration
Эксклюзивное оригинальное улучшение YOLOv8: собственная разработка SPPF | SPPF сочетается с воспринимаемой большой сверткой ядра UniRepLK, а свертка с большим ядром + без расширения улучшает восприимчивое поле
boy illustration
Популярное и подробное объяснение DeepSeek-V3: от его появления до преимуществ и сравнения с GPT-4o.
boy illustration
9 основных словесных инструкций по доработке академических работ с помощью ChatGPT, эффективных и практичных, которые стоит собрать
boy illustration
Вызовите deepseek в vscode для реализации программирования с помощью искусственного интеллекта.
boy illustration
Познакомьтесь с принципами сверточных нейронных сетей (CNN) в одной статье (суперподробно)
boy illustration
50,3 тыс. звезд! Immich: автономное решение для резервного копирования фотографий и видео, которое экономит деньги и избавляет от беспокойства.
boy illustration
Cloud Native|Практика: установка Dashbaord для K8s, графика неплохая
boy illustration
Краткий обзор статьи — использование синтетических данных при обучении больших моделей и оптимизации производительности
boy illustration
MiniPerplx: новая поисковая система искусственного интеллекта с открытым исходным кодом, спонсируемая xAI и Vercel.
boy illustration
Конструкция сервиса Synology Drive сочетает проникновение в интрасеть и синхронизацию папок заметок Obsidian в облаке.
boy illustration
Центр конфигурации————Накос
boy illustration
Начинаем с нуля при разработке в облаке Copilot: начать разработку с минимальным использованием кода стало проще
boy illustration
[Серия Docker] Docker создает мультиплатформенные образы: практика архитектуры Arm64
boy illustration
Обновление новых возможностей coze | Я использовал coze для создания апплета помощника по исправлению домашних заданий по математике
boy illustration
Советы по развертыванию Nginx: практическое создание статических веб-сайтов на облачных серверах
boy illustration
Feiniu fnos использует Docker для развертывания личного блокнота Notepad
boy illustration
Сверточная нейронная сеть VGG реализует классификацию изображений Cifar10 — практический опыт Pytorch
boy illustration
Начало работы с EdgeonePages — новым недорогим решением для хостинга веб-сайтов
boy illustration
[Зона легкого облачного игрового сервера] Управление игровыми архивами
boy illustration
Развертывание SpringCloud-проекта на базе Docker и Docker-Compose