Администратор Linux - сценарии оболочки

Введение в Bash Shell

Как и разновидности GNU Linux, оболочки бывают разных видов и различаются по совместимости. Оболочка по умолчанию в CentOS известна как Bash или Bourne Again Shell. Оболочка Bash - это современная модифицированная версия Bourne Shell, разработанная Стивеном Борном. Bash был прямой заменой исходной оболочки Thompson Shell в операционной системе Unix, разработанной в Bell Labs Кеном Томпсоном и Деннисом Ричи (Стивен Борн также работал в Bell Labs)

У каждого есть любимый снаряд, и у каждого есть свои сильные стороны и трудности. Но по большей части Bash будет оболочкой по умолчанию для всех дистрибутивов Linux и наиболее общедоступной. Имея опыт, каждый захочет изучить и использовать оболочку, которая лучше всего подходит для него. Однако в то же время каждый захочет освоить оболочку Bash.

Другие оболочки Linux включают: Tcsh, Csh, Ksh, Zsh и Fish.

Развитие навыков использования любой оболочки Linux на экспертном уровне чрезвычайно важно для администратора CentOS. Как мы упоминали ранее, в отличие от Windows, Linux по своей сути является операционной системой командной строки. Оболочка - это просто пользовательский интерфейс, который позволяет администратору (или пользователю) отдавать команды операционной системе. Если бы системный администратор Linux был пилотом авиакомпании, использование оболочки было бы похоже на снятие самолета с автопилота и взятие ручного управления для более маневренного полета.

Оболочка Linux, такая как Bash, известна в компьютерных науках как Command Line Interpreter. В Microsoft Windows также есть два интерпретатора командной строки: DOS (не путать с исходной операционной системой DOS) и PowerShell.

Большинство современных оболочек, таких как Bash, предоставляют constructsпозволяя более сложным сценариям оболочки автоматизировать как общие, так и сложные задачи.

Конструкции включают -

  • Управление потоком скриптов (ifthen и else)
  • Логические операции сравнения (больше, меньше, равенство)
  • Loops
  • Variables
  • Параметры, определяющие работу (аналогично переключателям с командами)

Использование сценария оболочки и языка сценариев

Часто, думая о выполнении задачи, администраторы задают себе вопрос: следует ли мне использовать сценарий оболочки или язык сценариев, такой как Perl, Ruby или Python?

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

Оболочка

Shell позволяет использовать такие команды Linux, как sed , grep , tee , cat и все другие утилиты командной строки в операционной системе Linux. Фактически, практически любая утилита командной строки Linux может быть написана в вашей оболочке.

Отличным примером использования оболочки может быть быстрый скрипт для проверки списка хостов на предмет разрешения DNS.

Наш простой сценарий Bash для проверки имен DNS -

#!/bin/bash 
for name in $(cat $1);
   do 
      host $name.$2 | grep "has address" 
   done 
exit

небольшой список слов для проверки разрешения DNS -

dns 
www 
test 
dev 
mail 
rdp 
remote

Вывод для домена google.com -

[rdc@centos ~]$  ./dns-check.sh dns-names.txt google.com
-doing dns
dns.google.com has address 172.217.6.46
-doing www
www.google.com has address 172.217.6.36
-doing test
-doing dev
-doing mail
googlemail.l.google.com has address 172.217.6.37
-doing rdp
-doing remote

[rdc@centos ~]$

Используя простые команды Linux в нашей оболочке, мы смогли создать простой 5-строчный скрипт для аудита DNS-имен из списка слов. Это заняло бы значительное время в Perl, Python или Ruby даже при использовании хорошо реализованной библиотеки DNS.

Язык сценариев

Язык сценариев даст больше контроля за пределами оболочки. В приведенном выше сценарии Bash используется оболочка для команды хоста Linux . Что, если бы мы хотели сделать больше и сделать наше собственное приложение, например host, для взаимодействия вне оболочки? Здесь мы будем использовать язык сценариев.

Кроме того, благодаря хорошо поддерживаемому языку сценариев мы знаем, что наши действия по большей части будут работать в разных системах. Python 3.5, например, будет работать в любой другой системе, на которой работает Python 3.5 с такими же установленными библиотеками. Это не так, если мы хотим запустить наш сценарий BASH как в Linux, так и в HP-UX.

Иногда границы между языком сценариев и мощной оболочкой могут быть размыты. Задачи администрирования CentOS Linux можно автоматизировать с помощью Python, Perl или Ruby. Это действительно обычное дело. Кроме того, богатые разработчики сценариев оболочки создали простой, но в остальном функциональный демон веб-сервера в Bash.

Имея опыт работы с языками сценариев и автоматизации задач в оболочках, администратор CentOS сможет быстро определить, с чего начать, когда необходимо решить проблему. Довольно часто проект запускается с помощью сценария оболочки. Затем переходите к скриптовому (или скомпилированному) языку по мере усложнения проекта.

Кроме того, для разных частей проекта можно использовать как язык сценариев, так и сценарий оболочки. Примером может служить Perl-скрипт для очистки веб-сайта. Затем используйте сценарий оболочки для анализа и форматирования с помощью sed , awk и egrep . Наконец, используйте сценарий PHP для вставки форматированных данных в базу данных MySQL с помощью веб-интерфейса.

Имея некоторую теорию оболочек, давайте начнем с основных строительных блоков для автоматизации задач из оболочки Bash в CentOS.

Вход, выход и перенаправление

Обработка stdout для другой команды -

[rdc@centos ~]$ cat ~/output.txt | wc -l 
6039 
[rdc@centos ~]$

Выше мы прошли cat'sstoud в туалет для обработки с трубой характером. Затем wc обработал вывод cat , распечатав счетчик строк файла output.txt на терминал. Подумайте трубы характера , как «труба» , проходящей вывод из одной команды, должны быть обработаны следующей команды.

Ниже приведены ключевые концепции, которые следует помнить при работе с перенаправлением команд.

номер Дескриптор файла символ
0 стандартный ввод <
1 стандартный вывод >
2 стандартная ошибка
добавить стандартный вывод >>
назначить перенаправление &
конвейер из стандартного вывода в стандартный ввод |

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

  • стандартный ввод <0
  • стандартный вывод> 1
  • стандартная ошибка 2

Посмотрим, как это работает -

[rdc@centos ~]$ lsof -ap $BASHPID -d 0,1,2 
 COMMAND   PID   USER    **FD**   TYPE DEVICE   SIZE/OFF   NODE      NAME 
 bash    13684    rdc    **0u**   CHR  136,0      0t0     3      /dev/pts/0 
 bash    13684    rdc    **1u**   CHR  136,0      0t0     3      /dev/pts/0 
 bash    13684    rdc    **2u**   CHR  136,0      0t0     3      /dev/pts/0
 
[rdc@centos ~]$

/ dev / pts / 0 - это наш псевдотерминал. CentOS Linux смотрит на это и думает о нашем открытом терминальном приложении как о реальном терминале с клавиатурой и дисплеем, подключенными через последовательный интерфейс. Однако, как гипервизор абстрагирует оборудование до операционной системы, / dev / pts абстрагирует наш терминал от приложений.

Из приведенной выше команды lsof мы можем видеть подFDстолбец, что все три файловых дескриптора установлены на наш виртуальный терминал (0,1,2). Теперь мы можем отправлять команды, видеть вывод команды, а также любые ошибки, связанные с командой.

Ниже приведены примеры для STDIN и STDOUT -

STDOUT

[root@centosLocal centos]# echo "I am coming from Standard output or STDOUT." >
output.txt && cat output.txt
I am coming from Standard output or STDOUT. 
[root@centosLocal centos]#

Также можно отправлять как stdout, так и stderr в отдельные файлы -

bash-3.2# find / -name passwd 1> good.txt 2> err.txt
bash-3.2# cat good.txt
/etc/pam.d/passwd
/etc/passwd
bash-3.2# cat err.txt 
find: /dev/fd/3: Not a directory
find: /dev/fd/4: Not a directory
bash-3.2#

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

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

Одно замечание при передаче STDOUT в текстовый файл - это различия между >> и >. Двойной ">>" будет добавляться к файлу, в то время как форма единственного числа будет стирать файл и записывать новое содержимое (поэтому все предыдущие данные будут потеряны).

STDIN

[root@centosLocal centos]# cat < stdin.txt
Hello,
I am being read form Standard input, STDIN.

[root@centosLocal centos]#

В приведенной выше команде текстовый файл stdin.txt был перенаправлен на команду cat, которая отобразила свое содержимое в STDOUT .

Символ трубы "|"

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

Теперь давайте "перенаправим" стандартный вывод cat другой команде -

[root@centosLocal centos]# cat output.txt | wc -l
2
[root@centosLocal centos]#

Выше, wc выполняет вычисления на выходе из cat, который был передан из трубы. Команда pipe особенно полезна при фильтрации вывода grep или egrep -

[root@centosLocal centos]# egrep "^[0-9]{4}$" /usr/dicts/nums | wc -l  
9000 
[root@centosLocal centos]#

В приведенной выше команде мы передали в wc каждое 4-значное число из текстового файла, содержащего все числа из 65535, пропущенные через фильтр egrep .

Перенаправление вывода с помощью &

Вывод можно перенаправить с помощью &персонаж. Если мы хотим направить вывод как STDOUT, так и STDERR в один и тот же файл, это можно сделать следующим образом:

[root@centosLocal centos]# find / -name passwd > out.txt 2>&1
[root@centosLocal centos]# cat out.txt  
find: /dev/fd/3: Not a directory 
find: /dev/fd/4: Not a directory 
/etc/passwd

[root@centosLocal centos]#

Перенаправление с помощью &символ работает так: сначала вывод перенаправляется в out.txt . Во-вторых, STDERR или файловый дескриптор 2 переназначается в то же место, что и STDOUT, в данном случае out.txt .

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

Несмотря на свою мощь, перенаправление может усложнить новым администраторам CentOS. Практика, исследования и случайные вопросы на форуме Linux (например, Stack Overflow Linux) помогут найти передовые решения.

Конструкции оболочки Bash

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

  • Variables
  • Loops
  • Conditionals
  • Контроль цикла
  • Чтение и запись в файлы
  • Основные математические операции

Подсказки по устранению неполадок BASH

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

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

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