- Руководство по команде dmesg для начинающих
- Команда Linux dmesg
- Q1. Как использовать команду dmesg?
- Q2. Как ограничить вывод только ошибками и предупреждениями?
- Q3. Как заставить dmesg выводить временные метки?
- Q4. Как заставить dmesg отображать информацию, специфичную для устройства?
- Q5. Как заставить dmesg отображать только сообщения пользователя?
- Заключение
- Команда Dmesg в Linux
- Использование команды dmesg
- Формирование вывода dmesg
- Команда Dmesg в Linux
- Dmesg Command in Linux
- В этом руководстве мы рассмотрим основы dmesg команды.
- Использование dmesg команды
- Форматирование dmesg вывода
- Фильтрация dmesg вывода
- Очистка кольцевого буфера
- Вывод
- Linux dmesg команда инструкция для начинающих (5 примеров)
- Команда Linux dmesg
- В1. Как использовать команду dmesg?
- В2. Как ограничить вывод только ошибками и предупреждениями?
- В3. Как создать dmesg для создания временных меток?
Руководство по команде dmesg для начинающих
Оригинал: Linux dmesg Command Tutorial for Beginners (5 Examples)
Автор: Himanshu Arora
Дата публикации: 3 июля 2018 года
Перевод: А. Кривошей
Дата перевода: январь 2019 г.
Знаете ли вы, что ядро Linux загружает несколько драйверов устройств при загрузке системы? На самом деле, когда ваша система запущена и работает, и вы подключаете аппаратное устройство, то также загружается соответствующий драйвер устройства. Конечно, ядро также делает много других вещей. Что если вы хотите узнать информацию, связанную с этими действиями ядра?
Есть команда dmesg, которую вы можете использовать, если хотите получить доступ к сообщениям, выводимым ядром. В этом руководстве мы разберемся, как работает утилита dmesg, используя несколько простых для понимания примеров.
Команда Linux dmesg
Команда dmesg позволяет вам печатать или управлять буфером кольца ядра. Ниже ее синтаксис:
И вот как справочная страница утилиты объясняет ее назначение:
dmesg используется для проверки содержимого или управления буфером кольца ядра. Действие по умолчанию — отобразить все сообщения из буфера кольца ядра.
Ниже приведены примеры в стиле вопрос/ответ, которые должны дать вам лучшее представление о том, как работает команда dmesg.
Q1. Как использовать команду dmesg?
Вы можете для начала ввести команду dmesg без опций командной строки.
Например, вот небольшая часть вывода команды, созданной в моем случае:
Q2. Как ограничить вывод только ошибками и предупреждениями?
Если вы запустите dmesg в своей системе, вы увидите, что она выводит множество информации. В зависимости от того, что вы ищете, вы можете фильтровать или ограничивать вывод. Со своей стороны, dmesg предлагает вам реализацию этой возможности с помощью «уровней». Ниже приводится полный список уровней (вместе с их объяснением):
emerg — система не работает;
alert — действие должно быть выполнено немедленно;
crit — критические условия;
err — условия ошибок;
warn — условия предупреждениий;
notice — нормальное, но существенное состояние;
info — информационный;
debug — сообщения уровня отладки.
Например, если вы хотите ограничить вывод только ошибками и предупреждениями, вы можете сделать это следующим образом:
В моем случае, вот часть вывода, который выдает указанная выше команда:
Q3. Как заставить dmesg выводить временные метки?
Иногда вам может понадобиться, чтобы с сообщениями, создаваемыми dmesg, была связана временная метка. Это можно сделать с помощью параметра командной строки -T, который создает удобочитаемые временные метки.
Q4. Как заставить dmesg отображать информацию, специфичную для устройства?
Предположим, вы хотите, чтобы dmesg отображал только информацию, связанную с интерфейсом eth0. Вот как вы можете это сделать:
Q5. Как заставить dmesg отображать только сообщения пользователя?
Если вы хотите ограничить вывод dmesg только сообщениями в пользовательском пространстве, используйте параметр командной строки -u.
Заключение
Согласен, dmesg — это не та команда, которая будет вам нужна каждый день. Но это инструмент, к которому можно обратиться, когда кто-то (к кому вы обратились за помощью по определенной теме) попросит вас предоставить сообщения ядра. Чаще всего я встречал этот случай на онлайн-форумах, где опытные пользователи запрашивают вывод ядра.
Здесь, в этом уроке, мы обсудили команду dmesg с точки зрения начинающих. Более подробную информацию можно получить, изучив справочную страницу команды.
Источник
Команда Dmesg в Linux
Ядро Linux — это ядро операционной системы, которое контролирует доступ к системным ресурсам, таким как ЦП, устройства ввода-вывода, физическая память и файловые системы. Ядро записывает различные сообщения в кольцевой буфер ядра во время процесса загрузки и во время работы системы. Эти сообщения содержат различную информацию о работе системы.
Кольцевой буфер ядра — это часть физической памяти, в которой хранятся сообщения журнала ядра. Он имеет фиксированный размер, что означает, что после заполнения буфера старые записи журналов перезаписываются.
Утилита командной строки dmesg используется для печати и управления кольцевым буфером ядра в Linux и других Unix-подобных операционных системах. Это полезно для изучения сообщений загрузки ядра и отладки проблем, связанных с оборудованием.
В этом руководстве мы рассмотрим основы команды dmesg .
Использование команды dmesg
Синтаксис команды dmesg следующий:
При запуске без каких-либо параметров dmesg записывает все сообщения из кольцевого буфера ядра в стандартный вывод:
По умолчанию все пользователи могут запускать команду dmesg . Однако в некоторых системах доступ к dmesg может быть ограничен для пользователей без полномочий root. В этой ситуации при вызове dmesg вы получите сообщение об ошибке, подобное приведенному ниже:
Параметр ядра kernel.dmesg_restrict указывает, могут ли непривилегированные пользователи использовать dmesg для просмотра сообщений из буфера журнала ядра. Чтобы снять ограничения, установите его на ноль:
Обычно вывод содержит много строк информации, поэтому видна только последняя часть вывода. Чтобы видеть по одной странице за раз, направьте вывод в утилиту пейджера, например, less или more :
—color=always используется для сохранения цветного вывода.
Если вы хотите фильтровать сообщения буфера, используйте grep . Например, чтобы просмотреть только сообщения, относящиеся к USB, вы должны ввести:
dmesg читает сообщения, генерируемые ядром, из виртуального файла /proc/kmsg . Этот файл предоставляет интерфейс для кольцевого буфера ядра и может быть открыт только одним процессом. Если в вашей системе запущен процесс syslog и вы пытаетесь прочитать файл с помощью cat или less , команда зависнет.
Демон syslog выгружает сообщения ядра в /var/log/dmesg , поэтому вы также можете использовать этот файл журнала:
Формирование вывода dmesg
Команда dmesg предоставляет ряд параметров, которые помогут вам отформатировать и отфильтровать вывод.
Один из наиболее часто используемых параметров dmesg — -H ( —human ), который позволяет выводить данные в удобочитаемом для человека —human . Эта опция направляет вывод команды в пейджер:
Чтобы напечатать удобочитаемые метки времени, используйте параметр -T ( —ctime ):
Формат временных меток также можно установить с помощью параметра —time-format
Источник
Команда Dmesg в Linux
Dmesg Command in Linux
В этом руководстве мы рассмотрим основы dmesg команды.
Ядро Linux — это ядро операционной системы, которое контролирует доступ к системным ресурсам, таким как процессор, устройства ввода-вывода, физическая память и файловые системы. Ядро записывает различные сообщения в кольцевой буфер ядра в процессе загрузки и во время работы системы. Эти сообщения содержат различную информацию о работе системы.
Кольцевой буфер ядра — это часть физической памяти, которая содержит сообщения журнала ядра. Он имеет фиксированный размер, что означает, что после заполнения буфера старые записи журналов перезаписываются.
dmesg — Утилита командной строки используется для печати и управления кольцевого буфера ядра в Linux и других Unix-подобных операционных систем. Это полезно для изучения загрузочных сообщений ядра и устранения проблем, связанных с оборудованием.
Использование dmesg команды
Синтаксис dmesg команды следующий:
При вызове без каких-либо параметров dmesg записывает все сообщения из кольцевого буфера ядра в стандартный вывод:
По умолчанию все пользователи могут запускать dmesg команду. Однако в некоторых системах доступ к ним dmesg может быть ограничен для пользователей без полномочий root. В этой ситуации при вызове dmesg вы получите сообщение об ошибке, как показано ниже:
Параметр ядра kernel.dmesg_restrict указывает, могут ли непривилегированные пользователи dmesg просматривать сообщения из буфера журнала ядра. Чтобы снять ограничения, установите его на ноль:
Обычно выходные данные содержат много строк информации, так что только последняя часть выходных данных является видимой. Чтобы увидеть одну страницу за раз, перенаправьте вывод в утилиту пейджера, такую как less или more :
—color=always Используется для сохранения цветного вывода.
Если вы хотите фильтровать сообщения буфера, используйте grep . Например, чтобы просмотреть только сообщения, связанные с USB, вы должны набрать:
dmesg читает сообщения, сгенерированные ядром, из /proc/kmsg виртуального файла. Этот файл предоставляет интерфейс к кольцевому буферу ядра и может быть открыт только одним процессом. Если syslog в вашей системе запущен процесс, и вы пытаетесь прочитать файл с помощью cat , или less , команда зависнет.
syslog Демон отвалов сообщения ядра /var/log/dmesg , так что вы можете использовать этот файл журнала:
Форматирование dmesg вывода
Команда dmesg предоставляет ряд опций, которые помогут вам отформатировать и отфильтровать вывод.
Одна из наиболее часто используемых опций dmesg — это -H ( —human ), которая обеспечивает удобочитаемый вывод. Эта опция направляет вывод команды в пейджер:
Для печати удобочитаемых временных меток используйте опцию -T ( —ctime ):
Формат —time-format отметок времени также может быть установлен с помощью параметра, который может быть ctime, reltime, delta, notime или iso. Например, чтобы использовать дельта-формат, введите:
Вы также можете объединить два или более вариантов:
Чтобы просмотреть вывод dmesg команды в режиме реального времени, используйте параметр -w ( —follow ):
Фильтрация dmesg вывода
Вы можете ограничить dmesg вывод данными объектами и уровнями.
Средство представляет процесс, который создал сообщение. dmesg поддерживает следующие возможности журнала:
- kern — сообщения ядра
- user — сообщения уровня пользователя
- mail — почтовая система
- daemon — системные демоны
- auth — сообщения безопасности / авторизации
- syslog — внутренние сообщения syslogd
- lpr — подсистема линейного принтера
- news — подсистема сетевых новостей
Опция -f ( —facility
) позволяет ограничить вывод определенными объектами. Опция принимает одно или несколько разделенных запятыми объектов.
Например, для отображения только сообщений ядра и системных демонов вы должны использовать:
Каждое сообщение журнала связано с уровнем журнала, который показывает важность сообщения. dmesg поддерживает следующие уровни журнала:
- emerg — система неработоспособна
- alert — действие должно быть предпринято немедленно
- crit — критические условия
- err — условия ошибки
- warn — условия предупреждения
- notice — нормальное, но значимое состояние
- info — информационный
- debug — сообщения уровня отладки
Опция -l ( —level
) ограничивает вывод определенными уровнями. Опция принимает один или несколько уровней, разделенных запятыми.
Следующая команда отображает только сообщения об ошибках и критические сообщения:
Очистка кольцевого буфера
Опция -C ( —clear ) позволяет очистить кольцевой буфер:
Только root или пользователи с привилегиями sudo могут очистить буфер.
Чтобы распечатать содержимое буфера перед очисткой, используйте параметр -c ( —read-clear ):
Если вы хотите сохранить текущие dmesg журналы в файле перед его очисткой, перенаправьте вывод в файл:
Вывод
Команда dmesg позволяет вам просматривать и контролировать кольцевой буфер ядра. Это может быть очень полезно при устранении проблем с ядром или оборудованием.
Введите man dmesg в своем терминале информацию о всех доступных dmesg опциях.
Источник
Linux dmesg команда инструкция для начинающих (5 примеров)
Знаете ли вы, что ядро Linux загружает несколько драйверов устройств при загрузке системы?
Фактически, когда ваша система запущена и работает, и вы подключаете аппаратное устройство, то также загружается соответствующий драйвер устройства.
Конечно, ядро также делает много других вещей.
Что делать, если вы хотите узнать информацию, связанную с этими действиями ядра?
Что ж, существует команда – dmesg – которую вы можете использовать, если хотите получать доступ к сообщениям, выведенные ядром.
В этом уроке мы поймем, как работает инструмент dmesg, используя несколько простых для понимания примеров.
Команда Linux dmesg
Синтаксис команды dmesg:
Ниже приведены примеры Вопрос & Ответ, которые помогут вам лучше понять, как работает команда dmesg.
В1. Как использовать команду dmesg?
Вы можете начать использовать команду dmesg без любой опции командной строки.
Например, вот небольшая часть вывода команды, созданной в моем случае:
В2. Как ограничить вывод только ошибками и предупреждениями?
Если вы запустите dmesg в своей системе, вы увидите, что он выводит множество информации.
В зависимости от того, что вы ищете, вы можете фильтровать или ограничивать вывод.
Со своей стороны, dmesg предлагает вам эту способность через «уровни».
Ниже приведен полный список уровней (вместе с их объяснением):
Например, если вы хотите ограничить вывод только ошибками и предупреждениями, вы можете сделать это следующим образом:
В моем случае, вот часть вывода выведенной выше команды:
В3. Как создать dmesg для создания временных меток?
Иногда вам может понадобиться связать временную метку с сообщениями, которые создает dmesg.
Это можно сделать, используя опцию командной строки -T, которая создает человекочитаемые метки времени.
В4. Как сделать, что dmesg отображал информацию об определенном устройстве?
Предположим, вы хотите, чтобы dmesg отображал только информацию, связанную с интерфейсом eth0.
Вот как вы можете это сделать:
В5. Как заставить dmesg отображать только сообщения в пользовательском пространстве?
Если вы хотите ограничить вывод dmesg только сообщениями пользовательского пространства, используйте параметр командной строки -u.
Согласитесь, dmesg – это не та команда, которая вам понадобится каждый день.
Но это инструмент, к которому нужно обратиться, когда кто-то (которого вы попросили о помощи по определенной теме) просит вас предоставить сообщения ядра.
В основном я видел этот случай на форумах онлайн-пользователей, где опытные пользователи просят вывод ядра.
Источник