Архив метки: Linux

Как изменить имя хоста в Oracle Linux 8

Когда вы приобретаете новую компьютерную систему или устанавливаете новую виртуальную машину в уже существующей компьютерной системе, у системы будет имя хоста или имя устройства по умолчанию. В Oracle Linux 8 вы можете изменить имя хоста сервера в соответствии с вашими предпочтениями. В этой статье показаны два наиболее эффективных метода изменения имени хоста системы Oracle Linux 8.

 

Способы изменения имени хоста в Oracle Linux 8

Есть два метода, которые вы можете использовать для изменения имени хоста вашей системы Oracle Linux 8:

  1. Метод GUI (графический интерфейс пользователя)
  2. Метод CLI (интерфейс командной строки)

В следующих разделах показано, как изменить имя хоста вашего сервера с помощью каждого из этих методов.

 

Метод I: Метод с графическим интерфейсом

Чтобы изменить имя хоста вашей системы Oracle Linux 8 с помощью метода графического интерфейса пользователя, выполните следующие пять быстрых шагов.

 

Шаг 1. Проверьте текущее имя хоста

Прежде чем пытаться изменить имя хоста вашей системы Oracle Linux 8, вы должны сначала проверить текущее имя хоста, чтобы после изменения имени хоста вы могли легко проверить, произошли ли изменения. Чтобы проверить текущее имя хоста вашей системы Oracle Linux 8, запустите терминал, а затем выполните в терминале следующую команду:

$ hostnamectl

Команда hostnamectl отображает имя хоста вашей системы, а также некоторые другие детали, связанные с системой, например информацию об ее архитектуре, ядре, операционной системе и т. д. Текущее имя хоста моей системы Oracle Linux 8 — 10.0.2.15.

 

Шаг 2. Доступ к настройкам системы

Теперь мы изменим имя хоста, которое мы нашли на предыдущем шаге. Для этого нам сначала нужно получить доступ к системным настройкам Oracle Linux 8. Просто щелкните правой кнопкой мыши в любом месте рабочего стола Oracle Linux 8 и выберите параметр «Параметры» в появившемся раскрывающемся меню.

 

Шаг 3. Доступ к сведениям о системе

После того, как вы выберете опцию «Настройки» в раскрывающемся меню, на вашем экране появится окно «Системные настройки Oracle Linux 8». Используйте полосу прокрутки на самой левой панели этого окна, чтобы прокрутить вниз и найти вкладку «Подробности». Эта вкладка соответствует сведениям о системе Oracle Linux 8; просто щелкните эту вкладку, чтобы получить доступ к сведениям о системе.

 

Шаг 4. Измените имя хоста

Щелкнув вкладку «Подробности» в окне «Параметры системы Oracle Linux 8», вы сможете увидеть все основные сведения, относящиеся к системе, такие как память, процессор, тип ОС и т. д. Здесь вы также увидите поле, которое соответствует имени устройства, как показано на следующем изображении. Имя устройства — это фактически имя хоста вашей системы Oracle Linux 8.

В текстовом поле, соответствующем тегу имени устройства, введите любое имя хоста по вашему выбору. Мы решили изменить имя устройства или имя хоста с 10.0.2.15 на Andrey Ex. После внесения этих изменений закройте окно системных настроек Oracle Linux 8, и изменение имени хоста должно быть завершено.

 

Шаг 5. Убедитесь, что имя хоста изменилось

К настоящему времени имя хоста нашей системы Oracle Linux 8 должно было быть успешно изменено. Однако всякий раз, когда вы пытаетесь изменить настройки системы, всегда рекомендуется проверять, произошли ли желаемые изменения. Чтобы проверить, было ли изменено имя хоста вашей системы Oracle Linux 8, снова выполните следующую команду:

$ hostnamectl

Нам успешно удалось изменить имя хоста нашей системы Oracle Linux 8 с 10.0.2.15 на Andrey Ex. Вы можете выбрать любое другое имя хоста по вашему выбору.

 

Метод II: метод командной строки

Чтобы изменить имя хоста вашей системы Oracle Linux 8 с помощью терминала, выполните следующие два простых шага.

 

Шаг 1. Измените имя хоста

Перед выполнением этого шага вы можете проверить свое текущее имя хоста, как мы это делали в методе № 1, с помощью команды hostnamectl. После проверки текущего имени хоста вы можете изменить имя хоста, выполнив следующую команду в терминале Oracle Linux 8:

$ hostnamectl set-hostname NewHostname

Здесь замените NewHostname любым именем, которое вы хотите использовать в качестве нового имени хоста. Мы изменили имя хоста на AndreyEx.

Если эта команда выполняется без ошибок, то она не будет отображать никаких сообщений в терминале.

 

Шаг 2: проверьте, изменилось ли имя хоста

После изменения имени хоста вашей системы Oracle Linux 8 через терминал вы можете легко проверить его, выполнив следующую команду:

$ hostnamectl

Как показано на следующем изображении, наше статическое имя хоста теперь является Andrey, поэтому было подтверждено, что нам удалось успешно изменить имя хоста нашей системы Oracle Linux 8.

 

Заключение

В этой статье мы представили вам как метод на основе графического интерфейса пользователя, так и метод на основе интерфейса командной строки для изменения имени хоста вашей системы Oracle Linux 8. Вы можете выбрать наиболее удобный для вас метод. Следуя любому из этих методов, вы можете изменять имя хоста вашей системы Oracle Linux 8 столько раз, сколько захотите. Если вы допустили ошибку при присвоении имени своему устройству, вы можете исправить ее, как только поймете это, следуя методам, описанным в этой статье.



2020-12-25T14:44:05
Oracle Linux

Как установить и использовать FFmpeg в CentOS 7

FFmpeg — это бесплатный набор инструментов с открытым исходным кодом для работы с мультимедийными файлами. Он содержит набор общих аудио и видео библиотек, таких как libavcodec, libavformat и libavutil. С FFmpeg вы можете конвертировать между различными видео и аудио форматами, устанавливать частоту дискретизации, захватывать потоковое аудио / видео и изменять размер видео.

Это руководство проведет вас через установку FFmpeg на CentOS 7. Читать

Как вывести список пользователей в Ubuntu Linux

Linux — отличная операционная система, которая широко используется для командных проектов. Итак, хорошо бы иметь подробную информацию о пользователях системы. Получить подробную информацию о пользователях системы в Ubuntu Linux VPS легко, а ввод из командной строки может помочь системному администратору проверить права доступа и действия пользователей в системе.

Очень важно изучить эти команды, чтобы иметь возможность быстро увидеть список пользователей в вашей системе Ubuntu VPS. В этой статье показано, как использовать командную строку для вывода списка пользователей в Ubuntu Linux VPS.

Как составить список пользователей в Ubuntu Linux VPS: руководство для начинающих

Если вы хотите просмотреть всех пользователей в Linux Ubuntu VPS, вы можете использовать команду /etc/passwd, поскольку данные локального пользователя сохраняются в файле «/etc/passwd». Есть два способа выполнить эту команду, а именно:

cat /etc/passwd

Или же

less /etc/passwd

После успешного выполнения указанной выше команды вы получите следующий результат:

Эти выходные строки относятся к пользователям. Количество строк зависит от количества пользователей в системе.

Каждая строка содержит семь разных полей, которые представляют подробные сведения о конкретном пользователе. Например, первая строка вывода — это root:x:0:0:root:/root:/bin/bash, что означает:

  • root — логин пользователя.
  • b — заполнитель пароля, так как фактический пароль сохраняется в отдельном файле.
  • 0 — UserID пользователя.
  • 0 — GroupID пользователя.
  • root — командное поле с некоторыми подробностями о пользователе.
  • /root — домашний каталог, который является основным каталогом пользователя.
  • /bin/bash — оболочка пользователя.

Обратите внимание, что двоеточия (:) используются для разделения значений в выводе.

Выполните следующие команды, чтобы увидеть имена пользователей:

cut -d : -f 1 /etc/passwd

Или же

awk -F: '{ print $1}' /etc/passwd

Как просматривать группы в Ubuntu Linux VPS

Вы также можете создавать группы, собирая нескольких пользователей и давая им некоторые административные права в системе. Этот вариант удобен для создания групп пользователей в одной системе. Информация об этих группах будет сохранена в папке Group. Итак, используйте следующую команду для просмотра групп в терминале.

less /etc/group

После успешного выполнения команды вы получите следующий результат:

Используйте команду ниже, если вы хотите отобразить имена групп:

cut -d : -f 1 /etc/group

Как вывести список пользователей в Ubuntu Linux VPS с помощью команды getent

Команда getent используется для отображения записей из базы данных, настроенной в файле /etc/nsswitch.conf. Он охватывает базу данных passwd, которую можно использовать для запроса списка пользователей. Команда getent отображает записи из баз данных, настроенных в файле /etc/nsswitch.conf, включая базу данных passwd, для запроса списка всех пользователей.

Используйте следующую команду для выполнения getent в терминале:

getent passwd

После выполнения команды вы получите следующий вывод:

Вы можете использовать awk или cut для печати первого поля, содержащего имя пользователя:

getent passwd | awk -F: '{ print $1}'

getent passwd | cut -d: -f1

Как просмотреть зарегистрированных пользователей с помощью команды w

Вы можете использовать команду w для вывода списка зарегистрированных пользователей Linux Ubuntu VPS. Чтобы использовать эту команду, введите «w» в терминале и выполните ее, нажав Enter.

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

  • user -⁠ представляет имя пользователя.
  • TTY ⁠- представляет имя терминала.
  • From ⁠- представляет имя удаленного хоста.
  • Login@ — время входа в систему.
  • Idle — представляет собой простой.
  • JCPU — ⁠ представляет время, используемое процессом, связанным с TTY.
  • PCPU ⁠ — представляет время, используемое конкретным процессом, отображаемым в поле WHAT.
  • WHAT ⁠- представляет текущий процесс пользователя.

Заключение

В этой статье подробно описано, как составить список пользователей и информацию о пользователях в Ubuntu Linux VPS. Эти команды помогают системным администраторам получить сведения о пользователях, использующих определенную систему, и узнать другие важные сведения о них. Надеемся, статья была достаточно информативной и исчерпывающей для ваших нужд.



2020-12-23T11:17:03
Вопросы читателей

Команда mount или как правильно смонтировать диск в Линукс. Монтирование диска в Linux — команда mount.



























Rate this post

Если нужно подключить/примонтировать жесткий диск с файловой системой NTFS или ext2, ext3 к компьютеру на базе операционной системы Linux, то команда mount незаменима. Mount — утилита командной строки в UNIX-подобных операционных системах. Применяется для монтирования файловых систем. В статье приведено описание и примеры для операционной системы GNU/Linux. mount /dev/cdrom /mnt/cdrom.

Монтирование что это?

Монтирование – это подключение диска, раздела, каталога или файла в корневую систему Linux.

Как уже сказано было выше, в ОС «Линукс» имеется общая корневая система. Именно к ней подключаются все устройства и ресурсы, которыми пользуется владелец ПК. Если углубиться в эту сферу более подробно, Windows выполняет процедуры аналогично, но все процесс скрыты от пользователя.

После монтирования определённый раздел становится частью корневой системы, которая всяческими способами пытается сделать свою работу максимально прозрачной. К примеру, после монтирования оперативной памяти или удаленной системной папки пользователь может изучить ее в файловом менеджере. Допускается работа с такими разделами. Она будет аналогична работе, которая касается локального диска.

Синтаксис команды mount

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

Процесс использования утилиты подразумевает обаятельное применение всевозможных опций, каждая из которых выполняет свою функцию. К примеру, опция «-t» является необязательной, но дает возможность без особого труда задать файловую систему, которая в последующем будет использоваться. Нередко это оказывается весьма полезным.

Специальная опция «-о» позволяет предварительно прописать параметры, которые будут распространяться на монтирование. В синтаксис обаятельно включен адрес файл, по которому расположено само устройство, а также папка назначения.

Перед тем, как приступить к полноценному использованию утилиты «mount», рекомендуется максимально подробно изучить список опций. На самом деле их огромное множество, но чаще всего применяются:

  • «-v». Отображение максимально подробного режима.
  • «-a». Монтируются все требуемые устройства, которые предварительно прописаны в fstab
  • «-F». Создается отдельный экземпляр утилиты для каждого из исследуемых разделов.
  • «-n». Исключается вероятность записи информации о выполняемом монтировании в /etc/mtab.
  • «-f». Исключается вероятность осуществления каких-либо действий. С помощью такой опции можно посмотреть перечень процедур, которые планирует выполнить утилита.
  • «-l». Добавляется специальная метка на диск, которая приравнивается к точке монтирования.
  • «-c». При выполнении команды не использовать относительные пути, а руководствоваться только абсолютными путями (пример – /etc/exim4) .
  • «-r». Создаваемый раздел будет доступен лишь для чтения.
  • «-w». Создаваемый раздел будет доступен как для чтения, так и для записи.
  • «-L». Монтируется раздел с использованием метки.
  • «-U». Монтируется раздел с использованием UUID.
  • «-T». Появляется возможность применения альтернативного fstab
  • «-B». Монтируется раздел в локальную папку
  • «-R». Перемонтируется сама локальная папка.
  • «-h». Вывести справочную информацию.
  • «-V». Параметр покажет текущею версию утилиты.

Представленный выше список опций является неполным. Такие функции основные, чаще всего могут потребоваться пользователю операционной системы «Линукс» во время работы с утилитой «mount».

Монтирование файловой системы командой mount

Для подключения файловой системы к конкретному местоположению (точке монтирования) команда mount используется в следующей форме:

mount [опции…] имя_устройства директория

После подключения точка монтирования становится корневой директорией смонтированной ФС. Например, смонтировать жесткий диск /dev/sdb1 в директорию /mnt/media можно следующим образом:

$ sudo mount /dev/sdb1 /mnt/media

Обычно при монтировании устройства с распространенной ФС, например, ext4 или xfs, команда mount автоматически определяет ее тип. Однако, некоторые ФС не распознаются. Их тип нужно указывать в явном виде. Для этого используется опция -t:

mount -t тип имя_устройства директория

Чтобы указать дополнительные опции монтирования, используется флаг -o:

mount -o опции_монтирования имя_устройства директория

Можно указать несколько опций, разделенных запятыми (после запятых не должно быть пробелов). Ниже предоставлены основные опции команды

-V — вывести версию утилиты;

-h — вывести справку;

-v — подробный режим;

-a, —all — примонтировать все устройства, описанные в fstab;

-F, —fork — создавать отдельный экземпляр mount для каждого отдельного раздела;

-f, —fake — не выполнять никаких действий, а только посмотреть что собирается делать утилита;

-n, —no-mtab — не записывать данные о монтировании в /etc/mtab;

-l, —show-labels — добавить метку диска к точке монтирования;

-c — использовать только абсолютные пути;

-r, —read-only — монтировать раздел только для чтения;

-w, —rw — монтировать для чтения и записи;

-L, —label — монтировать раздел по метке;

-U, —uuid — монтировать раздел по UUID;

-T, —fstab — использовать альтернативный fstab;

-B, —bind — монтировать локальную папку;

-R, —rbind — перемонтировать локальную папку.

Полный список опций можно получить, выполнив команду man mount.

Монтирование разделов с помощью mount

Монтирование разделов с помощью mount выполняется очень просто. Фактически в большинстве случаев будет достаточно упрощенной версии команды. Например, смонтируем раздел /dev/sdb6 в папку /mnt:

В большинстве случаев вы будете вынуждены выполнять команду mount с правами суперпользователя, если обратное не указано в fstab (опция монтирования users). Вы можете посмотреть информацию о процессе монтирования добавив опцию -v:

sudo mount -v /dev/sdb6 /mnt/

Если нужно, вы можете указать файловую систему с помощью опции -t:

sudo mount -v -t ext4 /dev/sdb6 /mnt

Если необходимо примонтировать файловую систему только для чтения, то вы можете использовать опцию -r или опцию монтирования -o ro, результат будет одинаковым:

sudo mount -t ext4 -r /dev/sdb6 /mnt

$ sudo mount -t ext4 -o ro /dev/sdb6 /mnt

Вы можете использовать и другие опции чтобы выполнить монтирование разделов linux, например, указать, что на этом разделе нельзя выполнять программы:

sudo mount -t ext4 -o noexec /dev/sdb6 /mnt

Обратите внимание, что вы не можете использовать опции uid, gid, fmask для файловых систем ext. Они поддерживаются только в FAT, vFAT, exFAT.

Вы можете использовать не только имена устройств чтобы выполнить монтирование диска в linux. Для этого можно применять UUID или метки, например, монтирование с помощью UUID:

sudo mount —uuid=»b386d309-05c1-42c8-8364-8d37270b69e0″ /mnt

mount

Посмотреть uuid для ваших разделов можно с помощью команды:

sudu blki

Точно так же вы можете использовать метки. Команда монтирования диска linux будет выглядеть так:

sudo mount —label=»home» /mnt/

mount

Вы можете примонтировать одну папку в другую, для этого используйте опцию —bind

sudo mount —bind /mnt/ /media/

Возможно, не только монтирование разделов linux, но и монтирование файлов, если они содержат файловую систему, например, образов дисков. Монтирование образа диска linux работает точно так же:

sudo mount ~/file.iso /mnt

Посмотреть список всех примонтированных устройств можно просто выполнив mount без параметров:

mount

mount

Примеры команды mount

Наиболее простая команда, позволяющая изучить список всех устройств, примонтированных в вашей операционной системе Линукс. Достаточно ввести утилиту без параметров.

mount

Смонтируем раздел /dev/sda6 в папку /root/newpapka. Предварительно посмотрим все разделы в Линукс, с помощью команды “df -h”.

Монтирование раздела sda6

ВАЖНО! Обычно команда mount требует прав суперпользователя, если обратного не требует fstab.

Есть несколько вариантов запуск утилиты от root:

  1. Войти в учетную запись root.
  2. Использовать sudo.
  3. Ввести команду su-.

Утилита дает возможность сделать монтировать одну папку в другую. Для этого предусмотрена специальная опция «–bind».

sudo mount –bind /root/katalog /root/newpapka

Каталог1 в каталог2

Пользователю может потребоваться указание определённой файловой системы. Для этого посмотрим список всех разделов, с помощью df -h.

df -h

Далее узнаем к какой файловой системе относится раздел /dev/sda6, с помощью утилиты “file”.

file -s /dev/sda6

Узнаем файловую систему

Примонтируем файловую систему “ext4” в каталог “primercataloga”. В данном случае используется опция «-t».

mount -t ext4 /dev/sda6 /root/primercataloga

Примонтируем ext4

Если в последующем смонтированная файловая система будет использоваться только для чтения, применяется опция «-r».  Для примера смонтируем /dev/sda6 в ту же папку “newpapka”, однако так как мы уже делали это в прошлом примере, система будет ругаться. “already mounted or /root/newpapka busy”.

already mounted or busy

Именно поэтому нужно сначала размонтировать каталог. Для этого будем использовать команду umount.

umount /root/newpapka

Пример размонтирования каталога

Далее монтируем с опцией -r.

mount -r /dev/sda6 /root/newpapka

Есть возможность указать и иные опции, которые будут распространяться на смонтированные разделы в «Линукс». Если требуется запрет выполнения программ в определенной файловой системе, вводится:

mount -t ext4 -o noexec /dev/sda6 /root/primercataloga

При монтировании диска можно указать не только имена различных устройств. Для составления команды нередко применяется UUID. Вводится:

sudo mount –uuid=”a5d3369c-8c1b-42c4-869f-05d9d286196e” /katalog

где a5d3369c-8c1b-42c4-869f-05d9d286196e – это уникальный номер uuid. Посмотреть его можно с помощью утилиты blkid.

blkid

uuid

При монтировании диска можно указать определенные метки. Для этих целей нужно предварительно узнать ту самую метку, потом уже можно приступить к монтированию.

Узнаем:

sudo e2label /dev/sda6

Утилита e2label умеет изменять метки, а также выводить их на экран.

e2label

sudo mount –label=”root1″ /root/katalog

Утилита «mount» имеет широкие возможности. С ее помощью можно монтировать не только определенные разделы, но и файлы, например образы iso. Это можно осуществить только в том случае, если в них содержится файловая система.

sudo mount /root/obraz-diska.iso /root/disk

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

Примеры использования mount

Давайте рассмотрим несколько примеров использования утилиты. Как правило для монтирования нужно выполнить всего два действия

  1. Создать точку монтирования
  2. Примонтировать файловую систему

Монтирование USB-накопителя/жесткого диска

В большинстве современных дистрибутивов Linux, например, Ubuntu, USB-накопители автоматически монтируются при подключении, но иногда может потребоваться ручное монтирование устройства. Чтобы смонтировать USB-накопитель, выполните следующие действия.

Создайте точку монтирования

sudo mkdir -p /media/usb

Если USB-накопитель использует устройство /dev/sdd1, его можно смонтировать в директорию /media/usb следующей командой:

sudo mount /dev/sdd1 /media/usb

Для поиска устройства и типа файловой системы можно воспользоваться любой из следующих команд:

  • fdisk -l
  • ls -l /dev/disk/by-id/usb*
  • dmesg
  • lsblk

Монтирование дисков CD/DVD-ROM Наверх

Если Вам нужно примонтировать CD/DVD-ROM, то монтирование CD/DVD-ROM осуществляется точно так же, той же командой mount, которая были приведены выше:

# sudo mount -t iso9660 -o ro /dev/cdrom /cd Только при монтировании CD-ROM нужно указать тип файловой системы iso9660.

Монтирование образов диска ISO Наверх

Если Вы хотите примонтировать образ диска ISO, то это тоже достаточно просто сделать командой mount: # sudo mount -t iso9660 -o loop /home/file.iso /home/iso Где /home/file.iso — путь и имя файла ISO /home/iso — точка монтирования Добавился только параметр -o loop, который указывает, что используется файл .iso.

Монтирование NFS

Для монтирования системы NFS требуется установить клиент NFS. Установка клиента NFS в Ubuntu и Debian:

sudo apt install nfs-common

Установка клиента NFS в CentOS и Fedora:

sudo yum install nfs-utils

Создайте директорию, которая будет точкой монтирования удаленной файловой системы:

sudo mkdir /media/nfs

Обычно требуется автоматическое монтирование удаленной директории NFS при загрузке. Для этого нужно изменить файл конфигурации /etc/fstab. Откройте его в любом текстовом редакторе, например:

sudo nano /etc/fstab

Добавьте в файл следующую строку, заменив сервер:/директория на имя или IP-адрес сервера NFS и экспортируемую директорию:

#

сервер:/директория    /media/nfs nfs      defaults    0       0

Смонтируйте ресурс NFS следующей командой:

sudo mount /mnt/nfs

или

sudo mount -a

Монтирование сетевых дисков SMB Наверх

В некоторых случаях необходимо примонтировать удаленный сетевой диск. В некоторых дистрибутивах Linux, он так же монтируется автоматически (например в Ubuntu) при открытии его по сети. Можно примонтировать его вручную командой mount через консоль. Можно сделать ярлык и поместив его на рабочем столе активировать его когда нужен удаленный доступ к сетевому ресурсу. Ну или мало еще для чего.

# sudo mount -t smbfs -o username=vasja,password=pupkin //pupkin_v/Video /home/user/video Где username=vasja,password=pupkin — это имя и пароль доступа к удаленному сетевому ресурсу, а //pupkin_v/Video — имя сетевого ресурса, /home/user/video – точка монтирования

Размонтирование файловой системы

Для отключения смонтированной файловой системы используется команда umount, в качестве аргумента которой указывается директория, в которую она была смонтирована (точка монтирования) или имя устройства:

umount директория umount имя_устройства

Если файловая система используется, umount не сможет ее отключить. В таких ситуациях можно воспользоваться командой fuser, чтобы выяснить, какие процессы осуществляют доступ к файловой системе:

fuser -m директория

Определив процессы, можно остановить их и размонтировать файловую систему. Также для отключения занятой файловой системы сразу после завершения ее использования можно воспользоваться опцией -l (—lazy, “ленивое” отключение):

umount -l директория

Для принудительного размонтирования применяется опция -f (—force). Обычно она используется для отключения недостижимой системы NFS.

umount -f директория

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

Сохранение параметров mount после перезагрузки

Для того, что бы устройства при перезагрузки системы монтировались автоматически, необходимо прописать инструкции монтирования в файл /etc/fstab. Файл /etc/fstab содержит список записей в следующем формате:


[Файловая система] [Точка монтирования] [Тип файловой системы] [Опции] [Dump] [Номер прохода]

Например:

/dev/sdb1    /home    ext4    defaults 0 0

Подключит устройство /dev/sdb1 (например жесткий диск) в директорию /home

После того как инструкция для mount прописаны в /etc/fstab, что бы проверить правильность написания дайте команду

mount -a

Если команда отработает без ошибок, то все устройства прописанные в /etc/fstab будут подключены, а также изменения не потеряются после перезагрузки.

Пользовательские пространства имен

В листинге 1 приведена часть кода модуля PAM (pluggable authentication module, подключаемого модуля авторизации), который предоставляет каждому пользователю, кроме root, обособленное пространство имен. Если директория /tmp/priv/USER существует, то она будет смонтирована с помощью bind на директорию /tmp в пользовательском пространстве имен.

Настройка системы для организации отдельных каталогов root для каждого пользователя

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

В листинге 4 показан пример скрипта, используемого при создании любой учетной записи пользователя.


[spoiler title=»Источники»]

  • https://www.vseprolinux.ru/mount
  • https://hamsterden.ru/mount-umount/
  • https://ITProffi.ru/podklyuchenie-fajlovyh-sistem-komanda-mount-v-linux/
  • https://losst.ru/montirovanie-diska-v-linux
  • https://www.ibm.com/developerworks/ru/library/l-mount-namespaces/index.html


[/spoiler] VKTelegramFacebookTwitterGoogle+WhatsAp

Монтирование дисков в Linux

Способ 1: Утилита GParted

Существуют совершенно разные методы монтирования дисков в Linux, однако начинающим пользователям проще всего будет взаимодействовать с программами, в которых присутствует графический интерфейс. Одним из таких решений является GParted, по умолчанию установленное во многих популярных дистрибутивах. Предлагаем начать именно с него.

    1. Запустите операционную систему и отыщите GParted через меню приложений. Запуск осуществляется стандартным кликом по соответствующему значку.

Запуск утилиты GParted в Linux через меню приложений

    1. Для открытия подобных приложений всегда требуется подтверждение подлинности, поэтому придется ввести пароль от root, чтобы запустить окно.

Подтверждение запуска утилиты GParted в Linux через меню приложений

    1. Здесь отыщите необходимый раздел или физический накопитель, ориентируясь по его названию, файловой системе или размеру. Щелкните по выбранной строке правой кнопкой мыши.

Выбор раздела или диска в утилите GParted в Linux для монтирования

    1. В появившемся контекстном меню остается только нажать на «Монтировать».

Пункт для монтирования диска через утилиту GParted в Linux

Точно таким же образом осуществляется подключение любых съемных носителей, встроенных жестких дисков или отдельных логических разделов. В большинстве случаев эта операция проходит успешно, но если какая-то ошибка и появится, вы получите соответствующее уведомление с инструкциями по ее решению.

Способ 2: Стандартная утилита «Диски»

В большинстве популярных дистрибутивов имеется стандартная утилита под названием «Диски». Именно она и отвечает за управление накопителями. Если приведенного выше решения на ПК не оказалось или оно вам не подходит, выполните такие действия:

    1. Воспользуйтесь меню приложений, чтобы отыскать соответствующую утилиту. Запустите ее, нажав по значку.

Запуск утилиты Диски в Linux для монтирования раздела

    1. Здесь просмотрите существующие разделы. Можно назвать на кнопку в виде шестеренки, чтобы изучить дополнительные параметры и выбрать необходимый логический том для монтирования.

Выбор раздела в утилите Диски в Linux для монтирования

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

Кнопка для монтирования раздела или носителя в утилите Диски в Linux

    1. Это действие в обязательном порядке требует подтверждения подлинности, поэтому введите пароль суперпользователя в появившейся форме.

Подтверждение монтирования носителя или раздела в утилите Диски в Linux

    1. На рабочем столе появилась иконка смонтированного диска или раздела. Нажатие по ней правой кнопкой мыши открывает контекстное меню, в котором имеются пункты по управлению накопителем, в том числе и для его отсоединения.

Успешное монтирование носителя или раздела в утилите Диски в Linux

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

Способ 3: Терминальная команда

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

    1. Запустите «Терминал» удобным для вас образом, например, горячей клавишей Ctrl + Alt + T или через меню приложений.

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

    1. Введите команду sudo mount -v /dev/sda2 /mnt/, где /dev/sda2 — название необходимого диска, а /mnt/ — точка монтирования.

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

    1. Подтвердите данное действие, введя пароль суперпользователя. Это требуется, поскольку для активации команды был использован аргумент sudo.

Подтверждение монтирования диска через терминал Linux

    1. Вы будете уведомлены о том, что данная операция завершена успешно.

Успешное монтирование диска через терминал в Linux

Если вы не знаете точное название диска или логического тома, чтобы вписать его в строку, понадобится заранее уточнить эту информацию. Осуществляется поставленная задача тоже при помощи стандартных терминальных команд. Ориентироваться в выводах можно по размеру тома или его заполненности. Более детально о данной теме написано в отдельной статье на нашем сайте по следующей ссылке.

Подробнее: Просмотр списка дисков в Linux

Дополнительно отметим, что у команды mount есть множество полезных опций, позволяющих установить параметры монтирования. Рекомендуем ознакомиться с основными из них:

  • -r — подключение в формате только для чтения;
  • -w — монтирование с возможностью чтения и записи;
  • -c — использование абсолютных путей;
  • -t ext4 — монтирование файловой системы. Здесь ext4 следует заменить на необходимую ФС;
  • -a — монтирование всех разделов и носителей, указанных в fstab.

Теперь вы знакомы с одной из основных команд в Linux под названием mount и знаете, что она отвечает за подключение дисков. В следующем способе мы тоже будем задействовать эту утилиту, но в немного необычной и более сложной ситуации.

Способ 4: Монтирование окружения в режиме LiveCD

Особого внимания заслуживает метод монтирования окружения или отдельных разделов дисков в режиме загрузки с LiveCD. В большинстве случаев подобное подключение производится конкретно с теми носителями, где хранится основная операционная система, например, для дальнейшего сжатия томов или взаимодействия с файлами. Выглядит эта операция следующим образом:

    1. Загрузите компьютер с LiveCD версией дистрибутива. Более детально об этом читайте в официальной документации по приведенной далее ссылке.

Загрузка Linux с LiveCD

    1. Выберите вариант ознакомления с ОС, предварительно указав удобный язык интерфейса.

Запуск LiveCD монтирования диска через терминал в Linux

    1. Потребуется запустить «Терминал», поскольку отсюда все манипуляции производятся более удобно. Однако ничего не мешает вам задействовать те утилиты, о которых мы уже рассказывали выше. В этом режиме они так же работают корректно.

Запуск терминала в режиме LiveCD для монтирования диска в Linux

    1. Используйте команду sudo mount /dev/sda1 /mnt, чтобы смонтировать основной раздел. Наименование /dev/sda1 взято только в качестве примера, а по факту оно может быть другим.

Команда для монтирования основного раздела жесткого диска через LiveCD в Linux

    1. В некоторых случаях разделы с загрузчиком тоже придется смонтировать. Для этого используется команда sudo mount –bind /dev/ /mnt/dev/.

Команда для монтирования раздела с загрузчиком при работе с LiveCD Linux

    1. Следом идет строка sudo mount –bind /proc/ /mnt/proc/.

Вторая команда для монтирования раздела с загрузчиком при работе с LiveCD Linux

    1. Последняя команда имеет вид sudo mount –bind /sys/ /mnt/sys/.

Третья команда для монтирования раздела с загрузчиком при работе с LiveCD Linux

    1. По завершении можно перейти к окружению sudo chroot /mnt/.

Команда для подключения к смонтированному окружению через LiveCD Linux

Все действия будут осуществляться непосредственно через основную операционную систему, и можно приступить к работе с разделами или имеющимися там файлами.

В этой статье вы узнали о принципах монтирования дисков в Linux. После этого можно смело переходить к их использованию. На нашем сайте имеются отдельные темы, посвященные этому процессу. Предлагаем прочитать их, перейдя по указанным ниже ссылкам.

CentOS 7: Монтирование дисков. Утилита mount, umount.

1. Описание утилиты.

Mount — утилита командной строки. Применяется для монтирования файловых систем.

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

Например, вы хотите примонтировать флешку. Вы даете системе команду подключить ее в папку /run/media/имя_пользователя/UUID_флешки/. Система определяет файловую систему устройства, а затем, используя драйвера ядра подключает ее к указанной папке. Дальше вам остается работать с той папкой, как с любой другой. Больше ни о чем думать не нужно. Когда надумаете извлечь флешку, ее нужно отмонтировать.

2. Общий синтаксис.

Для монтирования в CentOS 7 используется команда mount.

Рассмотрим ее параметры:

# mount /файл_устройства /папка_назначения

Или расширенный вариант:

# mount опции -t файловая_система -o опции_монтирования /файл_устройства /папка_назначения

Опции задают различные дополнительные особенности работы утилиты. Опция -t необязательна, но она позволяет задать файловую систему, которая будет использована и иногда это очень полезно. С помощью опции -o вы можете задать различные параметры монтирования, например, монтировать только для чтения и так далее. Последних два параметра — это файл устройства, например, /dev/sda1 и папка назначения, например, /mnt.

Перед тем как перейти к рассмотрению примеров работы утилитой, давайте рассмотрим ее основные опции:

  • -V — вывести версию утилиты;
  • -h — вывести справку;
  • -v — подробный режим;
  • -a, –all — примонтировать все устройства, описанные в fstab;
  • -F, –fork — создавать отдельный экземпляр mount для каждого отдельного раздела;
  • -f, –fake — не выполнять никаких действий, а только посмотреть что собирается делать утилита;
  • -n, –no-mtab — не записывать данные о монтировании в /etc/mtab;
  • -l, –show-labels — добавить метку диска к точке монтирования;
  • -c — использовать только абсолютные пути;
  • -r, –read-only — монтировать раздел только для чтения;
  • -w, –rw — монтировать для чтения и записи;
  • -L, –label — монтировать раздел по метке;
  • -U, –uuid — монтировать раздел по UUID;
  • -T, –fstab — использовать альтернативный fstab;
  • -B, –bind — монтировать локальную папку;
  • -R, –rbind — перемонтировать локальную папку.

3. Монтирование разделов.

3.1. Простое монтирование.

Монтирование разделов с помощью mount выполняется очень просто. Фактически в большинстве случаев будет достаточно упрощенной версии команды. Например, смонтируем раздел /dev/sdb6 в папку /mnt:

# sudo mount /dev/sdb2 /mnt/

3.2. Монтирование с правами суперпользователя.

В большинстве случаев вы будете вынуждены выполнять команду mount с правами суперпользователя, если обратное не указано в fstab (опция монтирования users). Вы можете посмотреть информацию о процессе монтирования добавив опцию -v:

# sudo mount -v /dev/sdb2 /mnt/

3.3. Монтирование с указанием файловой системы.

Если нужно, вы можете указать файловую систему с помощью опции -t:

# sudo mount -v -t ext4 /dev/sdb2 /mnt

3.4. Монтирование только для чтения.

Если необходимо примонтировать файловую систему только для чтения, то вы можете использовать опцию -r или опцию монтирования -o, результат будет одинаковым:

# sudo mount -t ext4 -r /dev/sdb2 /mnt

# sudo mount -t ext4 -o ro /dev/sdb2 /mnt

3.5. Ограничения на выполнение программ.

Вы можете использовать и другие опции чтобы выполнить монтирование разделов, например, указать, что на этом разделе нельзя выполнять программы:

# sudo mount -t ext4 -o noexec /dev/sdb2 /mnt

Обратите внимание, что вы не можете использовать опции uid, gid, fmask для файловых систем ext. Они поддерживаются только в FAT, vFAT, exFAT.

3.6. Монтирование по UUID.

Вы можете использовать не только имена устройств чтобы выполнить монтирование диска в CentOS 7. Для этого можно применять UUID или метки, например, монтирование с помощью UUID:

# sudo mount –uuid=”b386d309-05c1-42c8-8364-8d37270b69e0″ /mnt

Посмотреть UUID для ваших разделов можно с помощью команды:

# sudu blkid

или так

# blkid /dev/sdb1

Также соответствие «классических» имен устройств и их UUID представлений можно посмотреть вот так:

# ls -l /dev/disk/by-uuid/

3.7. Монтирование по метке.

Точно так же вы можете использовать метки. Команда монтирования диска CentOS 7 будет выглядеть так:

# sudo mount –label=”home” /mnt/

3.8. Монтаж каталога к каталогу.

Вы можете примонтировать один каталог в другой, для этого используйте опцию –bind:

# sudo mount -v -R –rbind /mnt/ /media/

3.9. Монтирование файлов с файловой системой.

Возможно, не только монтирование разделов CentOS 7, но и монтирование файлов, если они содержат файловую систему, например, образов дисков.

Монтирование образа диска CentOS 7 работает точно так же:

# sudo mount ~/file.iso /mnt

4. Список смонтированного.

Посмотреть список всех примонтированных устройств можно просто выполнив mount без параметров:

# mount

5. Размонтирование разделов.

Когда вы хотите завершить работу с устройством, особенно с флешкой, его нужно размонтировать. Для этого существует утилита umount. В качестве параметров она принимает точку монтирования или устройство.

Например:

# sudo umount /mnt

Теперь ваше устройство не смонтировано, но иногда может возникнуть ошибка размонтирования.

Система сообщит, что устройство занято:

umount: /mnt: target is busy.

Проблему можно решить закрыв все программы, которые могут использовать любой файл в этой папке. Какие именно это программы вы можете узнать с помощью команды lsof:

# lsof -w /mnt

# lsof -w /dev/sdb6

Здесь вы видите всю необходимую информацию, чтобы понять что происходит и что с этим делать. Утилита вывела название программы, ее PID, и даже файл, с которым она работает. Вы можете завершить все программы, а потом снова повторить попытку или используйте опцию -l, файловая система будет отключена немедленно, несмотря на то, что она занята:

# sudo umount -l /mnt

6. Оригиналы источников информации.

  1. ru.wikipedia.org «mount».
  2. losst.ru «Монтирование диска в Linux».

Выводы

В этой статье мы рассмотрели как выполняется монтирование жестких дисков linux, а также разделов и даже образов. Вы знаете как правильно использовать опции mount и umount.


[spoiler title=”Источники”]

  • https://www.vseprolinux.ru/mount
  • https://ITProffi.ru/podklyuchenie-fajlovyh-sistem-komanda-mount-v-linux/
  • https://GitJournal.tech/montirovanie-diska-v-linux-komanda-mount/
  • https://itshaman.ru/articles/3/mount
  • https://lumpics.ru/mounting-disk-in-linux/
  • https://hamsterden.ru/mount-umount/
  • https://losst.ru/montirovanie-diska-v-linux


[/spoiler]


2020-12-22T10:34:30
Linux

Изучаем команды Linux: dd. Некоторые особенности использования системной утилиты dd и её модифицированных версий



























3/5 — (1 голос)

Некоторые особенности использования системной утилиты dd и её модифицированных версий. В UNIX системах есть одна очень древняя команда, которая называется dd. Она предназначена для того, чтобы что-то куда-то копировать побайтово. dd (dataset definition) — программа UNIX, предназначенная как для копирования, так и для конвертации файлов. Название унаследовано от оператора DD (Dataset Definition) из языка JCL.

Несколько слов о резервном копировании файлов

Бэкапы (от английского «Backup») – это метод создания запасной копии важной информации на компьютере либо сервере. Его можно проводить ручным способом или автоматическим в соответствии с регулярным расписанием.

Утилитой DD можно воспользоваться для ОС семейства Линукс, ее команды помогают с копированием файлов через определенные операнды. Это одна из наиболее давних утилит, ее бэкапы можно открыть разнообразным софтом. Версия под операционную систему Виндовс отличается меньшим функционалом, чем версия для Линукс. К примеру, в ней отсутствует поддержка конвертации файлоы и использования блочных устройств.

Что такое утилита dd?

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

Утилита dd является аналогом одноименной утилиты для Linux систем. Команда dd копирует файл, в соответствии с указанными операндами. Программа генерирует необработанные файлы, которые могут быть прочитаны многими другими программами. dd является самой старой утилитой для создания образов и не обладает некоторыми полезными опциями, но при этом все еще используется. Версия для Windows является урезанной по сравнению с родительской под Linux, например, не поддерживается конвертация данных и нельзя использовать блочные устройства.

Примеры использования dd

Если вы работали с командой dd в Linux, то у вас не возникнет сложностей при её использовании в операционной системе Windows.

Для того чтобы открыть страницу помощи перейдите в каталог с исполняемым файлом, откройте консоль PowerShell и выполните команду:

./dd.exe –list

Чтобы сделать запасную копию вашего жесткого диска используйте следующую команду:

./dd.exe if=<исходный_диск> of=<полное_имя_копии> bs=1440k

Пример создания образа диска f на диск e:

./dd.exe if=.f: of=e:tempdisk1.img bs=8M

Результат:

rawwrite dd for windows version 0.5. Written by John Newbigin <jn@it.swin.edu.au>This program is covered by the GPL. See copying.txt for details 7279+1 records in 7279+1 records out

  1. if=/dev/sda – копируем весь жесткий диск sda;
  2. of=/mnt/backup/sda.img – копируем в /mnt/backup/sda.img, где каталог /mnt/backup точка монтирования диска, на котором будет содержаться образ;
  3. bs=8M – задаем размер кэша жесткого диска для ускорения процедуры копирования (иначе данные будут сбрасываться малыми порциями по 512 байт).

Примечание: на целевом диске должно быть достаточно места, т.е. не менее того объема, который занимает исходный диск.

Чтобы сделать восстановление вашего жесткого диска из резервной копии используйте следующую команду:

./dd.exe if=<полное_имя_копии> of=<целевой_диск> bs=8M

Например:

./dd.exe if=e:tempdisk1.img of=.f: bs=8M

Результат:

rawwrite dd for windows version 0.5. Written by John Newbigin <jn@it.swin.edu.au>This program is covered by the GPL. See copying.txt for details 1279+1 records in 1279+1 records out

Создавать резервную копию очень удобно по настроенному расписанию, о том как настроить планировщик Windows читайте в нашей статье. Это позволит автоматизировать создание копий сервера или данных.

Примечание: В рамках нашего сервиса есть услуга резервного копирования серверов, копирование выполняется 1 раз в сутки на территориально удаленный дисковый массив, при этом вам не нужно самостоятельно выполнять настройки резервирования, а сохранность копии не зависит от работоспособности сервера.

</jn@it.swin.edu.au></jn@it.swin.edu.au>

Команда dd

Синтаксис утилиты достаточно необычен, но в то же время очень прост, после того как вы его запомните и привыкнете:

$ dd if=источник_копирования of=место_назначенияпараметры

С помощью параметра if вам нужно указать источник, откуда будут копироваться блоки, это может быть устройство, например, /dev/sda или файл – disk.img. Дальше, с помощью параметра of необходимо задать устройство или файл назначения. Другие параметры имеют такой же синтаксис, как if и of.

Теперь давайте рассмотрим дополнительные параметры:

  • bs – указывает сколько байт читать и записывать за один раз;
  • cbs – сколько байт нужно записывать за один раз;
  • count – скопировать указанное количество блоков, размер одного блока указывается в параметре bs;
  • conv – применить фильтры к потоку данных;
  • ibs – читать указанное количество байт за раз;
  • obs – записывать указанное количество байт за раз;
  • seek – пропустить указанное количество байт в начале устройства для чтения;
  • skip – пропустить указанное количество байт в начале устройства вывода;
  • status – указывает насколько подробным нужно сделать вывод;
  • iflag, oflag – позволяет задать дополнительные флаги работы для устройства ввода и вывода, основные из них: nocache, nofollow.

Это были все основные опции, которые вам могут понадобиться. Теперь перейдем ближе к практике и рассмотрим несколько примеров как пользоваться утилитой dd linux.

Почему dd?

Мы выбрали dd как первого соискателя в нашей серии, потому что это очень полезная утилита, имеющая, как вы увидите ниже, множество опций. Это делает ее практически швейцарским армейским ножом в мире Linux.

Как работает команда dd?

Сначала нужно понять как работает команда dd и что она делает. Фактически, это аналог утилиты копирования файлов cp только для блочных данных. Утилита просто переносит по одному блоку данных указанного размера с одного места в другое.

Поскольку в Linux все, в том числе, устройства, считается файлами, вы можете переносить устройства в файлы и наоборот.

С помощью различных опций утилиты можно повлиять на размер блока, а это, в свою очередь, уже влияет на скорость работы программы. Дальше мы рассмотрим основные опции утилиты и ее возможности.

Как загрузить утилиту dd

Скачиваем утилиту DD со специального сайта, ведь это стороннее программное обеспечение, широко доступное для пользователей.

В загруженном архиве будет несколько файлов, запустить утилиту позволит приложение dd.exe.

Синтаксис команды dd

У данной утилиты странный и слегка сложный синтаксис. Несмотря на это, он весьма прост. Пользоваться программой легко, вы быстро запомните алгоритм и привыкнете к нему.

dd if=[что копировать] of=[куда копировать] параметры

С использованием параметра «if» потребуется прописать что копировать (источник). В “of” можно написать файл или устройство, например флешку или HDD диск.

Основные параметры:

  • «bs» – количество байт, которые будут читаться и записываться за один раз.
  • «cbs» – число байт, записываемых за один раз.
  • «count» – число скопированных блоков. Размер блока прописывается в опции «bs».
  • «ibs» – чтение определенного числа байт за 1 раз.
  • «obs» – записывание определенного числа байт за 1 раз.
  • «seek» – пропуск определенного числа байт в самом начале устройства во время чтения.
  • «skip» – пропуск определенного числа байт в самом начале при выводе.
  • «status» – подробность вывода.
  • «iflag», «oflag» – создание дополнительных флагов, которые нужны для ввода или вывода.
  • –help – показывает справку.
  • –version – показывает информацию о версии утилиты.

Выше описаны наиболее популярные функции, которые могут потребоваться вам при использовании программы dd Linux.

Примеры команды linux dd

Утилита чаще всего применяется для формирования образов DVD- и CD-дисков. Для их сохранения в виде образа iso существуют определенные команды. Чтобы программа не реагировала на ошибки, можно запустить фильтр noerror. Далее создается образ, который в последующем сохраняется на диск.

Чтобы сделать образ, узнаем разметку диска, с помощью dh.

df -h

Сделаем образ раздела /home, файловая разметка /dev/sda6 в каталог /root/home.iso. В качестве аргумента укажем “noerror” – не выдавать ошибки. Также ограничим  максимальный размер файла на 4096 байт.

dd if=/dev/sda6 of=/root/home.iso bs=4096 conv=noerror

Таким образом делаются образы жестких дисков, флешек, оптических приводов.

Как видно из примера выше, в каталоге /root появился файл home.iso. В дальнейшем его можно развернуть. Он позволит восстановить испорченную в ходе использования систему, в нашем случае файлы каталога home.

Весьма полезный параметр – «bs». Он в значительной мере влияет на скорость работы самой программы. Этот аргумент дает возможность установить размер блока во время передачи информации. Предварительно задается цифровое значение, где указывается один из модификаторов.

Как было сказано выше,  dd Linux позволяет записать информацию на диск или в определенный раздел именно в двоичном виде. В этом случае записываются как нули, так и единицы. Для очистки диска достаточно наполнить его нулями.

Создадим образ диска. Пусть /dev/cdrom1 это наш оптический привод, cdrom.

# dd if=/dev/cdrom1 of=/home/samba/disk/obraz.iso

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

Как пользоваться dd?

Обычные пользователи используют команду dd чаще всего для создания образов дисков DVD или CD.

Например, чтобы сохранить образ диска в файл можно использовать такую команду:

$ dd if=/dev/sda of=~/disk.img

В вашей домашней папке будет создан файл с именем disk1.img, который в будущем можно будет развернуть и восстановить испорченную систему.

Чтобы записать образ на жесткий диск или раздел достаточно поменять местами адреса устройств:

$ dd if=/dev/sda of=~/disk.img bs=5M

Команда dd linux

Следующий параметр — это count. С помощью него можно указать сколько блоков необходимо скопировать.

Например, мы можем создать файл размером 512 мегабайт, заполнив его нулями из /dev/zero или случайными цифрами из /dev/random:

$ sudo dd if=/dev/sda of=mbr.img bs=1b count=1

Команда dd linux

Использование параметров, управляющих размерами и количеством блоков

Важными параметрами команды dd являются bs (block size) и count. Первый упрвляет размером блока, второй — количеством блоков, подвергающихся обработке. Например, можно выполнить следующую команду

# dd if=/dev/zero of=/dev/null bs=1M count=32768 32768+0 записей считано 32768+0 записей написано скопировано 34359738368 байт (34 GB), 2,35194 c, 14,6 GB/c

дающую представленеие о скорости передачи данных “процессор-память”.

Другое, более полезное применение параметров изменения размера и количества блоков — создание образа MBR (Master Boot Record):

dd if=/dev/sda of=/home/user/archive/MBR.image bs=512 count=1

С помощью dd можно также при необходимости тестировать и анализировать производительность жёсткого диска при выполнении операций последовательного чтения/записи с блоками заданного размера, например, с блокми по 1024 байта

dd if=/dev/zero bs=1024 count=1000000 of=/home/user/tmp/1Gb.file dd if=/home/user/tmp/1Gb.file bs=64k | dd of=/dev/null

Параметры пропуска блоков

Когда необходимо игнорировать некоторые данные из входного файла и не переносить их в выходной файл, на помощь приходит параметр skip, который позволяет пропустить заданное количество блоков перед началом копирования (даже на устройствах, на которых невозможна операция seek</strong>; при этом “пропускаемые” блоки считываются, но никак не используются).

Например, информацию в BIOS, располагающууюся по адресам с C:0000 по F:FFFF можно просмотреть следующим образом:

dd if=/dev/mem bs=1k skip=768 count=256 2>/dev/null | strings -n 8

А вот пример преобразования файла образа диска, созданного программой Nero (Nero Image File) в обычный ISO-формат (команда просто удаляет 300-килобайтный заголовок при записи нового образа):

dd if=nero_image.nrg bs=1k skip=300 of=image.iso

Параметр seek позволяет пропускать заданное количество блоков в выходном файле. Это может оказаться полезным при “склейке” большого файла, который может быть считан лишь фрагментарно (то есть, не всё содержимое можно получить за одну операцию чтения). Хороший пример подобного применения параметра seek приведён в википедии. Иногда необходимо зараезервировать свободное место в начале выходного файла или имитировать “большой” файл. В этом случае также помогает seek:

dd if=small.file seek=100 of=pseudo_big.file

Параметр conv в данной статье не рассматривается в подробностях, а упомянут он здесь лишь для того, чтобы отметить один из его аргументов, noerror — продолжать после ошибок чтения. Дело в том, что при указании conv=noerror при наличии слишком большого количества ошибок во входных файлах (на устройствах) возникают затруднения и даже потенциальные опасности для оборудования при выполнении команды dd.

Утилита dd_rescue

Программа dd_rescue выполняет те же задачи, что и dd, но делает это более эффективно и с меньшим риском. В общем виде её выполнение выглядит так:

dd_rescue /dev/sda1 local_sda1.img

Следует обратить внимание на то, что здесь не используется формат параметров dd, то есть части “if=” и “of=” не нужны. По умолчанию dd_rescue копирует стандартный ввод в стандартный вывод, то есть, так же, как и dd, является фильтром и может участвовать в конвейерах команд:

dd_rescue /dev/sda1 – | bzip2 > /dir/local_sda1.img.bz2

Ещё один пример, с передачей файла образа раздела диска по сети:

dd_rescue /dev/sda1 – | ssh user@remote.host “cat – > /remote/destination/my_sda1.img”

В целом операции и действия похожи на dd. Но главным отличием dd_rescue от dd является то, что эта утилита не прекращает работу при возникновении ошибок и не пытается выполнять чтение (или запись) с ошибкой до бесконечности, а обрабатывает возникающие ошибки наилучшим возможным в конкретной ситуации образом. Здесь можно определить обнуление “плохого” блока после определённого количества попыток чтения/записи, фиксацию номеров “плохих” блоков в log-файле и запись либо отказ от записи блоков, обнулённых при ошибках. Такой подход делает программу весьма полезной при извлечении данных с устройств, при чтении которых возникает слишком много ошибок ввода/вывода.

Описание всех ключей можно получить, выполнив команду dd_rescue -h.

Чтение и запись файлов и устройств

В предыдущем примере мы вводили текст в stdin (стандартный поток ввода). Однако, всегда можно использовать входные и выходные файлы. Чтобы указать имена входного и выходного файла, используются опции if и of, соответственно. Например, если вам нужно перевести в верхний регистр текст из файла file1 и записать его в файл file2, можно выполнить следующую команду:

dd if=file1 of=file2 conv=ucase

Командой dd также можно создавать файлы различных объемов, например для тестов. Следующая команда создаст файл объемом 1 ГБ заполненный случайными данными

dd if=/dev/urandom of=bigfile bs=1M count=1000

Или файл заполненный нулями

dd if=/dev/null of=bigfile bs=1M count=1000

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

Например, следующая команда полностью копирует диск /dev/sda на диск /dev/sdb:

dd if=/dev/sda of=/dev/sdb bs=4096 conv=noerror,sync

Аргумент noerror опции conv позволяет программе продолжать копирование даже при наличии ошибок, а sync задаёт использование синхронизированного ввода/вывода. Размер блока должен быть кратным 1 Кб (1024 байта), а выходной диск равен по объему входному или больше.

Аналогично можно создать образ CD или DVD, вместе с загрузочным сектором:

dd if=/dev/cdrom of=/mycd.iso

Опция -o loop команды mount позволяет смонтировать файл как обычное устройство. Так можно подключить созданный образ:

mount -o loop /mycd.iso /mnt/cd

Сокращение вывода в stderr

Можно ограничить объём информации, выводимой в поток stderr, при помощи опции status. Например, если требуется сообщать только об ошибках, нужно указать эту опцию с аргументом none:

dd if=file1 of=file3 status=none

Другие возможные значения — noxfer, исключающее вывод конечной статистики, и progress, исключающее вывод текущей статистики.

Действия с выходными файлами

Чтобы команда работала только в том случае, если выходного файла ещё не существует, в качестве аргумента опции conv можно указать значение excl.

dd if=file1 of=file3 conv=excl

По умолчанию dd перезаписывает выходной файл, если он уже существует. Если требуется обновление с записью в конец файла, укажите значение append для опции oflag и значение notrunc для опции conv, например:

dd if=file1 of=file2 oflag=append conv=notrunc

При необходимости можно также отключить создание выходного файла, если такого файла не существует. Для этого используется аргумент nocreat опции conv:

dd if=file1 of=file10 oflag=append conv=nocreat

Изменение регистра текста

Наиболее простой пример, на котором можно рассмотреть работу команды — скопировать текст с заменой регистра символов (большие буквы вместо маленьких или наоборот).

Допустим, у вас есть несколько строк текста, написанного в нижнем регистре, а вам нужно перевести его в верхний регистр. Для этого можно воспользоваться опцией conv с аргументом ucase:

dd conv=ucase

Здесь мы видим команду и введённый текст. Чтобы показать dd, что ввод текста завершён, мы воспользовались комбинацией клавиш Ctrl+D, и команда вывела следующий результат:

Введённый текст был переведён в верхний регистр, последние три строки — это статистика операции. Аналогичным образом можно перевести текст в нижний регистр.

Пропуск части входных данных

При необходимости можно задать команде пропустить несколько начальных байтов входных данных. Это осуществляется при помощи опции skip с целочисленным аргументом. Например, если значение этого аргумента N, то dd пропустит N блоков размера ibs. Это ещё одна опция команды, которая определяет число байтов, считываемых за раз (по умолчанию 512).

Если вам требуется пропустить первые 4 байта входного файла, нужно задать ibs равным 4, а аргумент skip равным 1. Таким образом при чтении файла команда пропустит один блок размером 4 байта.

dd if=file1 of=file2 ibs=4 skip=1

Сравним файлы командой grep

grep -v -f file1 file2

Видно, что часть текста при считывании файла file1 были пропущены, поэтому в файле file2 их нет.

Утилита dcfldd

Программа dcfldd является дальнейшим развитием клона dd с расширенной функциональностью и множеством дополнительных параметров, краткое описание которых можно получить с помощью команды dcfldd –help. В дополнение к типовым операциям dd утилита dcfldd может выполнять следующие действия: хэширование копируемых данных “на лету”, разделять вывод данных в несколько различных файлов, осуществлять проверку соответствия создаваемого образа оргинальному устройству “бит-в-бит”. Кроме того, dcfldd выводит индикатор прогресса выполняемой работы, фиксирует свои действия в log-файле и, разумеется, может быть составной частью конвейера, как и положено члену семейства dd.

Типичный пример использования программы dcfldd на первый взгляд может показаться несколько ошеломляющим, но при проходе по каждому параметру всё становится гораздо проще:

dcfldd if=/dev/sdb4 hash=md5,sha256 hashwindow=10G md5log=md5.txt sha256log=sha256.txt hashconv=after bs=512 conv=noerror,sync split=10G splitformat=aa of=sdb4image.dd

Здесь считываются 10 Гб данных с устройства /dev/sdb4, и эти данные записываются в файл sdb4image.dd.aa. При этом также вычисляется MD5-хэш и sha256-хэш для копируемого фрагмента данных. Затем считываются следующие 10 Гб данных и записываются в файл sdb4image.dd.ab и т.д. Вычисленные хэши сохраняются в файлах md5.txt и sha256.txt соответственно. Само вычисление хэш-сумм выполняется после всех прочих преобразований. Размеры блока хэширования и блока, записываемого в выходные файлы (различные), совпадают. Размер блока копирования 512 байтов. После ошибок чтения выполнение команды не прерывается, по умолчанию dcfldd записывает в такие блоки нули.

Заключение

Утилита dd и её более усовершенствованные версии представляют собой весьма удобный инструмент для решения определённого круга задач, к которым можно отнести копирование и клонирование файлов и разделов устройств, формирование образов дисков и разделов, создание резервных копий, просмотр обычных и бинарных файлов, а также тестирование и анализ производительности устройств.


[spoiler title=”Источники”]

  • https://serverspace.by/support/help/dd-utility-for-windows-backup/
  • https://1cloud.ru/help/windows/rezervnoe-kopirovanie-windows-utilita-dd
  • https://losst.ru/komanda-dd-linux
  • http://rus-linux.net/MyLDP/consol/dd.html
  • https://j4web.ru/linux/komanda-dd.html
  • https://www.vseprolinux.ru/dd-linux
  • https://www.ibm.com/developerworks/ru/library/os-dd_util/index.html
  • https://www.ibm.com/developerworks/ru/library/os-dd_util/
  • https://ITProffi.ru/komanda-dd-v-linux/


[/spoiler]


2020-12-22T10:34:30
Linux

Изучаем команды Linux: команда sed Linux



























3.4/5 — (5 голосов)

Команда sed – это потоковый редактор текста, работающий по принципу замены. Его можно использовать для поиска, вставки, замены и удаления фрагментов. Утилиту sed называют потоковым текстовым редактором. В интерактивных текстовых редакторах, наподобие nano, с текстами работают, используя клавиатуру, редактируя файлы, добавляя, удаляя или изменяя тексты. Sed позволяет редактировать потоки данных, основываясь на заданных разработчиком наборах правил.

Команда sed в Linux

Сначала рассмотрим синтаксис команды:

$ sedопции-e командыфайл

А вот её основные опции:

  • -n, –quiet – не выводить содержимое буфера шаблона в конце каждой итерации;
  • -e – команды, которые надо выполнить для редактирования;
  • -f – прочитать команды редактирования из файла;
  • -i – сделать резервную копию файла перед редактированием;
  • -l – указать свою длину строки;
  • -r – включить поддержку расширенного синтаксиса регулярных выражений;
  • -s – если передано несколько файлов, рассматривать их как отдельные потоки, а не как один длинный.

Установка

Здесь не нужно много рассказывать. Скорее все sed у вас уже установлен, так как он используется различными системными скриптами, а также пользователями Linux, которые хотят повысить эффективность своей работы. Вы можете узнать, какая версия sed у вас установлена, с помощью команды:

$ sed –version

В моей системе эта команда показывает, что у меня установлен GNU sed 4.2.1 плюс дает ссылку на домашнюю страницу программы и другие полезные сведения. Пакет называется “sed” независимо от дистрибутива, кроме Gentoo, где он присутствует неявно.

Концепции

Перед тем, как идти дальше, мы считаем важным акцентировать внимание на том, что делает “sed”, так как словосочетание “потоковый редактор” мало что говорит о его назначении. sed принимает на входе текст, выполняет заданные операции над каждой строкой (если не задано другое) и выводит модифицированный текст. Указанными операциями могут быть добавление, вставка, удаление или замена. Это не так просто, как выглядит: предупреждаю, что имеется большое количество опций и их комбинаций, которые могут сделать команду sed очень трудной для понимания. Поэтому мы рекомендуем вам изучить основы регулярных выражений, чтобы понимать, как это работает. Перед тем, как приступить к руководству, мы хотели бы поблагодарить Eric Pement и других за вдохновление и за то, что он сделал для всех, кто хочет изучать и использовать sed.

Как работает sed

Теперь нужно понять как работает команда sed. У утилиты есть два буфера, это активный буфер шаблона и дополнительный буфер. Оба изначально пусты. Программа выполняет заданные условия для каждой строки в переданном ей файле.

sed читает одну строку, удаляет из неё все завершающие символы и символы новой строки и помещает её в буфер шаблона. Затем выполняются переданные в параметрах команды, с каждой командой может быть связан адрес, это своего рода условие и команда выполняется только если подходит условие.

Когда всё команды будут выполнены и не указана опция -n, содержимое буфера шаблона выводится в стандартный поток вывода перед этим добавляется обратно символ перевода строки. если он был удален. Затем запускается новая итерация цикла для следующей строки.

Если не используются специальные команды, например, D, то после завершения одной итерации цикла содержимое буфера шаблона удаляется. Однако содержимое предыдущей строки хранится в дополнительном буфере и его можно использовать.

Адреса sed

Каждой команде можно передать адрес, который будет указывать на строки, для которых она будет выполнена:

  • номер – позволяет указать номер строки, в которой надо выполнять команду;
  • первая~шаг – команда будет выполняется для указанной в первой части сроки, а затем для всех с указанным шагом;
  • $ – последняя строка в файле;
  • /регулярное_выражение/ – любая строка, которая подходит по регулярному выражению. Модификатор l указывает, что регулярное выражение должно быть не чувствительным к регистру;
  • номер, номер – начиная от строки из первой части и заканчивая строкой из второй части;
  • номер, /регулярное_выражение/ – начиная от сроки из первой части и до сроки, которая будет соответствовать регулярному выражению;
  • номер, +количество – начиная от номера строки указанного в первой части и еще плюс количество строк после него;
  • номер, ~число – начиная от строки номер и до строки номер которой будет кратный числу.

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

Синтаксис

Синтаксис данной утилиты не отличается сложностью. Он представлен в виде:

sed [параметры]  [команды] (файл)

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

  • «-n» – дает возможность не выводить содержимое, присутствующее в буфере шаблона после каждой итерации.
  • «-e» – позволяет выполнить команды, которые необходимы для редактирования текста.
  • «-f» – дает возможность прочесть команды, которые были использованы при изменении файла.
  • «-l». Опция позволяет указать требуемую длину строки.
  • «-r». Опция применяется для включения поддержки синтаксиса расширенного типа, распространяющегося на активно используемые выражения.
  • «-i». Функция предназначена для создания копии файла (в резерве) перед тем, как он будет отредактирован.
  • «-s». Опция позволяет изучить несколько файлов единовременно. Они будут просмотрены не как длинные потоки, а как отдельные.

Чтобы выполнить несколько действий, используется аргумент “-e”.

sed -e [команды] (файл)

Первоначально кажется, что данная утилита очень сложная. На самом деле это не так, ей сможет пользоваться даже новичок в сфере программирования.

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

Первоначально программа «sed» изучает одну строку. Из нее удаляются все завершающие данные, а также символы, присутствующие в новой строке. Обрабатываемая стока помещается в главный буфер.

Далее выполняются команды, которые были переданы пользователем в параметрах. За каждой определенной командой закрепляется адрес. Он используется в качестве своеобразного условия. Команда пройдет лишь в том случае, если данное условие будет соблюдено.

После выполнения всех предписанных команд, содержимое буфера шаблона попадает в классический поток вывода. Это происходит в том случае, если предварительно не была указана функция «-n», которая ограничивает вывод содержимого.

Когда символ перевода изначально был удален, он добавляется обратно. Только после этого запускается следующая интерпретация, подразумевающая обработку новой строки.

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

Особенности адресов, предающихся утилите «sed»

Все команды получают свой адрес. Именно он указывает на строки, для которых выполняется команда:

  • «номер». В данном случае прописывается номер определенной строки, где в последующем будет выполняться команда.
  • «первая~шаг». Здесь команда выполняется для изначальной части строки, а далее – для всех остальных. В обязательном порядке указывается шаг.
  • «$». Обрабатывается последняя строка, которая относится к выбранному вами файлу.
  • «/часто используемое_выражение/». Здесь используется любая строка, подходящая по регулярному выражению. Оно не должно зависеть от особенностей регистра.
  • «номер, номер». Обработка начинается с начала первой строки, а заканчивается концом второй строки.
  • «номер,/регулярное_выражение/». Обработка начинается с первоначальной строки, заканчивается в той, которая соответствует информации в часто используемых фразах.
  • «номер+количество». Обработка начинается с верхней строки, длится до той поры, пока не будет исчерпано предварительно указанное число строк.
  • «номер~число». Обработка начинается со строки с определенным номеров. Она заканчивается той строкой, которая кратна определенному числовому обозначению.

Когда пользователь не желает задавать определенный адрес для программы «sed», она распространяется на все строки в файле. Если передается один адрес, команда выполняется до той строки, которая расположена по указанному адресу.

Есть возможность передавать диапазон адресов. Информация разделяется запятыми, а команда осуществляется для тех адресов, которые находятся в требуемом диапазоне.

Использование специальных символов:

Можно использовать спецсимволы:

^ – начало строки

$ – конец строки

. – обозначение одного символа

Полный набор не ограничен только этими тремя. Sed прекрасно понимает регулярные выражения (regular expressions).

Следующая команда заменит root на Admin в тех строках, которые начинаются с user:

sed ‘/^user/s/root/Admin/g’ имя_файла

Следующая команда заменит root на Admin в тех строках, которые заканчиваются словом data:

sed ‘/data$/s/root/Admin/g’ имя_файла

В том, случае если Вам нужно использовать какой-либо спецсимвол в sed ( $, ^, /, пробел, точка, ‘, и т.д.) его нужно экранировать с помощью .

С помощью следующей конструкции слово root с пробелом после него будет заменено на Admin с двоеточием:

sed ‘s/root /Admin:/g’ имя_файла




В случае использования символа(pipe) в качестве разделителя спецсимволы экранировать не нужно, но при этом регулярные выражения работать не будут

sed ‘s|root |Admin:|g’ имя_файла

Регулярные выражения

Убрать все цыфры из вывода:

sed ‘s/[0-9][0-9]//g’

Продублировать отсеченное значение:

sed ‘s/root/& &/g’

Попробуйте выполнить:

echo`123 abc` | sed ‘s/[0-9][0-9]*/&-&/’

Регулярное выражение [0-9]* определят 0 или больше цыфр.

Регулярное выражение [0-9][0-9]* определят 1 или больше цыфр.

Если Вам нужно использовать первое слово из строки текста – обзначьте его экранированой цыфрой:

sed ‘s/([a-z]*).*/1/’

Проверьте сами:

echo’abcd qwer zxc 123’| sed ‘s/([a-z]*).*/1/’

Для того что бы поменять местами первое и второе слово – воспользуйтесь следующей конструкцией:

sed ‘s/([a-z]*) ([a-z]*)/2 1/’

Пробел в левой части выражения может быть заменен на любой другой разделитель.

Для теста:

echo’abcd qwer zxc 123’| sed -r’s/([a-z]+) ([a-z]+)/2 1/’

и

echo’abcd_qwer_zxc_123’| sed -r’s/([a-z]+)_([a-z]+)/2**_**1/’echo’abcd_qwer_zxc_123’| sed -r’s/([a-z]+)**_**([a-z]+)/2 1/’

Замена текства между двумя словами:

sed -ure’s/**word1**.+?**word2**/**word1** замена **word2**/g’-i файл

Использование переменных в выражениях sed

При написании bash скриптов мы используем переменные. Иногда возникает необходимость использовать эти переменные в выражениях sed.

Самый простой подход – использование двойных кавычек для обертки выражения:

sed ‘s/$var1/$var2/g’

Двойные кавычки не сработают, есть в $var1 или $var2 присутвствуют спецсимволы. Лучше всего – исключать переменные из обертки:

sed ‘s/”$var1”/”$var2”/g’

Основные команды Sed

Для того чтобы применить SED достаточно ввести в командную строку

echo ice | sed s/ice/fire/

Результат:

fire

Замена слова в файле

Обычно SED применяют к файлам, например к логам или конфигам.

Предположим, что у нас есть файл input.txt следующего содержания

Here is a StringHere is an IntegerHere is a Float

Мы хотим заменить слово Here на There

sed ‘s/Here/There/’ input.txt

Результат будет выведен в консоль:

There is a String

There is an Integer

There is a Float

Если нужно не вывести в консоль а изменить содержание файла – используем опцию -i

sed -i ‘s/Here/There/’ input.txt

В этом случае перепишется исходный файл input.txt

Рассмотрим пример посложнее. Файл input.txt теперь выглядит так:

Here is an Apple. Here is a Pen. Here is an ApplePenInteger is HereHere is a FloatHere is a Pen. Here is a Pineapple. Here is a PineapplePen

sed ‘s/Here/There/’ input.txt

Как Вы сейчас увидите, замена произойдёт только по одному разу в строке

There is an Apple. Here is a Pen. Here is an ApplePen

Integer is There

There is a Float

There is a Pen. Here is a Pineapple. Here is a PineapplePen

Чтобы заменить все слова нужна опция g

sed ‘s/Here/There/g’ input.txt

There is an Apple. There is a Pen. There is an ApplePen

Integer is There

There is a Float

There is a Pen. There is a Pineapple. There is a PineapplePen

Замена слова в файле и вывод результата в другой файл

Та же замена, но с выводом в новый текстовый файл, который мы назовём output:

sed ‘s/Here/There/’ input.txt > output.txt

Замена слова в нескольких файлах одновременно

Если нужно обработать сразу несколько файлов: например файл 1.txt с содержанием

First File: Here

И файл 2.txt с содержанием

Second File: Here

Это можно сделать используя *.txt

sed ‘s/Here/There/’ *.txt > output.txt

На выходе файл output.txt будет выглядеть так

First File: ThereSecond File: There

Отбросить всё, что левее определённого слова

Предположим, что у нас есть файл input.txt следующего содержания

Here is a String it has a NameHere is an Integer it has a NameHere is a Float it has a Name

Мы хотим отбросить всё, что находится левее слова it, включая слово it, и записать в файл.

sed ‘s/^.*it//’ input.txt > output.txt

^ означает, что мы стартуем с начала строки Результат:

 has a Name

has a Name

has a Name

Для доступности объясню синтаксис сравнив две команды. Посмотрите внимательно, когда мы заменяем слово Here на There.

There находится между двумя слэшами. Раскрашу их для наглядности в зелёный и красный.

sed ‘s/Here/There/

А когда мы хотим удалить что-то, мы сначала описываем, что мы хотим удалить. Например, всё от начала строки до слова it.

Теперь в правой части условия, где раньше была величина на замену, мы ничего не пишем, т.е. заменяем на пустое место. Надеюсь, логика понятна.

sed ‘s/^.*it//‘ > output.txt

Отбросить всё, что правее определённого слова

Предположим, что у нас есть файл input.txt следующего содержания

Here is a String / it has a NameHere is an Integer / it has a NameHere is a Float / it has a Name

Мы хотим отбросить всё, что находится правее слова is, включая слово is, и записать в файл.

sed ‘s/is.*//’ > output.txt

Результат:

HereHereHere

Экранирование символов в sed

Специальные символы экранируются с помощью

Предположим, что у нас есть файл input.txt следующего содержания

Here is a String / it has a NameHere is an Integer / it has a NameHere is a Float it / has a Name

Мы хотим отбросить всё, что находится левее /a, включая /a, и записать в файл.

sed ‘s/^.*/a//’ > output.txt

В результате получим ошибку

-e expression #1, char 15: unknown option to `s’

Чтобы команда заработала нужно добавить перед /

sed ‘s/^.*/a//’ > output.txt

Результат:

Here is a StringHere is an IntegerHere is a Float

Два условия одновременно в Sed

Предположим, что у нас есть файл input.txt следующего содержания

Here is a String /b it has a NameHere is an Integer /b it has a NameHere is a Float /b it has a Name

Мы хотим отбросить всё, что находится левее /b, включая /b, и всё, что правее has.

Таким образом, в каждой строчке должно остаться только слово it.

Нужно учесть необходимость экранирования специального символа / а также мы хотим направить вывод в файл.

sed ‘s/^.*/b// s/has.*//’ input.txt > output.txt

Результат:

ititit

Удаление переходов на новую строку

sed ‘:a;N;$!ba;s/n//g’ file

Удалить всё после определённой строки

Допустим Вы хотите удалить все строки после третьей

sed 3q input.txt > output.txt

Удаление текста

Можно легко удалить текст, который мы выводили в предыдущем примере, заменив команду “p” на команду “d”. Команда «-n» нам больше не нужна, потому что при использовании команды удаления утилита выводит все, что не удалено. Это позволяет нам видеть, что происходит. Изменим последнюю команду из предыдущего раздела так, чтобы она удаляла все нечетные строки, начиная с первой. В результате мы должны получить все строки, которые не были выведены в прошлый раз.

sed ‘1~2d’ BSD All rights reserved. Redistribution and use in source and binary forms, with or without are met: notice, this list of conditions and the following disclaimer. notice, this list of conditions and the following disclaimer in the 3. Neither the name of the University nor the names of its contributors without specific prior written permission. . . . . . .

При этом исходный файл не меняется. Результаты редактирования просто выводятся на экран. Если результат нужно сохранить, можно перенаправить стандартный вывод в файл:

sed ‘1~2d’ BSD > everyother.txt

Открыв этот файл командой cat, мы увидим тот же результат, который был на экране после выполнения предыдущей команды. По умолчанию sed не редактирует исходный файл в целях безопасности. Это можно изменить при помощи опции «-i», которая означает редактирование на месте. Исходный файл будет изменен. Давайте попробуем отредактировать только что созданный нами файл «everyother.txt». Снова удалим все нечетные строки:

sed -i ‘1~2d’ everyother.txt

При помощи cat можно убедиться, что файл был отредактирован.

Опция “-i” может быть опасной, но утилита предоставляет возможность создания резервной копии перед редактированием. Для этого сразу после опции “-i” укажите расширение резервной копии “.bak”:

sed -i.bak ‘1~2d’ everyother.txt

Будет создан файл резервной копии с расширением “bak”, а затем выполнено редактирование исходного файла.

Замена текста

Чаще всего sed используется для замены текста. Редактор позволяет осуществлять поиск текста по шаблону при помощи регулярных выражений. А затем заменять найденный текст. В простейшем варианте можно заменить одно слово на другое, используя следующий синтаксис:

‘s/старое_слово/новое_слово/’

Параметр «s» – это команда замены. Три слэша (/) нужны для разделения различных текстовых полей. Если вам удобно, вы можете использовать для этого другие символы. Например, если нам нужно изменить имя веб-сайта, удобнее использовать другой разделитель, так как URL содержат слэши. Воспользуемся командой echo для передачи примера:

echo “http://www.example.com/index.html” | sed ‘s_com/index_org/home_’ http://www.example.org/home.html

Здесь секция «com/index» заменяется на «org/home». В качестве разделителя используется нижнее подчеркивание «_». Не забудьте про последний разделитель, иначе sed выдаст ошибку.

echo “http://www.example.com/index.html” | sed ‘s_com/index_org/home’ sed: -e expression #1, char 22: unterminated `s’ command

Создадим файл для отработки замен:

echo “this is the song that never ends yes, it goes on and on, my friend some people started singing it not knowing what it was and they’ll continue singing it forever just because…” > annoying.txt

Теперь заменим «on» на «forward»

sed ‘s/on/forward/’ annoying.txt this is the sforwardg that never ends yes, it goes forward and on, my friend some people started singing it not knowing what it was and they’ll cforwardtinue singing it forever just because…

Стоит обратить внимание на ряд моментов. Во-первых, мы заменяем шаблоны, а не слова. “on” в слове “song” было заменено на “forward”. Во-вторых, второе “on” в строке 2 заменено не было. Это произошло потому, что по умолчанию команда “s” обрабатывает первое совпадение в строке. А затем переходит к следующей строке. Для замены каждого “on”, а не только первого в строке, можно указать команде замены флаг “g” после шаблонов:

sed ‘s/on/forward/g’ annoying.txt this is the sforwardg that never ends yes, it goes forward and forward, my friend some people started singing it not knowing what it was and they’ll cforwardtinue singing it forever just because…

Теперь были заменены все “on”. Чтобы заменить только вторые “on” в каждой строке, вместо “g” нужно указать “2”:

sed ‘s/on/forward/2’ annoying.txt this is the song that never ends yes, it goes on and forward, my friend some people started singing it not knowing what it was and they’ll continue singing it forever just because…

Если нам нужно вывести только те строки, где выполнялась замена, для отмены автоматического вывода можно снова воспользоваться опцией «-n». Затем мы можем передать флаг “p” для вывода строк, в которых производились замены.

sed -n ‘s/on/forward/2p’ annoying.text yes, it goes on and forward, my friend

Пример показывает, что флаги в конце команды можно комбинировать. Чтобы игнорировать регистр, нужно указать флаг “i”.

sed ‘s/SINGING/saying/i’ annoying.txt this is the song that never ends yes, it goes on and on, my friend some people started saying it not knowing what it was and they’ll continue saying it forever just because…

Если нужно заменить текст во всех файлах директории то можно воспользоваться командой

grep ‘текс’ -P -R -I -l  * | xargs sed -i ‘s/текст_который_нужно_искать/текст/g’

Примеры использования sed





























































































Синтаксис командыОписание
sed ‘s/Nick/John/g’ report.txtЗаменяет каждое вхождение Nick на John в файле report.txt
sed ‘s/Nick|nick/John/g’ report.txtЗаменяет каждое вхождение Nick или nick на John.
sed ‘s/^/ /’ file.txt > file_new.txtДобавляет 8 пробелов слева от текста для улучшения качества печати.
sed -n ‘/Of course/,/attention you pay/p’ myfileВыводит все абзацы, начинающиеся с “Of course” и заканчивающиеся на “attention you pay”.
sed -n 12,18p file.txtВыводит только строки 12-18 файла file.txt
sed 12,18d file.txtВыводит весь файл file.txt за исключением строк с 12 по 18
sed G file.txtВставляет пустую строку после каждой строки в file.txt
sed -f script.sed file.txtЗаписывает все команды в script.sed и выполняет их.
sed ‘5!s/ham/cheese/’ file.txtЗаменяет ham на cheese в file.txt за исключением 5-й строки
sed ‘$d’ file.txtУдаляет последнюю строку
sed -n ‘/[0-9]{3}/p’ file.txtПечатает только строки с тремя последовательными цифрами
sed ‘/boom/s/aaa/bb/’ file.txtЕсли найден “boom”, заменить aaa на bb
sed ’17,/disk/d’ file.txtУдаляет все строки, начиная с 17-й, до “disk”. Если строк с “disk” несколько, удаляет до первой из них.
echo ONE TWO | sed “s/one/unos/I”Заменяет one на unos независимо от регистра, поэтому будет напечатано “unos TWO”
sed ‘G;G’ file.txtВставляет две пустые строки после каждой строки в file.txt
sed ‘s/.$//’ file.txtСпособ замены dos2unix :). В общем случае удаляет последний символ в каждой строке.
sed ‘s/^[ t]*//’ file.txtУдаляет все пробелы/табы перед каждой строкой в file.txt
sed ‘s/[ t]*$//’ file.txtУдаляет все пробелы/табы в конце каждой строки в file.txt
sed ‘s/^[ t]*//;s/[ t]*$//’ file.txtУдаляет все пробелы/табы в начале и в конце каждой строки в file.txt
sed ‘s/foo/bar/’ file.txtЗаменяет foo на bar только в первом вхождении в строке.
sed ‘s/foo/bar/4’ file.txtЗаменяет foo на bar только в четвертом вхождении в строке.
sed ‘s/foo/bar/g’ file.txtЗаменяет foo на bar для всех вхождений в строке.
sed ‘/baz/s/foo/bar/g’ file.txtЗаменить foo на bar только если строка содержит baz.
sed ‘/./,/^$/!d’ file.txtСжать все последовательные пустые строки до одной. Пустой строки сверху не остается.
sed ‘/^$/N;/n$/D’ file.txtСжать все последовательные пустые строки до одной, но оставить верхнюю пустую строку.
sed ‘/./,$!d’ file.txtУдалить все начальные пустые строки
sed -e :a -e ‘/^n*$/{$d;N;};/n$/ba’ file.txtУдалить все замыкающие пустые строки
sed -e :a -e ‘/$/N; s/n/ /; ta’ file.txtЕсли строка заканчивается обратным сплешем, соединить ее со следующей (полезно для скриптов оболочки)
sed -n ‘/regex/,+5p’ file.txtВыводит 5 строк после строки содержащей regex
sed ‘1~3d’ file.txtУдалить каждую третью строку, начиная с первой.
sed -n ‘2~5p’ file.txtПечатать каждую пятую строку, начиная со второй.
sed ‘s/[Nn]ick/John/g’ report.txtДругой способ записи некоторых приведенных выше примеров. Вы можете предложить свой?
sed -n ‘/RE/{p;q;}’ file.txtПечатает строку с первым соответствием RE (регулярного выражения)
sed ‘0,/RE/{//d;}’ file.txtУдаляет строку с первым соответствием
sed ‘0,/RE/s//to_that/’ file.txtИзменяет только первое соответствие
sed ‘s/^[^,]*,/9999,/’ file.csvЗаменяет на 9999 все значения в первой колонке CSV-файла
s/^ *(.*[^ ]) *$/|1|/; s/” *, */”|/g; : loop s/| *([^”,|][^,|]*) *, */|1|/g; s/| *, */||/g; t loop s/ *|/|/g; s/| */|/g; s/^|(.*)|$/1/;Скрипт sed для конвертирования CSV-файла в файл с вертикальной чертой в качестве разделителя (работает только с некоторыми типами CSV, со встроенными кавычками и запятыми).
sed ‘:a;s/(^|[^0-9.])([0-9]+)([0-9]{3})/12,3/g;ta’ file.txtМеняет формат чисел в file.txt с 1234.56 на 1.234.56
sed -r “s/<(reg|exp)[a-z]+/U&/g”Переводит любое слово, начинающееся с reg или exp в верхний регистр.
sed ‘1,20 s/Johnson/White/g’ file.txtПроизводит замену Johnson на White только в строках 1 – 20.
sed ‘1,20 !s/Johnson/White/g’ file.txtПредыдущий пример наоборот (заменяет везде, кроме строк 1-20)
sed ‘/from/,/until/ { s//magenta/g; s//cyan/g; }’ file.txtЗаменяет только между “from” и “until”. Если областей “from”-“until” несколько, заменяет в каждой из них.
sed ‘/ENDNOTES:/,$ { s/Schaff/Herzog/g; s/Kraft/Ebbing/g; }’ file.txtЗаменяет только со слова “ENDNOTES:” и до EOF
sed ‘/./{H;$!d;};x;/regex/!d’ file.txtПечатает абзац только если он содержит regex
sed -e ‘/./{H;$!d;}’ -e ‘x;/RE1/!d;/RE2/!d;/RE3/!d’ file.txtПечатает абзацы только если они содержат RE1, RE2 и RE3. Порядок RE1, RE2 и RE3 не имеет значения.
sed ‘s/14″/fourteen inches/g’ file.txtТак вы сможете использовать двойные кавычки
sed ‘s//some/UNIX/path//a/new/path/g’ file.txtРабота с путями Unix
sed ‘s/[a-g]//g’ file.txtУдаляет все символы, начиная с a и заканчивая g из файла file.txt
sed ‘s/(.*)foo/1bar/’ file.txtЗаменяет только последнее в строке соответствие foo на bar
sed ‘1!G;h;$!d’Замена команды tac
sed ‘/n/!G;s/(.)(.*n)/&21/;//D;s/.//’Замена команды rev
sed 10q file.txtЗамена команды head
sed -e :a -e ‘$q;N;11,$D;ba’ file.txtЗамена команды tail
sed ‘$!N; /^(.*)n1$/!P; D’ file.txtЗамена команды uniq
sed ‘$!N; s/^(.*)n1$/1/;t; D’ file.txtОбратная команда (что эквивалентно uniq -d)
sed ‘$!N;$!D’ file.txtЭквивалент tail -n 2
sed -n ‘$p’ file.txt… tail -n 1 (или tail -1)
sed ‘/regexp/!d’ file.txtЭквивалент grep
sed -n ‘/regexp/{g;1!p;};h’ file.txtПечатает строку, находящуюся перед первым соответствием регулярному выражению, но не включающую само соответствие
sed -n ‘/regexp/{n;p;}’ file.txtПечатает строку, находящуюся после первого соответствия регулярному выражению, но не включающую само соответствие
sed ‘/pattern/d’ file.txtУдаляет строки, соответствующие шаблону pattern
sed ‘/./!d’ file.txtУдаляет все пустые строки из файла
sed ‘/^$/N;/n$/N;//D’ file.txtСжимает все последовательные пустые строки до двух пустых. Одинарные пустые строки не изменяются.
sed -n ‘/^$/{p;h;};/./{x;/./p;}’ file.txtУдаляет последнюю строку каждого абзаца
sed ‘/^$/q’Получает заголовок письма. Другими словами – удаляет все после первой пустой строки.
sed ‘1,/^$/d’Получает тело письма. Другими словами – удаляет все до первой пустой строки.
sed ‘/^Subject: */!d; s///;q’Получает тему письма
sed ‘s/^/> /’Цитирует сообщение, вставляя “> ” перед каждой строкой
sed ‘s/^> //’Обратная команда (убирает цитирование из сообщения)
sed -e :a -e ‘s/<[^>]*>//g;/Удаляет HTML-теги
sed ‘/./{H;$!d;};x;s/n/={NL}=/g’ file.txt | sort | sed ‘1s/={NL}=//;s/={NL}=/n/g’Сортирует абзацы в file.txt в алфавитном порядке
sed ‘s@/usr/bin@&/local@g’ path.txtЗаменяет /usr/bin на /usr/bin/local в path.txt
sed ‘s@^.*$@<&>>>@g’ path.txtПопробуйте и увидите 🙂
sed ‘s/(/[^:]*).*/1/g’ path.txtПри условии, что path.txt содержит $PATH, выводит только первый путь в каждой строке
sed ‘s/([^:]*).*/1/’ /etc/passwdЗамена awk – показывает только пользователей из файла passwd
echo “Welcome To The Geek Stuff” | sed ‘s/(b[A-Z])/(1)/g’Понятно без объяснений – (W)elcome (T)o (T)he (G)eek (S)tuff
sed ‘/./{H;$!d;};x;s/n/={NL}=/g’ file.txt | sed ‘/END$/s/hills/mountains/g’ | sed ‘1s/={NL}=//;s/={NL}=/n/g’Заменяет “hills” на “mountains”, но только в блоках текста, начинающихся с пустой строки и заканчивающихся строкой с тремя символами “END”, включительно.
sed -e ‘/^#/d’ /etc/services | moreПоказывает файл services без закомментированных строк
sed ‘$s@([^:]*):([^:]*):([^:]*)@3:2:1:@g’ path.txtМеняет порядок первых трех элементов в последней строке файла path.txt на обратный
sed ‘/regex/{x;p;x;}’ file.txtВставляет новую строку выше каждой строки, соответствующей регулярному выражению
sed ‘/AAA/!d; /BBB/!d; /CCC/!d’ file.txtИщет строки содержащие AAA, BBB и CCC в любом порядке
sed ‘/AAA.*BBB.*CCC/!d’ file.txtИщет строки содержащие AAA, BBB и CCC в заданном порядке
sed -n ‘/^.{65}/p’ file.txtПечатает строки длиной 65 символов и более
sed -n ‘/^.{65}/!p’ file.txtПечатает строки длиной 65 символов и менее
sed ‘/regex/G’ file.txtВставляет пустую строку под каждой строкой, содержащей regex
sed ‘/regex/{x;p;x;G;}’ file.txtВставляет пустую строку над и под каждой строкой, содержащей regex
sed = file.txt | sed ‘N;s/n/t/’Нумерует строки в file.txt
sed -e :a -e ‘s/^.{1,78}$/ &/;ta’ file.txtВыровнять текст по правому краю
sed -e :a -e ‘s/^.{1,77}$/ &/;ta’ -e ‘s/( *)1/1/’ file.txtВыровнять текст по центру

В окружении UNIX: конвертируем новые строки DOS (CR/LF) в формат Unix.

Предполагаем, что все строки оканчиваются на CR/LF

sed ‘s/.$//’

В bash/tcsh, нажмите Ctrl-V затем Ctrl-M

sed ‘s/^M$//’

Работает на ssed, gsed 3.02.80 или выше

sed ‘s/x0D$//’

В окружении UNIX: конвертируем новые строки Unix (LF) в формат DOS.

Командная строка под ksh

sed “s/$/`echo -e r`/”

Командная строка под bash

sed ‘s/$’”/`echo r`/”

Командная строка под zsh

sed “s/$/`echo r`/”

gsed 3.02.80 или выше

sed ‘s/$/r/’

В окружении DOS: конвертируем новые строки Unix (LF) в формат DOS.

Метод 1

sed “s/$//”

Метод 2

sed -n p

В окружении DOS: конвертировать DOS переводы строк (CR/LF) в формат Unix.

Может быть только сделано с UnxUtils sed, версии 4.0.7 или выше. Версию UnxUtils можно узнать пользовательским свичем “–text”, который появляется когда вы используете свич “–help”. В других случаях изменение перевода строк DOS в перевод строк Unix не может быть выполнено в окружении DOS. Используйте вместо этого “tr”.

UnxUtils sed v4.0.7 или выше

sed “s/r//” infile >outfile

GNU tr версия 1.22 или выше

tr -d r outfile

Удалить пустоту в начале (пробелы, табуляции) от передней части каждой строки выравнивает весь текст по левому краю

sed ‘s/^[ t]*//’

Удаление пустоты (пробелы, табуляции) в конце каждой строки

Удаление пустоты как в начале, так и в конце каждой строки

sed ‘s/^[ t]*//;s/[ t]*$//’

Вставка 5 пробелов в начале каждой строки (сделать отступ страницы)

sed ‘s/^/ /’

Выравнять весь текст заподлицо справа на 79-ом столбце по ширине

sed -e :a -e ‘s/^.{1,78}$/ &/;ta’ # установить в 78 плюс 1 пробел

Центрировать весь текст в середине на 79-ом столбце по ширине

В первом методе пробелы в начале строки имеют значение, и в конце строки добавляются пробелы.

sed -e :a -e ‘s/^.{1,77}$/ & /;ta’

Во втором методе пробелы из начала строки отбрасываются в центрируемой строке, и в конце строки пробелы не добавляются.

sed -e :a -e ‘s/^.{1,77}$/ &/;ta’ -e ‘s/( *)1/1/’

Подстановка (поиск и замена “foo” на “bar” в каждой строке

Заменить только первое вхождение в строке

sed ‘s/foo/bar/’

Заменить только четвёртое вхождение в строке

sed ‘s/foo/bar/4’

Заменить ВСЕ вхождения в строке

sed ‘s/foo/bar/g’

Заменяет следующее-на-последнее вхождение (the next-to-last case)

sed ‘s/(.*)foo(.*foo)/1bar2/’

Поменять только последний случай

sed ‘s/(.*)foo/1bar/’

Поменять “foo” на “bar” ТОЛЬКО для строк, которые содержат “baz”

sed ‘/baz/s/foo/bar/g’

Заменить “foo” на “bar” КРОМЕ строк, которые содержат “baz”

sed ‘/baz/!s/foo/bar/g’

Поменять “scarlet” или “ruby” или “puce” на “red”

Большинство sed

sed ‘s/scarlet/red/g;s/ruby/red/g;s/puce/red/g’

Только GNU sed

gsed ‘s/scarlet|ruby|puce/red/g’

Обратный порядок строк (эмулирует “tac”) баг/фича в HHsed v1.5 приводит к тому, что пустые строки удаляются

Метод первый

sed ‘1!G;h;$!d’

Метод второй

sed -n ‘1!G;h;$p’

Обратный порядок всех символов в строке (эмулирует “rev”)

sed ‘/n/!G;s/(.)(.*n)/&21/;//D;s/.//’

Соединить пары строк (наподобие “paste”)

sed ‘$!N;s/n/ /’

Если строка заканчивается на обратный слэш, прикрепить к ней следующую строку

sed -e :a -e ‘/$/N; s/n//; ta’

Если строка начинается со знака равно, прикрепить её к предыдущей строке и заменить “=” на пробел

sed -e :a -e ‘$!N;s/n=/ /;ta’ -e ‘P;D’

Добавить запятые в цифровую строку, замена “1234567” на “1,234,567”

GNU sed

gsed ‘:a;s/B[0-9]{3}>/,&/;ta’

Другие seds

sed -e :a -e ‘s/(.*[0-9])([0-9]{3})/1,2/;ta’

Добавить запятые к номерам, в том числе содержащим десятичные точки и знаки минус (GNU sed)

gsed -r ‘:a;s/(^|[^0-9.])([0-9]+)([0-9]{3})/12,3/g;ta’

Добавить пустую строку каждые 5 строк (после каждых 5, 10, 15, 20 и т. д. строк)

Только GNU sed

gsed ‘0~5G’

Другие sed

sed ‘n;n;n;n;G;’

Выборочная печать конкретных строк:

Напечатать первые 10 строк файла (эмулирует поведение “head”)

sed 10q

Напечатать первую строку файла (эмулирует “head -1″)

sed q

Напечатать последние 10 строк файла (эмулирует “tail”)

sed -e :a -e ‘$q;N;11,$D;ba’

Напечатать последние 2 строки файла (эмулирует “tail -2″)

sed ‘$!N;$!D’

Напечатать последнюю строку файла (эмулирует “tail -1″)

Первый метод

sed ‘$!d’

Второй метод

sed -n ‘$p’

Напечатать строки файла начиная с последней

Для файла в одну строку напечатать пустую строку

sed -e ‘$!{h;d;}’ -e x

Для файла в одну строку, напечатать эту строку:

sed -e ‘1{$q;}’ -e ‘$!{h;d;}’ -e x

Для файла в одну строку ничего не печатать

sed -e ‘1{$d;}’ -e ‘$!{h;d;}’ -e x

Печатать только строки, которые соответствуют регулярному выражению (эмулирует “grep”)

Метод 1

sed -n ‘/regexp/p’

Метод 2

sed ‘/regexp/!d’

Печатать только строки, которые НЕ соответствуют регулярному выражению (эмулирует “grep -v”)

Метод 1, соответствует вышеприведённому

sed -n ‘/regexp/!p’

Метод 2, упрощённый синтаксис

sed ‘/regexp/d’

Печатать строку, которая идёт перед строкой, удовлетворяющей регулярному выражению, но не строку, содержащую регулярное выражение

sed -n ‘/regexp/{g;1!p;};h’

Печатать строку, которая идёт сразу после регулярного выражения, но не строку, содержащую регулярное выражение

sed -n ‘/regexp/{n;p;}’

Печатать по одной строке перед и после регулярного выражения, с номером строки, показывающей где встретилось регулярное выражение (наподобии “grep -A1 -B1″)

sed -n -e ‘/regexp/{=;x;1!p;g;$!N;p;D;}’ -e h

grep для AAA и BBB и CCC (в любом порядке)

sed ‘/AAA/!d; /BBB/!d; /CCC/!d’

grep для AAA и BBB и CCC (в таком порядке)

sed ‘/AAA.*BBB.*CCC/!d’

grep для AAA или BBB или CCC (эмулирует “egrep”)

Большинство sed

sed -e ‘/AAA/b’ -e ‘/BBB/b’ -e ‘/CCC/b’ -e d

Только GNU sed

gsed ‘/AAA|BBB|CCC/!d’

Напечатать параграф, если он содержит AAA (параграфы разделяют пустые строки) HHsed v1.5 должен вставить ‘G;’ после ‘x;’ в следующих трёх скриптах ниже

sed -e ‘/./{H;$!d;}’ -e ‘x;/AAA/!d;’

Напечатать параграф, если он содержит AAA и BBB и CCC (в любом порядке)

sed -e ‘/./{H;$!d;}’ -e ‘x;/AAA/!d;/BBB/!d;/CCC/!d’

Напечатать параграф, если он содержит AAA или BBB или CCC

sed -e ‘/./{H;$!d;}’ -e ‘x;/AAA/b’ -e ‘/BBB/b’ -e ‘/CCC/b’ -e d

Только GNU sed

gsed ‘/./{H;$!d;};x;/AAA|BBB|CCC/b;d’

Напечатать только строки длинной 65 символов или длиннее

sed -n ‘/^.{65}/p’

Напечатать только строки, которые короче 65 символов

Метод 1, соответствует вышеприведённому

sed -n ‘/^.{65}/!p’

Метод 2, упрощённый синтаксис

sed ‘/^.{65}/d’

Напечатать секцию файла от регулярного выражения до конца файла

sed -n ‘/regexp/,$p’

Напечатать секцию файла, включающую номера строк (строки 8-12, включая и 8 и 12)

Метод 1

sed -n ‘8,12p’

Метод 2

sed ‘8,12!d’

Напечатать строку с номером 52

Способ 1

sed -n ’52p’

Способ 2

sed ’52!d’

Способ 3, эффективен на больших файлах

sed ’52q;d’

Начиная со строки 3, печатать каждую седьмую строку

Только GNU sed

gsed -n ‘3~7p’

Другие sed

sed -n ‘3,${p;n;n;n;n;n;n;}’

Напечатать раздел файла между двумя регулярными выражениями (включая)

sed -n ‘/Iowa/,/Montana/p’ # чувствительно к регистру

Выборочное удаление конкретных строк:

Напечатать весь файл КРОМЕ секции между двумя регулярными выражениями 2

sed ‘/Iowa/,/Montana/d’

Удалить дубликаты последовательных строк файла (эмулирует “uniq”). Первая строка из двух дублирующих сохраняется, остальное удаляется.

sed ‘$!N; /^(.*)n1$/!P; D’

Удалить дубликаты непоследовательных строк из файла. Остерегайтесь переполнения буфера или используйте GNU sed.

sed -n ‘G; s/n/&&/; /^([ -~]*n).*n1/d; s/n//; h; P’

Удалить все строки, кроме дублирующих строк (эмулирует “uniq -d”).

sed ‘$!N; s/^(.*)n1$/1/; t; D’

Удалить первые 10 строк файла

sed ‘1,10d’

Удалить последние строки файла

sed ‘$d’

Удалить последние 2 строки файла

sed ‘N;$!P;$!D;$d’

Удалить последние 10 строк файла

Способ 1

sed -e :a -e ‘$d;N;2,10ba’ -e ‘P;D’

Способ 2

sed -n -e :a -e ‘1,10!{P;N;D;};N;ba’

Удалить каждую восьмую строку файла

Только GNU sed

gsed ‘0~8d’

Другие sed

sed ‘n;n;n;n;n;n;n;d;’

Удалить строки, содержащие паттерн

sed ‘/pattern/d’

Удалить ВСЕ пустые строки из файла (то же самое что и “grep ‘.’ “)

Способ 1

sed ‘/^$/d’

Способ 2

sed ‘/./!d’

Удалить все ПОСЛЕДОВАТЕЛЬНЫЕ пустые строки из файла, кроме первой, также удаляет все пустые строки в начале и в конце файла (эмулирует “cat -s”)

Способ 1, позволяет 0 пустых строк вверху, 1 в EOF

sed ‘/./,/^$/!d’

Способ 2, позволяет 1 пустую строку вверху, 0 в EOF

sed ‘/^$/N;/n$/D’

Удалить все ПОСЛЕДОВАТЕЛЬНЫЕ пустые строки из файла кроме первых двух:

sed ‘/^$/N;/n$/N;//D’

Удалить все первые пустые строки в файле

sed ‘/./,$!d’

Удалить все конечные пустые строки в файле

sed -e :a -e ‘/^n*$/{$d;N;ba’ -e ‘}’ # works on all seds

Удалить последнюю строку каждого параграфа

sed -n ‘/^$/{p;h;};/./{x;/./p;}’

Заключение

Мы рассмотрели основы использования sed. Теперь вы можете быстро редактировать текстовые документы при помощи соответствующих команд sed.


[spoiler title=”Источники”]

  • https://losst.ru/komanda-sed-linux
  • http://rus-linux.net/MyLDP/consol/sed.html
  • https://www.vseprolinux.ru/linux-sed
  • https://www.tech-notes.net/sed-examples/
  • https://www.AndreyOlegovich.ru/IT/sed/
  • https://ITProffi.ru/komanda-sed-v-linux-vyvod-teksta-udalenie-zamena/
  • https://ZaLinux.ru/?p=266


[/spoiler]


2020-12-22T10:34:30
Linux