Истории успеха наших клиентов — лучшие проекты
Вход/ Регистрация

Переменные оболочки и окружения в Linux

5460
9 минут чтения
Средний рейтинг статьи: 5

Переменные Оболочки И Окружения В Linux (1)

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

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

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

Кстати, в официальном канале Timeweb Cloud собрали комьюнити из специалистов, которые говорят про IT-тренды, делятся полезными инструкциями и даже приглашают к себе работать. 

VDS и VPS

Гибкие виртуальные серверы с почасовым
биллингом по всему миру: Россия, Азия и Европа.

Общая информация по окружению и переменным

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

Информация в нем представлена как пара ключ-значение. Если запланирована передача нескольких значений, их разделяют, например, двоеточием (зависит от программы, которая будет интерпретировать их). Выглядит это так:

    

Если в значении имеются пробелы, его закрывают кавычками:

    

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

Выведем переменную оболочки и окружения

Просмотреть перечень локальных переменных можно по-разному. Например, с использованием printenv или env. Обе команды работают схожим образом:

    

Результат исполнения команды будет выведен на экран:

    

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

    

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

    

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

    

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

    

Результат исполнения представлен следующим образом:

    

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

    

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

    

Теперь команда отображает переменные. Для примера сравним выводимые данные командами set и env:

    

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

Типовые переменные окружения и оболочки

Рассмотрим наиболее востребованные переменные окружения и дадим краткое описание:

  • SHELL – описание оболочки, где интерпретируются вводимые команды – обычно это bash, но пользователь вправе указать иной способ;
  • TERM – указание вида терминала, используемого при старте;
  • USER – наименование аккаунта, который использовался для входа в систему;
  • PWD – рабочая папка;
  • OLDPWD – папка, используемая ранее (необходима для возможности вернуться в нее при помощи cd-);
  • LS_COLORS – коды, выделяющие различными цветами файлы в соответствии с их типом (для удобства восприятия больших объемов информации при беглом осмотре);
  • MAIL – путь, где размещен почтовый ящик активного аккаунта;
  • PATH – перечень папок, где система ищет команды;
  • LANG – поддерживаемый язык;
  • HOME – домашняя папка пользователя;
  • _ – команда, которую выполнила система последней.

Теперь рассмотрим популярные переменные оболочки:

  • BASHOPTS – опции, которые использовались при обращении к bash;
  • BASH_VERSION – текущая версия bash в понятном для чтения виде;
  • BASH_VERSINFO – то же, но в виде машинного кода;
  • COLUMNS – количество столбцов, которые надо отображать при выводе;
  • DIRSTACK – стек директорий, доступных командам pushd и popd;
  • HISTFILESIZE – количество строк, сохраняемых в журнале исполненных команд;
  • HISTSIZE – то же, но относится к лимиту хранения уже в памяти;
  • HOSTNAME – действующее имя сервера;
  • IFS – разделитель поля, без указания применяется пробел;
  • PS1 – вид приглашения при старте текущего сеанса;
  • PS2 – то же, но для случаев использования нескольких строк;
  • SHELLOPTS – опции, задаваемые командой set;
  • UID – ID активного аккаунта.

Настроим переменные оболочки и окружения

Перейдем к изучению различий переменных оболочки и окружения. Заодно познакомимся с синтаксисом их настройки.

Создадим переменную оболочки

Начнем с текущего сеанса. Все, что нам нужно сделать – внести имя и значение. Мы применим правила, предполагающие ввод заглавными буквами. Пример:

    

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

Чтобы подтвердить это, попробуем найти новую переменную:

    

Результат такой:

    

Повторим действие командой printenv:

    

Теперь на экране ничего нет. Значит, мы имеем дело не с переменной окружения. Перейдем к демонстрации метода открытия доступа к значению переменной.

    

В этом случае вывод будет таким:

    

Вывод простой – чтобы обратиться к значению переменной, достаточно добавить знак $. Откроем новый bash, чтобы проверить, передается ли информация «дочкам».

    

Значение не возвращается, это ожидаемо. Теперь вернемся к изначальной оболочке:

    

Создадим переменную окружения

На следующем этапе изучения преобразуем переменную из оболочки в окружение. Выполняется такая операция экспортом. Это выглядит так:

    

Чтобы подтвердить преобразование, введем:

    

Вывод следующий:

    

Отлично, переменная отображается. Проверим, произойдет ли то же в дочерней оболочке:

    

Видим следующее:

    

Все функционирует, как и предполагалось. Можно экспортировать переменную прямо из дочерней bash всего за один шаг:

    

Проверим результат экспорта:

    

Ожидаемый вывод:

    

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

    

Выясним, есть ли доступ к новой переменная оттуда:

    

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

Понижение и сброс переменных

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

    

Проверим результат:

    

Вывод следующий:

    

Можно целиком сбросить значения переменных:

    

После применения команды в ответ ничего не вернется:

    

Настроим переменные окружения при входе

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

Сеансы оболочки с входом и без него, интерактивные и не интерактивные

Оболочка bash считывает конфигурационные файлы исходя из способа запуска сеанса. Например, используют вариант с входом или без него. Первый способ старта предполагает аутентификацию пользователя перед активацией того же SSH-канала. Второй – это запуск внутри оболочки, куда уже вошли, например, запуск скрипта из командной строки.

Можно разделить сеансы оболочки на интерактивные и не интерактивные. Первый вариант – всегда прикреплен к терминалу. Второй, наоборот, не прикреплен к нему. Вернемся к разделению «вход – не вход». Варианты отличает еще и различный набор считываемых файлов. Так, при осуществлении входа система обращается сначала к файлу /etc/profile.

Затем будет осуществлен поиск конфигурационного файла в домашней директории пользователя, откуда оболочка считает его индивидуальные настройки. В списке – ~/.bash_profile, ~/.bash_login и ~/.profile/. Если речь идет об оболочке без входа, система обратится к файлу /etc/bash.bashrc, а следом к ~/.bashrc (важно учитывать, что /etc/bash.bashrc используется только в Debian и дистрибутивах, созданных на его основе). Подробнее читайте в официальной документации по Bash.

Реализуем переменные окружения

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

    

По умолчанию в нем уже содержится приличный объем информации. Большая ее часть относится к опциям bash, а не к переменным окружения. Зададим последние строкой:

    

Внутри файла ~/.bashrc можно разместить любые новые переменные окружения. Главное, после изменений согласиться с их сохранением. Теперь при каждом старте сеанса оболочки переменные будет объявляться автоматически (подробнее в мануале). Сейчас же мы считаем файл вручную:

    

Подготовили для вас выгодные тарифы на облачные серверы

Cloud MSK 15

477 ₽/мес

Процессор
1 x 3.3 ГГц
Память
1 ГБ
NVMe
15 ГБ
Канал
1 Гбит/с
Публичный IP
Cloud MSK 30

657 ₽/мес

Процессор
1 x 3.3 ГГц
Память
2 ГБ
NVMe
30 ГБ
Канал
1 Гбит/с
Публичный IP

Заключение

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

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

5460
9 минут чтения
Средний рейтинг статьи: 5
Хотите внести свой вклад?
Участвуйте в нашей контент-программе за
вознаграждение или запросите нужную вам инструкцию
img-server