Команды консоли в Linux
Данное руководство описывает работу в командной строке Linux и оболочке "bash". Оно предназначено для тех, кто никогда ранее не использовал командную строку в Linux/Unix. Люди, которые уже имеют опыт работы в оболочке Unix, могут найти его для себя слишком простым.
В связи с популярностью ОС Microsoft Windows и большим количеством её бывших пользователей, открывших для себя мир Linux, я обеспечил сравнение описываемого материала с эквивалентными возможностями и терминологией, принятыми в приглашениях на ввод команд в Windows и MS-DOS. Сравнение введено лишь в качестве дополнительной справочной информации.
Т.к. это учебное пособие задумывалось как подготовительное, оно умышленно не является всеобъемлющим. Некоторые команды, например, объясняются на уровне, достаточном лишь для необходимой глубины понимания сути их работы и применения, а не для раскрытия их полных потенциальных возможностей.
При написании руководства я полагал, что пользователь уже знаком с такими понятиями, как файлы, каталоги, имена файлов и.т.д.
Введение
После установки Linux Вы получили в распоряжение прекрасный графический интерфейс и редко, если вообще должны, использовать т.н. режим командной строки (другое название: приглашение командной оболочки). Приглашение командной оболочки - это значок в начале командной строки, символизирующий о том, что оболочка готова принимать Ваши команды. Обычно этот значок имеет вид '%' или '$'. В Вашей системе он может выглядеть по другому.
Простой и скромный терминал в Linux является чрезвычайно мощным повседневным рабочим инструментом, а не средством, используемым лишь в крайнем случае. Несмотря на то, что в данный момент у Вас нет необходимости использовать терминал, он несложен в изучении, а знать принципы его работы очень полезно. К счастью, ОС Linux является многопользовательской и безопасной, и Вы можете создать учётную запись нового пользователя для улучшения своих практических навыков, а затем экспериментировать без риска что-либо испортить.
В этом документе мы пошагово рассмотрим большинство общих задач. Надеюсь, что после прочтения материала Вы будете чувствовать себя уверенней при работе с терминалом. Это пригодится в случае обработки документов, требующих работы с терминалом для ввода определённых команд.
Предварительные замечания
Как уже отмечалось выше, для экспериментов лучше всего создать учётную запись нового пользователя. Работая в Linux, обычный пользователь не может нарушить работу системы, он может лишь удалить свои личные файлы. Создав учётную запись нового пользователя, Вы получите новое "поле" для своих действий, и сделанные Вами возможные ошибки не приведут к потере непосредственно Ваших данных.
Единственно чего Вы никогда не должны делать (до тер пор, пока не знаете, что делаете) - это работать в режиме администратора (root). Такой пользователь наделён правами удалять или изменять все файлы на компьютере, что, в данном случае, сопряжено с ненужным риском.
Для начала воспользуйтесь своим излюбленным инструментом для создания учётной записи нового пользователя. Все параметры оставьте без изменений, убедитесь только, что параметр "оболочки" - "/bin/bash". Я назвал свою новую учётную запись "sandbox", но Вы можете назвать её по другому. Т.к. различные дистрибутивы Linux снабжаются различными средствами создания учётных записей новых пользователей, выберите наиболее подходящее для Вас. В качестве примера приведу "Менеджер пользователей" в KDE и инструментарий LinuxConf.
Этот рисунок демонстрирует использование "Менеджера пользователей" в KDE для создания учётной записи пользователя "sandbox". Можно также использовать и другую программу управления учётными записями пользователей.Другой вариант заключается в создании учётной записи нового пользователя с помощью командной строки. Для того, чтобы это сделать, нужно ввести следующие команды:
su
Password: (введите здесь пароль администратора)
useradd -m -s /bin/bash sandbox
passwd sandbox
Changing password for user sandbox
New UNIX password: (введите здесь новый пароль)
Retype new UNIX password: (введите здесь новый пароль)
passwd: all authentication tokens updated successfullyПосле того, как Вы создали учётную запись нового пользователя, Вы можете выйти из системы, затем снова войти, используя только что созданную запись, чтобы быть уверенным в безопасности ввода команд.
Оболочка Bash
Оболочка - это программа, обрабатывающая команды, вводимые пользователем, или содержащиеся в файле. Этот файл называется основным сценарием, и является простой интерпретируемой программой. Аналогами в среде WindowsTM являются "командный процессор" "COMMAND.COM" или "CMD.EXE" и командные файлы - ".BAT файлы".
Несмотря на то, что Linux располагает рядом различных оболочек, наиболее популярной является bash. Поэтому дальнейшее описание будет посвящено именно этой оболочке, (хотя большинство команд применимы для всех оболочек). Некоторые другие сохранены по той причине, что многие люди просто привыкли к ним и не хотят что - либо менять, или потому, что они нацелены на специализированный контингент пользователей.
Полезно знать: Linux, как и все Unix - системы, использует множество акронимов для названий своих программ, большинство из них даже юмористичны (например, yacc="yet another compiler compiler"). Большинство названий оболочек оканчивается на "sh", например, ksh (korn shell), csh (C shell... seashell, улавливаете?) и bash (Bourne again shell).
Запуск терминала
Запуск терминала осуществляется щелчком мыши по иконке терминала в нижней части экрана. Это наиболее простой способ. Надеюсь, Вы предварительно вошли в систему, используя только что созданную учётную запись
Левый рисунок - иконка запуска терминала KDE, правый - терминала Gnome. Описываемые здесь действия применимы для обоих терминалов, т.к. запускаемая ими по умолчанию оболочка - bash. Для запуска терминалов с другими GUI поищите "xterm" в меню или другое имя программы, оканчивающееся на "term" или "terminal".Другой способ запуска терминала заключается в загрузке Linux в текстовом режиме. Многие серверы по умолчанию сконфигурированы на запуск без использования GUI, т.о. Вы можете столкнуться с приглашением на вход в систему в текстовом режиме. "Домашние" или "настольные" компьютеры, наоборот, обычно начинают работу в графическом режиме.
Проще всего переключиться в текстовый режим комбинацией клавиш Alt-Ctrl-F1. Alt-Ctrl-F7 - обратное переключение в графический режим. Фактически, комбинации от Alt-Ctrl-F1 до Alt-Ctrl-F6 загружают 6 отдельных приглашений на вход в систему в текстовом режиме, тогда как Alt-Ctrl-F7 - в графическом режиме.
Рабочее окно терминала - в данном случае, KDE 'Konsole'.При первом запуске рабочего окна терминала (или при входе в систему в текстовом режиме) Вы увидите приглашение, похожее на указанное выше. Фактический текст в окне приглашения определяется пользователем и варьируется в зависимости от дистрибутива. Вообще же, окно приглашения включает в себя текущее имя пользователя, имя компьютера и текущий каталог. Как показано на рисунке, имя пользователя "sandbox", имя компьютера "laptop", каталог "~". Обычно значок "~" применяется для обозначения домашнего каталога (/home).
Ввод команд
В процессе чтения этого документа Вам придётся вводить много команд. Каждый раз набирайте слова и символы именно так, как они указаны, в конце нажимая Enter.
Учтите, что как и большинство других параметров в Linux, команды вводятся с учетом регистра клавиатуры. Т.е., если Вы хотите ввести "ls", то ввод "LS" не даст нужного результата.
Выход из терминала
Первое, что Вы, наверное, хотите узнать, это как выйти из терминала. Наберите "exit" и нажмите Enter. Другой вариант - Ctrl-D. Рабочее окно терминала закроется. Хотя можно закрыть терминал, щёлкнув мышью по кнопке "Закрыть (close)" или опции меню, данный способ наиболее предпочтителен т.к. гарантирует, что не не потеряете свои данные, работая в текстовом редакторе или в другом приложении.
Пример простой команды
В окне терминала введите "ls" и нажмите Enter. Вы должны увидеть что-то похожее на это (содержимое может варьироваться):
sandbox@laptop:~ > ls
KDesktop public_html snapshot1.png
sandbox@laptop:~ >Команда "ls" (list - список) отображает содержимое текущего каклога. При выполнении из терминала она выделяет разными цветами каталоги, графические и исполняемые файлы и.т.д. После выполнения команды появляется строка приглашения на ввод команд.
Добавление ключей
Практически все команды в Linux допускают использование ключей. Вы можете добавлять ключи и к команде "ls", чтобы видоизменять результат её выполнения или влиять на ход выполнения. Ключ упреждается чертой (например, "ls -a"). Проверьте нижеуказанные варианты выполнения команды "ls", чтобы увидеть соответствующие результаты:
- ls -l
- Выводит подробный перечень файлов каталога. Для каждого файла или каталога также выводятся владелец, группа, размер, дата изменения, права.
- ls -a
- Выводит перечень всех файлов в каталоге, включая скрытые. В Linux файлы, имена которых начинаются с точки, обычно не отображаются.
- ls -R
- Выводит содержимое каждого подкаталога, его подкаталоги и.т.д. (рекурсивно).
Если необходимо указать большее количество ключей, Вы можете сгруппировать их через одну черту. Например, команды "ls -al" и "ls -a -l" полностью идентичны.
Некоторые ключи состоят из слова (или слов), и их ввод требует двух черт, а не одной. Например, команда "ls -l --full-time" выводит полную информацию о дате и времени изменения.
Некоторые ключи могут содержать значение. Например, "ls -l --sort=size" сортирует перечень по размеру.
Добавление параметров
Кроме ключей (которые упреждаются одной или двумя чертами), Вы можете устанавливать параметры такие, как имена файлов, каталогов и.т.д.
Например, команда "ls", если Вы не указали каких-либо параметров, выведет содержимое текущего каталога. Но Вы можете добавить параметры, определяющие что именно отображать. Например, если ввести "ls /usr", то результатом будет отображение содержимого каталога "/usr". Вы можете указать и большее число параметров, но мы рассмотрим этот случай позже.
Получение справочной информации
Вопреки расхожему мнению, команды и программы в Linux прекрасно документированы. В Windows документируются лишь наиболее популярные команды, и то лишь до определённого "уровня".
Данный раздел описывает основные схемы получения справочной информации. Заметьте, что многие дистрибутивы, такие, как Mandrake, RedHat и SuSE, обеспечиваются GUI - средствами получения справочной информации.
Команда "man"
Почти каждая команда в Linux имеет доступную через командную строку оперативную справочную информацию. Она вызывается с помощью команды "man" (manual - справочник).
Введите "man ls". Полученная в результате страница описывает работу этой команды, её ключи, другие подробности относительно программы, автора и.т.д. Эта информация отображается с помощью команды "less" (её описание ниже). Для навигации по странице используются клавиши с указанием стрелок, PgUp/PgDn; клавиша Q - выход.
Команда "info"
Другим источником оперативной справочной информации является команда "info". Некоторые команды Linux снабжаются и man -, и info - документацией. Как правило, info - документация более информативна и наглядна, похожа на руководство пользователя, в то время, как man - документация носит справочный характер, указывая перечень ключей, параметров и их описание.
Ввведите "info ls". Для навигации по странице используются те же клавиши, что и для команды "man". Основное отличие заключается в том, что info - страницы могут содержать "меню" ссылок на другие страницы. Чтобы воспользоваться ссылкой, переместите на неё курсор клавишами с указанием стрелок и нажмите Enter.
Ключ "--help"
Большинство (но не все) программ поддерживают ключ --help, который отображает очень краткое описание главных ключей и параметров. Введите "ls --help". Результатом выполнения будет порождение нескольких полноэкранных страниц информации, и Вам придётся воспользоваться линейкой прокрутки для её просмотра.
Ключ "--help" почти не используется, т.к. выводимая им информация редко дополняет man - документацию. Исключение составляет незначительное количество программ, не снабжённых документацией иного рода.
Проект документации Linux (L.D.P.)
Проект L.D.P. содержит не только коллекцию всех "man" - и "info" - страниц, но и огромное количество руководств, howto - и mini-howto - документов по всем темам. В отличие от man - и info - страниц эти howto - документы описывают не специфические команды, а методы выполнения практических задач. Если Вы ищете информацию в сети Интернет, то данный ресурс является наилучшим местом поиска.
Каталоги Linux
Как Вы уже, вероятно, знаете, работая в графическом режиме, в Linux каталоги (другое название - "папки") используют косую черту (/) в качестве разделителя (Windows использует обратную косую черту (\)). Другими словами, он работает точно также, как в web - узлах или ftp - серверах.
Любой каталог, начинающийся с косой черты, например, "/usr/bin", означает, что это его "абсолютное" имя, определяющее полную последовательность каталогов от "корневого" (/) до требуемого (bin). Т.о., когда Вы определяете имя, не имеет значения, какой каталог является текущим, он всегда будет указывать на каталог /usr/bin.
С другой стороны, каталог, начинающийся не с косой черты, является относительным к текущему каталогу. Например, "bin" будет указывать на разные каталоги, в зависимости от того, находитесь ли Вы в корневом каталоге (в этом случае он укажет на "/bin"), в каталоге "/usr" (в этом случае он укажет на /usr/bin) или в каталоге "/usr/local" (в этом случае он укажет на /usr/local/bin).
Эти утверждения относятся и к файлам - если Вы указываете "file.txt", то, предположительно, к текущему каталогу, в то время, как "/tmp/file.txt" всегда будет указывать на файл "file.txt" именно во временном каталоге.
Два определённых каталога, находящиеся в текущем каталоге, представляются одной точкой, а родительский каталог представляется двойной точкой. Т.о., если Вы находитесь в каталоге /home/sandbox и введёте ls .., результатом будет вывод содержимого родительского каталога, в данном случае /home.
Некоторые системные каталоги
Ниже приведён перечень некоторых общих каталогов для Linux и других Unix - систем, а также их назначение.
- /
- Обозначает корневой каталог, внутри которого размещаются все остальные каталоги.
- Аналогом в Windows является корневой каталог дискового устройства (C:\), но в Linux даже разные дисковые устройства находятся в едином корневом каталоге.
- /bin
- Сокращённо от "binary - двоичный", содержит программные (исполняемые) файлы. В этом (и других каталогах "bin") находятся команды, такие, как "ls".
- В Windows каталог c:\windows\command содержит лишь некоторые консольные программы, остальные разбросаны по другим каталогам.
- /dev
- Сокращение от "devices - устройства". Содержит определённое количество специальных псевдо-файлов, использующихся для доступа к аппаратной части, а также к подключённым к компьютеру устройств. Например, параллельный порт - это файл с именем "lp0", жёсткий диск - "hda", а его первый раздел - "hda0".
- Windows/DOS использует похожий метод, однако в Windows эти файлы не вынесены в отдельный каталог. При попытке доступа к устройствам с именами LPT1, COM1 или CON из любого каталога, Вы получите, соответственно, свойства принтера, подключённого к параллельному порту, последовательного порта или консоли.
- /etc
- Каталог, в котором хранится почти вся информация о конфигурации в масштабе всей системы. Информация хранится в виде текстовых файлов, т.о. Вы можете просмотреть её с помощью любого текстового редактора. Хотя некоторые файлы являются скрытыми.
- Аналогов в Windows нет, т.к. конфигурационные данные, реестр, INI файлы и.т.д., хранятся в различных каталогах.
- /home
- Домашние каталоги пользователей. Т.о., если Вы создали учётную запись пользователя "sandbox", в этом каталоге создаётся новый подкаталог с именем "sandbox". Пользователям с другими именами он недоступен. Исключением является пользователь, наделённый правами администратора.
- Ближайшим аналогом в Windows является каталог c:\windows\profiles, в котором содержатся данные пользователей, а также каталог c:\My Documents, в который сохраняются все документы, созданные пользователем. Другие данные могут быть записаны в других каталогах.
- /lib
- Каталог, в котором хранятся файлы библиотек. Библиотеки - файлы, содержащие многократно используемые программами функции и процедуры.
- Аналогов в Windows/DOS нет.
- /mnt
- Каталог, в котором хранятся все подмонтированные устройства, а не только жёсткие диски. Обычно содержит подкаталоги "cdrom", "floppy", и.т.д., которые отображают содержимое подмонтированых CD-ROM или FDD. Ваши Windows устройства также могут автоматически подмонтироваться в этот каталог.
- Аналогов в Windows/DOS нет.
- /opt
- Каталог, в который устанавливаются дополнительные компоненты системы. Такие продукты, как KDE, Gnome и Oracle могут быть установлены в этот каталог.
- Ближайшим аналогом в Windows является каталог c:\Program Files.
- /tmp
- Каталог, в котором хранятся временные данные. Все файлы, помещённые в него, со временем автоматически удаляются.
- Аналог в Windows/DOS - c:\windows\temp.
- /usr
- Содержит копии большинства корневых каталогов. Например, каталог "bin", содержащий программы, катaлог "lib", содержащий библиотеки и.т.д. Обычно "ядровые" файлы Linux содержатся в корневых каталогах, в то время, как "неядровые" файлы находятся в подкаталогах "/usr".
- Аналогов в Windows/DOS нет.
- /var
- Сокращённо от "various - разное". Среди хранящихся здесь файлов системные журналы, спул-файлы (файл, в который в процессе спулинга сбрасывается содержимое задания на печать) и другие файлы данных. Спулинг - процесс обработки посылаемых на печать документов, которые сохраняются на диске до момента, когда принтер сможет их обработать.
- Аналогов в Windows/DOS нет.
Команды управления каталогами
Здесь описывается большинство общих команд управления каталогами.
- mkdir новое-имя-каталога
- Создаёт новый каталог с именем "новое-имя-каталога"
- cd имя каталога
- Перейти к указанному каталогу, делая его "текущим"
- cd
- Если Вы не указываете имя каталога, переход осуществляется к Вашему "домашнему" каталогу.
- rmdir имя-каталога
- Перемещает (удаляет) каталог. В качестве меры безопасности каталог должен быть пустым до удаления.
- pwd
- Отображает текущий каталог.
- ls имя-каталога
- Выводит содержимое указанного каталога.
Ниже приведена последовательность действий, демонстрирующая практическое применение описанных выше команд. Для наглядности приглашение на ввод команд сделано серым цветом. После отображения содержимого каталога был создан новый каталог "testing", а затем снова отображено содержимое каталога. Далее мы входим в новый каталог, отображаем текущий каталог, возвращаемся в "домашний" каталог, вновь отображаем текущий каталог. Удаляем каталог "testing".
sandbox@laptop:~ > ls
KDesktop public_html
sandbox@laptop:~ > mkdir testing
sandbox@laptop:~ > ls
KDesktop public_html testing
sandbox@laptop:~ > cd testing
sandbox@laptop:~/testing > pwd
/home/sandbox/testing
sandbox@laptop:~/testing > cd
sandbox@laptop:~ > pwd
/home/sandbox
sandbox@laptop:~ > rmdir testing
sandbox@laptop:~ >
Файлы Linux
Команды управления файлами
Здесь описываются большинство общих команд управления файлами.
- cp имя-файла1 имя-файла2
- cp имя-файла1 имя-файла2 имя-файла3 (и.т.д.) каталог
- Копирует файл из имя-файла1 в имя-файла2 или (вторая строка) копировать один или более файлов в указанный каталог. Внимание: если в указанном месте файл уже существует, он будет перезаписан.
- mv имя-файла1 имя-файла2
- Переименовывает файл из имя-файла1 в имя-файла2. Внимание: если второй файл уже существует, он будет перезаписан.
- mv имя-файла1 имя-файла2 имя-файла3 (и.т.д.) каталог
- Перемещает один или более файлов в указанный каталог. Внимание: если каталог уже содержит файлы с такими именами, они будут перезаписаны.
- less имя-файла
- Выводит на экран содержимое указанного файла с возможностью навигации по нему клавишами с указанием стрелок, PgUp/PgDn и.т.д. (см. команду "man").
- file имя-файла
- Отображает идентификатор типа файла, исследуя его содержимое с очень высокой степенью точности.
- locate имя-файла-или-каталога
- Ищет файл или каталог на указанном диске и отображает все места, где он был найден. Вы можете указать частичное имя или часть полного пути.
Групповые символы
В Linux Вы повсеместно можете указать имя файла и каталога, используя групповые символы. По одному или более специальным символам оболочка будет искать подходящие по шаблону файлы, и помещать их в командную строку вместо шаблона. Слово "wildcard - групповой символ" также переводится как карточный "Джокер", т.к. эта карта может заменить любую другую карту. В данном случае значок "группового символа" может заменить любые буквы или символы в имени файла.
Проверка групповых символов
Наилучшей тренировкой будет использование команды "ls" в каталоге со множеством файлов с применением групповых символов в качестве аргументов. Как мы видели ранее, команда "ls" может содержать параметр, указывающий, что именно нужно отобразить. Вместо указания каталога мы собираемся передать перечень всех имён файлов, которые необходимо отобразить. Перечень будет составлен согласно указанным шаблонам групповых символов. Их описание приведено ниже.
Перед тем, как продолжить, в окне терминала введите команду "cd /usr/bin". Результатом её выполнения будет переход в главный каталог, содержащий команды ОС. В нём огромное число файлов, т.е. он является идеальной средой для наших экспериментов.
sandbox@laptop:~ > cd /usr/bin
sandbox@laptop:/usr/bin >
Групповой символ *
Первый групповой символ - звёздочка. Знак * заменяет нуль и большее количество других символов. Размещая этот символ в начале, в середине или в конце шаблона, Вы можете сформировать конкретный тип задачи. Например, шаблон "*txt" означает любую последовательность букв, оканчивающуюся на "txt".
Ниже представлена таблица шаблонов, примеры соответствующих и несоответствующих этим шаблонам имён файлов.
Шаблон Соответствующие файлы Несоответствующие файлы Причина несоответствия *.txt File.txt
another-file.txt
txtFile.TXT
File.txt2
txtfile
FiletxtTXT - верхний регистр
заканчивается на "2"
"txt" - не в конце
нет точки (.)*txt File.txt
another-file.txt
txt
FiletxtFile.TXT
File.txt2
txtfileTXT - верхний регистр
заканчивается на "2"
"txt" - не в конце*txt* File.txt
another-file.txt
txt
Filetxt
File.txt2
txtfileFile.TXT TXT - верхний регистр Групповой символ ?
В то время, как групповой символ * может заменить нуль или более букв или знаков, групповой символ ? заменяет только один. Т.о., шаблон "???" заменяет имя файла, состоящее исключительно из трёх символов. Шаблон "x??" означает любое трёхбуквенное имя файла, начинающееся на "x".
Групповой символ [ ]
Квадратные скобки используются для содержания соответствующего набора символов. Например, шаблон "[ABC]*" соответствует любому имени файла, начинающегося на одну из букв A, B или C и сопровождающегося любым количеством символов.
Если первый символ - знак восклицания (!) или вставки (^), то шаблон соответствует любому символу, за исключением данных. Т.о., шаблон "[^x]*" означает любое имя файла, исключая начинающееся на "x".
Набор может содержать диапазон символов, а не только отдельные буквы. Например, шаблон "[A-Z]*" означает любое имя файла, начинающееся с прописной буквы от A до Z включительно, сопровождающегося любым количеством символов, а "[A-Za-z123]" означает один символ, являющийся прописной или строчной буквой или цифрой 1, 2, 3.
Как работают групповые символы
Обработка групповых символов в Windows существенно отличается от их обработки в Linux или других Unix - системах. В Windows выполняемая программа или команда получает выражение групповых символов целостно. Если программа не предназначена для обслуживания групповых символов, она будет пытаться открыть файл, именуемый "*.txt".
С другой стороны, в Linux всю работу выполняет оболочка bash. Она берёт шаблон, содержащий групповые символы, преобразует его в перечень соответствующих имён файлов и передаёт его программе на место шаблона. Ниже приведена таблица, показывающая, как определённые команды будут "транслироваться" оболочкой bash. Фактические имена файлов зависят от содержимого каталога, так что они могут варьироваться.
Исходная команда Что фактически выполняется ls ls ls y* ls yacc ybmtopbm yes ypcat ypchfn ypchsh ypmatch yppasswd ypwhich yuvsplittoppm yuvtoppm ls ?a? ls cal man tac ls blubble* ls blubble* Обратите внимание на последний пример - оболочка bash не смогла найти файл с таким именем, т.о., шаблон, содержащий групповые символы, передаётся программе в форме "как есть".
Это "облегчает жизнь" программам, т.к. они должны обслужить только списки имён файлов на их командных строках. Однако есть несколько приёмов, которые можно сделать в MS-DOS, и нельзя в Linux. Например, в MS-DOS можно ввести команду "copy *.doc *.bak" - которая скопирует все файлы с расширением "doc" в одноимённые файлы с расширением "bak". В Linux эта команда будет переведена в нечто похожее на "copy file1.doc file2.doc file3.doc file2.bak file4.bak" - что даст совершенно другой и, возможно, нежелательный результат. Из-за введения длинных имён файлов эта методика фактически не работает в Windows.
Работа с каталогами при помощи групповых символов
В Linux групповыми символами можно управлять и каталогами. Например, шаблон "*/file.txt" означает все файлы "file.txt" в любом подкаталоге.
Работа со скрытыми файлами при помощи групповых символов
Групповые символы не работают со скрытыми файлами, если шаблон группового символа начинается без точки. Т.о., шаблон ".*" соответствует всем скрытым файлам. Скрытые файлы - это файлы, имя которых начинается с точки. Например, .profile или .kde2.
Хитрости ввода команд
Работая в оболочке bash, Вы можете вызывать ранее введённые команды с помощью клавиш ↑ и ↓.
Существуют также bash_history (история bash) и комбинация Ctrl-R, позволяющая быстро вызывать команды из этой истории по ключевым последовательностям символов. Т.о. если Вы хотите найти последнюю смену каталога, введите "[Ctrl-R]cd", и в командной строке отобразится команда "cd".
При вводе первых символов имени файла или каталога, нажмите [Tab]. Оболочка bash автоматически заполнит его, при условии, что такой файл существует и начинается с введённых Вами символов. Например, если Вы ввели "ls br[Tab]", оболочка bash заполнит имя файла до "brushtopbm", при условии, что такой файл существует и что только он начинается на "br".
Перенаправление вывода
Перенаправление вывода в файл
Большинство программ при своём выполнении выводят на экран много текста. Вы можете сохранить этот текст в файл для возможного дальнейшего использования. Чтобы это сделать, воспользуйтесь оператором перенаправления ">".
Например, Вы хотите сохранить копию содержимого каталога в файл. Вы вводите команду "ls -l" с последующим ">", а также имя создаваемого файла.
В нижеприведённом примере мы отобразим содержимое каталога /usr в подробном формате, а затем запишем его в файл в наш "домашний" каталог (т.к. мы не можем создавать файлы в каталоге /usr).
sandbox@laptop:~ > cd /usr
sandbox@laptop:/usr > ls -l > ~/usr-listing.txt
sandbox@laptop:/usr > cd
sandbox@laptop:~ > ls
KDesktop public_html snapshot1.png usr-listing.txt
sandbox@laptop:~ >Обратите внимание на вторую строку. Сначала мы дали команду вывода содержимого каталога "ls -l", затем оператором перенаправления ">" указали оболочке сохранить результаты в файл с именем listing.txt (~/usr-listing.txt). Символ "~" обозначает "домашний" каталог пользователя для возможного повторного быстрого вызова.
Приведённый символ (>) создаёт новый файл с указанным именем. Если такой файл уже существует, он очищается перед получением вывода программы. Если Вы вводите двойной символ (>>), вывод программы будет дописываться в конец существующего файла. Это нужно при перенаправлении выводов нескольких программ в один файл.
Конвейеризация вывода в программу
В предыдущей главе мы рассмотрели перенаправление вывода команды в новый файл. Вывод одной программы можно передать на вхoд другой программы, применяя конвейеризацию. Вторая программа обрабатывает вывод первой программы, на основе которого порождает свой вывод.
Проверим. Содержимое файла отображается командой "cat". Файл "/etc/services" содержит список распознанных TCP/IP сервисов. Отображение занимает несколько полноэкранных страниц текста.
Учтите, что в нижеприведённом примере показан фрагмент отображаемой информации.
sandbox@laptop:~ >cat /etc/services
# 0/tcp Reserved
# 0/udp Reserved
tcpmux 1/tcp # TCP Port Service Multiplexer
tcpmux 1/udp # TCP Port Service Multiplexer
compressnet 2/tcp # Management Utility
compressnet 2/udp # Management Utility
......множество других строк.....
nimhub 48002/tcp # Nimbus Hub
nimhub 48002/udp # Nimbus Hub
nimgtw 48003/tcp # Nimbus Gateway
nimgtw 48003/udp # Nimbus GatewayТеперь команда "sort" сортирует ввод в алфавитном порядке и передаёт его на вывод. Т.о., для сортирования вывода команды "cat", мы должны конвейеризировать его на вход команды sort. Чтобы это сделать, нужно воспользоваться символом конвейеризации (|).
sandbox@laptop:~ >cat /etc/services | sort
3Com-nsd 1742/tcp # 3Com-nsd
3Com-nsd 1742/udp # 3Com-nsd
3com-amp3 629/tcp # 3Com AMP3
3com-amp3 629/udp # 3Com AMP3
......множество других строк.....
zip 6/ddp # Zone Information Protocol
zserv 346/tcp # Zebra server
zserv 346/udp # Zebra serverОдно очень популярное применение конвейера заключается в передаче вывода таких длинных команд на вход команды "less". Эта команда позволяет полностью пролистать полученную информацию.
ps -Hefw | lessУказанная командная строка отображает список системных процессов, а применение команды "less" позволяет полностью пролистать полученную информацию, используя клавиши с указанием стрелок, PgUp/PgDn; клавиша Q - выход.
Возможен одновременный ввод нескольких команд, разделённых знаком |. Например, мы можем использовать команду "cat" для отображения содержимого файла сервисов, передать результат на вход команды "sort" для сортировки, отсортированный список подать на вход команды "tail" для выделения последних 50 строк и, наконец, передать эти 50 строк на вход команды "less" для просмотра полученных результатов.
cat /etc/services | sort | tail -n 50 | less
Переменные окружения
В Linux (также, как и в MS-DOS, Windows и.т.д.) каждая программа имеет ряд "переменных окружения". Это ряд "параметров настройки", которые могут использоваться для контроля определённых аспектов системы, прав пользователя и.т.д. Каждый раз выполняемая программа получает копию переменных окружения от выполняющего их процесса. Т.е., если Вы запускаете программу из оболочки bash, эта программа получит копию всех переменных окружения непосредственно от оболочки bash.
В нижеприведённом примере я использую программу "date" для отображения даты. Однако, я каждый раз меняю кодировку языка. Команда "export" применяется для установки нового значения в переменной окружения или для его создания в случае, если оно не существует.
sandbox@laptop:~ >date
Thu Aug 2 04:35:55 CEST 2001
sandbox@laptop:~ >export LANG=it_IT
sandbox@laptop:~ >date
gio ago 2 04:45:05 CEST 2001
sandbox@laptop:~ >export LANG=mt_MT
sandbox@laptop:~ >date
Ħ Awi 2 04:45:55 CEST 2001Используя команду "set", Вы можете просмотреть все текущие переменные окружения. Т.к. объём выдаваемой информации достаточно большой, желательно передать результат на вход команды "less".
Вы можете включать значение любой переменной окружения в пределах команды, указывая перед ним знак $. Например, команда "ls -l $SHELL" выведет подробный листинг непосредственно программы bash, т.к. переменная окружения SHELL содержит размещение текущей оболочки.
Наиболее важными являются переменные окружения HOME, PATH и PS1. Первая явно указывает на домашний каталог пользователя. Применяется для создания таких конструкций, как "$HOME/file1.txt".
Переменная PATH
Вторая переменная, PATH (Путь), является списком имён каталогов, разделённых двоеточием. Это - список мест, которые оболочка bash будет просматривать при поиске указанных Вами имён команд. Т.о., при вводе "ls", оболочка bash начнёт поиск в этих каталогах исполняемого файла и именем "ls", а затем запустит его на исполнение, если такой файл будет найден.
Вы можете использвать "$PATH" в пределах другой команды, чтобы присвоить PATH разное значение, например, добавить новый каталог в PATH. Предположим, что Вы создаёте новый каталог для программ в своём домашнем каталоге. Вы можете добавить этот каталог в PATH, и оболочка bash также в нём будет производить поиск. Чтобы сделать это (полaгая, что имя Вашего нового каталога "bin"), дайте следующую команду:
export PATH=$PATH:$HOME/binВ этой команде я присваиваю переменной окружения PATH её же предыдущее значение, сопровождаемое двоеточием, и имя каталога, сформированное из переменной HOME и "/bin".
Переменная PS1
Последняя переменная окружения, PS1, указывает оболочке что отображать в приглашении на ввод команд. Вы можете поэкспериментировать с переменной PS1, установив нравящееся Вам приглашение на ввод команд. Работая над этим документом, я, например, установил необходимый HTML код для придания ему серого цвета.
sandbox@laptop:~ >export PS1="I am \u on \h> "
I am sandbox on laptop>Учтите, что все изменения, вносимые в переменные окружения, являются временными. Переменные окружения принимают свои исходные значения при следующем открытии окна терминала или при входе в систему. О том, как зафиксировать эти изменения, мы сейчас узнаем.
Сценарии
Сценарий оболочки - это файл, содержащий серию приведённых выше команд, которые будут последовательно выполнены оболочкой bash. Технически это программа, написанная на языке "bash".
Для создания сценариев можно использовать любой текстовый редактор. В KDE можно использовать любой расширенный редактор - kate, kwrite или kedit. Не следует применять программы подготовки текста - они не являются текстовыми редакторами, и добавляют в текст дополнительное форматирование. Если Вы знаете, как создать в них беспримесный текстовый файл, пользуйтесь ими.
Создайте новый файл и введите следующие строки.
#!/bin/bash
echo "I am about to list the home directory"
# here is the actual listing:
ls $HOME
echo "Done!"Первая строка указывает текущей оболочке, какую программу следует использовать для интерпретации файла. В данном случае это оболочка bash. Это сделано для того, что если сценарий вызывается в пределах другой оболочки или файлового менеджера - Konqueror и Nautilus, они будут "знать", что для выполнения этого сценария требуется оболочка bash.
Вторая строка - это первая команда в сценарии. Команда "echo" используется для вывода на экран простой информационной строки.
Третья строка - комментарий. Оболочка bash проигнорирует его, но для пользователя он полезен, т.к. поясняет ход работы сценария. В простых сценариях комментарии необязательны, но вот в сложных они уместны.
Далее следуют ещё две команды - команда "ls", которая берёт имя каталога в качестве параметра, и, наконец, команда "echo", выводящая на экран информацию об успешном выполнении работы!
При сохранении этого файла оказывается, что он неисполняемый. Чтобы сделать его исполняемым, нужно использовать команду "chmod". В качестве примера я назвал этот сценарий "myscript" - Вы можете назвать его по другому.
chmod u+x myscriptТеперь Вы можете запустить на выполнение новый сценарий. Для этого введите следующую команду, заменив имя сценария "myscript" на то, которое выбрали Вы.
sandbox@laptop:~ >./myscript
I am about to list the home directory
KDesktop myscript public_html snapshot1.png usr-listing.txt
Done!Учтите, что "./" перед именем файла - это актуальное имя каталога (точка означает текущий каталог). Можно воспользоваться переменной окружения PATH для того, чтобы указать каталог, в котором находятся созданные Вами сценарии. Теперь Вы можете вводить команды независимо от того, в каком каталоге Вы находитесь.
Сценарии автозапуска Bash
Оболочка bash использует специальный, скрытый файл, находящийся в Вашем домашнем каталоге: ".bashrc". По сути, это тот же сценарий, но в нём отсутствует первая строка, которую мы использовали выше (#!/bin/bash). Этот сценарий автоматически выполняется при запуске оболочки bash. В него можно помещать переменные окружения или другие параметры для того, чтобы они выполнялись оболочкой bash при каждом входе в систему.
Псевдоимена
Оболочка bash позволяет назначать новые команды, заменяющие длинноформатные команды. Например, если ввести...
alias lh="ls -l -a $HOME", то команда "lh" будет эквивалентна команде "lh -l -a $HOME".
Вы можете использовать данную возможность для переопределения существующих команд. Например, если Вы введёте "alias ls="ls -a"", то команда ls всегда будет отображать скрытые файлы. Вы можете удалить существующее псевдоимя командой unalias.
Эти псеводимена Вы можете поместить в файл .bashrc, чтобы они восстанавливались при загрузке оболочки bash.
Для некоторых команд Вы можете добавлять даже "меры обеспечения безопасности". Например, Вы создали псевдоимя для команды копирования:
alias cp="cp -i"При каждой операции копирования она будет запрашивать подтверждение, если копируемый файл уже существует, вместо того, чтобы перезаписать его без предупреждения. Учтите, что эти настройки действительны только для учётной записи конкретного пользователя. При входе в систему с использованием учётной записи другого пользователя они работать не будут. Для того, чтобы они работали, Вы должны добавить эти псевдоимена в файл .bashrc данного пользователя.
Переключение в режим администратора
Иногда возникает ситуация, когда для выполнения некоторых команд необходимо переключиться в режим администратора. Помните, что, работая в режиме администратора, Вы можете делать всё - устанавливать файлы в системную область или удалить все данные с жёсткого диска. Будьте внимательны при входе в систему в режиме администратора.
Команда переключения между учётными записями пользователей: su - сокращённо от "set user" (установить пользователя). Ввод этой команды без дополнительных параметров означает переключение в режим администратора. Чтобы переключиться на учётную запись конкретного пользователя, необходимо указать имя этого пользователя. Во всех случаях Вам будет предложен ввод пароля. После ввода пароля Вы можете приступить к работе с данными и файлами, которые доступны только для этого пользователя и.т.д. Администратору доступны все файлы и задачи.
Попробуйте начать работу с использованием Вашего обычного имени пользователя. В данном примере я использую 'ramon' в качестве имени пользователя.
sandbox@laptop:~ > ls /home/ramon
Access denied.
sandbox@laptop:~ > ls
file1.txt file2.txt
sandbox@laptop:~ > su ramon
Password: (ввод пароля для ramon)
ramon@laptop:/home/sandbox > ls
Access denied.
ramon@laptop:/home/sandbox > ls /home/ramon
Desktop Mail Documents
ramon@laptop:/home/sandbox > exit
sandbox@laptop:~ >Учтите, что, войдя в систему под именем "sandbox", я могу отобразить содержимое домашнего каталога пользователя "sandbox", домашние каталоги других пользователей недоступны. Обратите также внимание, что я воспользовался командой exit для возврата в учётную запись "sandbox" из записи "ramon". Это необходимо, т.к. команда su создаёт новый процесс оболочки, используя учётную запись "ramon".
При использовании команды su без дополнительных параметров выдаётся приглашение на ввод пароля администратора. Войдя в систему в режиме администратора, пользователю доступны все области.
sandbox@laptop:~ > su
Password: (ввод пароля администратора)
root@laptop:/home/sandbox > ls
file1.txt file2.txt
root@laptop:/home/sandbox > ls /home/ramon
Desktop Mail Documents
root@laptop:/home/sandbox > exit
sandbox@laptop:~ >Существует различие между входом в систему в режиме администратора (или другого пользователя) с дальнейшей загрузкой терминала и входом в режиме обычного пользователя с последующими загрузкой терминала и использованием команды su для переключения в режим администратора. Различие заключается в загружаемых сценариях автозапуска. При описанном выше использовании команды "su" она наследует все установки от предыдущей оболочки. Т.о., например, если Вы установили некоторые переменные окружения, они будут перенесены и доступны при работе в режиме администратора. Это полезно при некоторых компиляциях. Если Вы компилируете программу в режиме обычного пользователя, а затем переключаетесь в режим администратора для окончательного установочного шага, может оказаться полезным перенос некоторых установленных ранее переменных окружения.
Существует один недостаток - некоторые команды в сценариях автозапуска администратора не будут выполняться. Если Вам нужно переключиться в режим администратора (или другого пользователя) и быть уверенным, что сценарии автозапуска выполнятся, добавьте дефис между командой su и параметром имени пользователя. Т.о., применённая выше команда будет иметь такой вид:
su - ramon
su -Вам снова будет предложено ввести пароль, но теперь сценарии автозапуска будут выполнены, а любые установки Вашего сеанса будут "забыты" - так, словно Вы вошли в систему как пользователь, имя которого отображено на экране.
Компиляция программ из исходных кодов
Одной из основных причин использования терминала является компиляция программ, скачанных из Интернета. Компиляция - это процесс, преобразующий исходный код в программу в двоичном представлении с учётом типа процессора, установленного на компьютере.
Все подобные программы сопровождаются инструкцией по компиляции - обычно это текстовые файлы с именами "INSTALL", "README" и.т.п. Ниже описывается общий для всех программ метод.
Допустим, что скачанный файл называется "MyProgram-1.2.3.tgz". Т.к. это файл - архив, наподобие WinZip файла, необходимо извлечь его содержимое. Это делается с помощью команды tar:
tar -xvzf MyProgram-1.2.3.tgzПриведенные ключи указывают команде tar извлечь (x) и подробно описать (v) сжатое при помощи архиватора ZIP содержимое (z) архивного файла (f) c указанным именем. Tar извлечёт содержимое архива и отобразит что оно делает.
Далее необходимо перейти в только что созданный каталог, имеющий такое же имя, что и архив, но без расширения ".tgz".
cd MyProgram-1.2.3Следующий шаг - запуск сценария "configure". Он проверяет Вашу систему и порождает компилирование и установочный сценарий, идеально подходящий для Вашей конфигурации. Другая задача на этом этапе заключается в проверке установленного необходимого программного обеспечения. Команда "configure" по окончанию своей работы выводит большой объём информации. Здесь она не приводится, т.к. обычно всё проходит без ошибок.
./configureВ то время, как сценарий "configure" пишет рецепт, команда "make" берёт ингредиенты и печёт пирог. Обычно это делается в два этапа. Сначала Вы вводите "make" для генерации программы в двоичном представлении, затем "make install" для размещения этой программы в надлежащем месте Вашего компьютера. Последний шаг должен выполняться в режиме администратора, т.к. он требует разрешение разместить файлы в системных областях. Переключиться в режим администратора Вы можете при помощи команды "su".
make
su
make install
exitЕсли сообщений об ошибках не было, значит, всё прошло успешно.
Заключение
На этом мы заканчиваем наш обзор по использованию оболочки командной строки. Конечно, многие полезные вещи остались нераскрытыми, касающиеся написания основных сценариев или выполнения дополнительных задач. Однако то, о чём рассказывалось выше, должно на начальном этапе помочь понять "физику" системы, стать отправной точкой в изучении тонкостей консольных программ в Linux. Помните, что оболочка bash имеет собственную справочную страницу, которая так же, как другие руководства и документации, доступна на Web-сайте Проекта документации Linux (Linux Documentation Project).
Автор: Реймон Кейша (Ramon Casha) Дата: 8 ноября 2001 Локализация: Касимов М.А. (г. Киев) Дата перевода: 4 июня 2004 Источник: linux.org.mt/article/terminal
< Предыдущая | Следующая > |
---|
Кто онлайн?
Мы в twitter
Последние комментарии
-
Я не хочу обидеть автора статьи, но данный мануал ...
By Виктор -
если не прописать AnonRequirePass word off, то он ...
By Maksim -
есть и бесплатная версия. хотя для дома ИМХО это ...
By panda1945 -
Отличная статья жаль она не попалась мн когда я то...
By panda1945 -
Ну да, для дома или пары клиентов рублей 9 выкину...
By a148ru -
Бизнес в интернете - ровно как и заработок в интер...
By culbipa -
непонял
By DragoN -
ДЕЛАЛ ПОЛНОСТЬЮ ПО МАНУАЛУ - В /BOOT НИ ЧЕ КРОМЕ G...
By romka
Комментарии
RSS лента комментариев этой записи