summaryrefslogtreecommitdiff
path: root/lfs-12.1-sysv/chapter04/settingenvironment.html
diff options
context:
space:
mode:
Diffstat (limited to 'lfs-12.1-sysv/chapter04/settingenvironment.html')
-rw-r--r--lfs-12.1-sysv/chapter04/settingenvironment.html404
1 files changed, 404 insertions, 0 deletions
diff --git a/lfs-12.1-sysv/chapter04/settingenvironment.html b/lfs-12.1-sysv/chapter04/settingenvironment.html
new file mode 100644
index 0000000..e6a883e
--- /dev/null
+++ b/lfs-12.1-sysv/chapter04/settingenvironment.html
@@ -0,0 +1,404 @@
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <meta http-equiv="Content-Type" content="application/xhtml+xml; charset=utf-8" />
+ <title>
+ 4.4. Настройка окружения
+ </title>
+ <link rel="stylesheet" type="text/css" href="../stylesheets/lfs.css" />
+ <meta name="generator" content="DocBook XSL Stylesheets Vsnapshot" />
+ <link rel="stylesheet" href="../stylesheets/lfs-print.css" type=
+ "text/css" media="print" />
+ <meta name="viewport" content="width=device-width, initial-scale=1.0" />
+ </head>
+ <body class="lfs" id="lfs-12.1">
+ <div class="navheader">
+ <h4>
+ Линукс с нуля - Версия 12.1
+ </h4>
+ <h3>
+ Глава 4. Заключительный этап подготовки
+ </h3>
+ <ul>
+ <li class="prev">
+ <a accesskey="p" href="addinguser.html" title=
+ "Создание пользователя LFS">Пред.</a>
+ <p>
+ Создание пользователя LFS
+ </p>
+ </li>
+ <li class="next">
+ <a accesskey="n" href="aboutsbus.html" title=
+ "О SBU (Стандартная единица времени сборки)">След.</a>
+ <p>
+ О SBU (Стандартная единица времени сборки)
+ </p>
+ </li>
+ <li class="up">
+ <a accesskey="u" href="chapter04.html" title=
+ "Глава 4. Заключительный этап подготовки">Наверх</a>
+ </li>
+ <li class="home">
+ <a accesskey="h" href="../index.html" title=
+ "Линукс с нуля - Версия 12.1">Начало</a>
+ </li>
+ </ul>
+ </div>
+ <h1 class="sect1">
+ <a id="ch-preps-settingenviron" name="ch-preps-settingenviron"></a>4.4.
+ Настройка окружения
+ </h1>
+ <div class="sect1" lang="ru" xml:lang="ru">
+ <p>
+ Настроим хорошо работающее окружение, создав два новых файла запуска
+ для оболочки <span class="command"><strong>bash</strong></span>.
+ Войдя в систему как пользователь <code class="systemitem">lfs</code>,
+ введите следующую команду, чтобы создать новый <code class=
+ "filename">.bash_profile</code>:
+ </p>
+ <pre class="userinput"><kbd class=
+ "command">cat &gt; ~/.bash_profile &lt;&lt; "EOF"
+<code class=
+"literal">exec env -i HOME=$HOME TERM=$TERM PS1='\u:\w\$ ' /bin/bash</code>
+EOF</kbd></pre>
+ <p>
+ При входе в систему под учетной записью пользователя <code class=
+ "systemitem">lfs</code> или при переключении на <code class=
+ "systemitem">lfs</code>, используя команду <span class=
+ "command"><strong>su</strong></span> с опцией <span class=
+ "quote">«<span class="quote"><em class=
+ "parameter"><code>-</code></em></span>»</span>, начальная оболочка
+ представляет собой оболочку <span class=
+ "emphasis"><em>login</em></span>, которая читает данные из
+ <code class="filename">/etc/profile</code> хоста (который, вероятно,
+ содержит некоторые настройки и переменные среды), а затем
+ <code class="filename">.bash_profile</code>. Команда <span class=
+ "command"><strong>exec env -i.../bin/bash</strong></span> в файле
+ <code class="filename">.bash_profile</code> заменяет запущенную
+ оболочку новой, не содержащей переменные среды, за исключением
+ переменных <code class="envar">HOME</code>, <code class=
+ "envar">TERM</code>, и <code class="envar">PS1</code>. Это
+ гарантирует, что никакие нежелательные и потенциально опасные
+ переменные среды из хост-системы не попадут в среду сборки.
+ </p>
+ <p>
+ Новый экземпляр оболочки представляет собой <span class=
+ "emphasis"><em>non-login</em></span> оболочку, которая не считывает и
+ не выполняет содержимое файлов <code class=
+ "filename">/etc/profile</code> и <code class=
+ "filename">.bash_profile</code>, а вместо этого выполняет чтение из
+ файла <code class="filename">.bashrc</code>. Создайте файл
+ <code class="filename">.bashrc</code>:
+ </p>
+ <pre class="userinput"><kbd class=
+ "command">cat &gt; ~/.bashrc &lt;&lt; "EOF"
+<code class="literal">set +h
+umask 022
+LFS=/mnt/lfs
+LC_ALL=POSIX
+LFS_TGT=$(uname -m)-lfs-linux-gnu
+PATH=/usr/bin
+if [ ! -L /bin ]; then PATH=/bin:$PATH; fi
+PATH=$LFS/tools/bin:$PATH
+CONFIG_SITE=$LFS/usr/share/config.site
+export LFS LC_ALL LFS_TGT PATH CONFIG_SITE</code>
+EOF</kbd></pre>
+ <div class="variablelist">
+ <p class="title">
+ <strong>Значение настроек в <code class=
+ "filename">.bashrc</code></strong>
+ </p>
+ <dl class="variablelist">
+ <dt>
+ <span class="term"><em class="parameter"><code>set
+ +h</code></em></span>
+ </dt>
+ <dd>
+ <p>
+ Команда <span class="command"><strong>set +h</strong></span>
+ отключает хэш-функцию <span class=
+ "command"><strong>bash</strong></span>. Хеширование является
+ полезной функцией —<span class=
+ "command"><strong>bash</strong></span> использует хеш-таблицу
+ для запоминания полного пути к исполняемому файлу, чтобы
+ избежать многократного поиска одного и того же исполняемого
+ файла в переменной окружения <code class="envar">PATH</code>.
+ Однако новые инструменты требуется использовать сразу же после
+ их установки. Отключение хэш-функции, заставляет оболочку
+ искать переменную окружения <code class="envar">PATH</code>,
+ всякий раз, когда программу необходимо запустить. Таким
+ образом, оболочка найдет вновь скомпилированные инструменты в
+ <code class="filename">$LFS/tools/bin</code>, как только они
+ станут доступны, не запоминая предыдущую версию той же
+ программы, предоставленную хост-дистрибутивом, в <code class=
+ "filename">/usr/bin</code> или <code class=
+ "filename">/bin</code>.
+ </p>
+ </dd>
+ <dt>
+ <span class="term"><em class="parameter"><code>umask
+ 022</code></em></span>
+ </dt>
+ <dd>
+ <p>
+ Установка значения пользовательской маски создания файлов
+ (umask) 022 гарантирует, что вновь созданные файлы и каталоги
+ доступны для записи только их владельцу, но будут доступны для
+ чтения и выполнения остальным пользователям (при условии, что
+ системный вызов <a class="ulink" href=
+ "https://man.archlinux.org/man/open.2">open(2)</a> использует
+ режимы по умолчанию, новые файлы получат разрешения 644, а
+ каталоги 755).
+ </p>
+ </dd>
+ <dt>
+ <span class="term"><em class=
+ "parameter"><code>LFS=/mnt/lfs</code></em></span>
+ </dt>
+ <dd>
+ <p>
+ Переменная окружения <code class="envar">LFS</code> должна
+ указывать на выбранную точку монтирования.
+ </p>
+ </dd>
+ <dt>
+ <span class="term"><em class=
+ "parameter"><code>LC_ALL=POSIX</code></em></span>
+ </dt>
+ <dd>
+ <p>
+ Переменная <code class="envar">LC_ALL</code> управляет
+ локализацией определенных программ, и формирует сообщения в
+ соответствии с локализацией указанной страны. Установка в
+ <code class="envar">LC_ALL</code> значения <span class=
+ "quote">«<span class="quote">POSIX</span>»</span> или
+ <span class="quote">«<span class="quote">C</span>»</span> (они
+ эквивалентны) гарантирует, что все будет работать должным
+ образом в среде кросс-компиляции.
+ </p>
+ </dd>
+ <dt>
+ <span class="term"><em class="parameter"><code>LFS_TGT=$(uname
+ -m)-lfs-linux-gnu</code></em></span>
+ </dt>
+ <dd>
+ <p>
+ Переменная <code class="envar">LFS_TGT</code> устанавливает
+ нестандартное, но совместимое описание компьютера для
+ использования при создании кросс-компилятора и компоновщика, а
+ также при кросс-компиляции временного набора инструментов.
+ Дополнительная информация об этом представлена в <a class=
+ "xref" href="../partintro/toolchaintechnotes.html" title=
+ "Технические примечания по сборочным инструментам">Технические
+ примечания по сборочным инструментам</a>.
+ </p>
+ </dd>
+ <dt>
+ <span class="term"><em class=
+ "parameter"><code>PATH=/usr/bin</code></em></span>
+ </dt>
+ <dd>
+ <p>
+ Многие современные дистрибутивы Linux объединили <code class=
+ "filename">/bin</code> и <code class=
+ "filename">/usr/bin</code>. В этом случае стандартной
+ переменной <code class="envar">PATH</code> необходимо
+ установить значение <code class="filename">/usr/bin/</code> для
+ окружения из <a class="xref" href="../chapter06/chapter06.html"
+ title=
+ "Глава 6. Кросс-Компиляция временных инструментов">Глава&nbsp;6</a>.
+ Когда это не так, следующая строка добавит <code class=
+ "filename">/bin</code> к пути.
+ </p>
+ </dd>
+ <dt>
+ <span class="term"><em class="parameter"><code>if [ ! -L /bin ];
+ then PATH=/bin:$PATH; fi</code></em></span>
+ </dt>
+ <dd>
+ <p>
+ Если <code class="filename">/bin</code> не является
+ символической ссылкой, то его необходимо добавить в переменную
+ <code class="envar">PATH</code>.
+ </p>
+ </dd>
+ <dt>
+ <span class="term"><em class=
+ "parameter"><code>PATH=$LFS/tools/bin:$PATH</code></em></span>
+ </dt>
+ <dd>
+ <p>
+ Поместив <code class="filename">$LFS/tools/bin</code> перед
+ стандартным <code class="envar">PATH</code>, кросс-компилятор,
+ установленный в начале <a class="xref" href=
+ "../chapter05/chapter05.html" title=
+ "Глава 5. Сборка кросс-тулчейна">Глава&nbsp;5</a>, будет
+ обнаружен оболочкой сразу после его установки. Это, в сочетании
+ с отключением хеширования, ограничивает риск использования
+ компилятора хоста вместо кросс-компилятора.
+ </p>
+ </dd>
+ <dt>
+ <span class="term"><em class=
+ "parameter"><code>CONFIG_SITE=$LFS/usr/share/config.site</code></em></span>
+ </dt>
+ <dd>
+ <p>
+ В <a class="xref" href="../chapter05/chapter05.html" title=
+ "Глава 5. Сборка кросс-тулчейна">Глава&nbsp;5</a> и <a class=
+ "xref" href="../chapter06/chapter06.html" title=
+ "Глава 6. Кросс-Компиляция временных инструментов">Глава&nbsp;6</a>,
+ если эта переменная не задана, сценарии <span class=
+ "command"><strong>configure</strong></span> могут попытаться
+ загрузить элементы конфигурации, специфичные для некоторых
+ дистрибутивов, из <code class=
+ "filename">/usr/share/config.site</code> в хост-системе.
+ Переопределите её, чтобы предотвратить потенциальное влияние
+ хоста.
+ </p>
+ </dd>
+ <dt>
+ <span class="term"><em class="parameter"><code>export
+ ...</code></em></span>
+ </dt>
+ <dd>
+ <p>
+ Приведенные выше команды установили некоторые переменные, чтобы
+ сделать их видимыми в любых вложенных оболочках, мы
+ экспортируем их.
+ </p>
+ </dd>
+ </dl>
+ </div>
+ <div class="admon important">
+ <img alt="[Важно]" src="../images/important.png" />
+ <h3>
+ Важно
+ </h3>
+ <p>
+ Некоторые коммерческие дистрибутивы добавляют недокументированный
+ экземпляр <code class="filename">/etc/bash.bashrc</code> для
+ инициализации <span class="command"><strong>bash</strong></span>.
+ Этот файл потенциально может изменить среду пользователя
+ <code class="systemitem">lfs</code> таким образом, что это может
+ повлиять на сборку важных пакетов LFS. Чтобы убедиться, что
+ пользовательская среда <code class="systemitem">lfs</code> чиста,
+ проверьте наличие файла <code class=
+ "filename">/etc/bash.bashrc</code> и, если он есть, переименуйте
+ его. От имени пользователя <code class="systemitem">root</code>,
+ запустите:
+ </p>
+ <pre class="userinput"><kbd class=
+ "command">[ ! -e /etc/bash.bashrc ] || mv -v /etc/bash.bashrc /etc/bash.bashrc.NOUSE</kbd></pre>
+ <p>
+ Когда пользователь <code class="systemitem">lfs</code> больше не
+ нужен (в начале <a class="xref" href="../chapter07/chapter07.html"
+ title=
+ "Глава 7. Вход в окружение Chroot и создание дополнительных временных инструментов">
+ Глава&nbsp;7</a> ) вы можете безопасно восстановить <code class=
+ "filename">/etc/bash.bashrc</code> (по желанию).
+ </p>
+ <p>
+ Обратите внимание, что пакет LFS Bash, который мы создадим в
+ <a class="xref" href="../chapter08/bash.html" title=
+ "8.35. Bash-5.2.21">Раздел&nbsp;8.35, «Bash-5.2.21»</a>, не
+ настроен на загрузку или выполнение <code class=
+ "filename">/etc/bash.bashrc</code>, поэтому этот файл бесполезен в
+ готовой системе LFS.
+ </p>
+ </div>
+ <p>
+ Для многих современных систем с несколькими процессорами (или ядрами)
+ время компиляции пакета можно сократить, выполнив <span class=
+ "quote">«<span class="quote">параллельную сборку</span>»</span>, либо
+ установив переменную среды, либо сообщив программе <span class=
+ "command"><strong>make</strong></span>, сколько ядер задействовать
+ для сборки. Например, процессор Intel Core i9-13900K имеет 8 ядер P
+ (производительность) и 16 ядер E (энергоэффективность), ядро P может
+ одновременно запускать два потока, поэтому каждое ядро P моделируется
+ ядром Linux как два логических ядра. В результате получается 32
+ логических ядра. Очевидный способ задействовать все эти логические
+ ядра - разрешить <span class="command"><strong>make</strong></span>
+ создавать до 32 заданий сборки. Это можно сделать, передав параметр
+ <em class="parameter"><code>-j32</code></em> команде <span class=
+ "command"><strong>make</strong></span>:
+ </p>
+ <pre class="userinput"><kbd class="command">make -j32</kbd></pre>
+ <p>
+ Или установите переменную окружения <code class=
+ "envar">MAKEFLAGS</code>, и ее содержимое будет автоматически
+ использоваться <span class="command"><strong>make</strong></span> в
+ качестве параметров командной строки:
+ </p>
+ <pre class="userinput"><kbd class=
+ "command">export MAKEFLAGS=-j32</kbd></pre>
+ <div class="admon important">
+ <img alt="[Важно]" src="../images/important.png" />
+ <h3>
+ Важно
+ </h3>
+ <p>
+ Никогда не передавайте параметр <em class=
+ "parameter"><code>-j</code></em> без номера в <span class=
+ "command"><strong>make</strong></span> и не устанавливайте такой
+ параметр в <code class="envar">MAKEFLAGS</code>. Иначе <span class=
+ "command"><strong>make</strong></span> будет создавать бесконечные
+ задания сборки, что вызовет проблемы со стабильностью системы.
+ </p>
+ </div>
+ <p>
+ Чтобы использовать все логические ядра, доступные для сборки пакетов
+ в <a class="xref" href="../chapter05/chapter05.html" title=
+ "Глава 5. Сборка кросс-тулчейна">Глава&nbsp;5</a> и <a class="xref"
+ href="../chapter06/chapter06.html" title=
+ "Глава 6. Кросс-Компиляция временных инструментов">Глава&nbsp;6</a>,
+ укажите параметр <code class="envar">MAKEFLAGS</code> в <code class=
+ "filename">.bashrc сейчас</code>:
+ </p>
+ <pre class="userinput"><kbd class=
+ "command">cat &gt;&gt; ~/.bashrc &lt;&lt; "EOF"
+<code class="literal">export MAKEFLAGS=-j<em class=
+"replaceable"><code>$(nproc)</code></em></code>
+EOF</kbd></pre>
+ <p>
+ Замените <em class="replaceable"><code>$(nproc)</code></em>
+ количеством логических ядер, которые вы хотите использовать, если вы
+ планируете использовать не все логические ядра.
+ </p>
+ <p>
+ Наконец, чтобы убедиться, что среда полностью подготовлена для сборки
+ временных инструментов, перечитайте только что созданный профиль
+ пользователя:
+ </p>
+ <pre class="userinput"><kbd class=
+ "command">source ~/.bash_profile</kbd></pre>
+ </div>
+ <div class="navfooter">
+ <ul>
+ <li class="prev">
+ <a accesskey="p" href="addinguser.html" title=
+ "Создание пользователя LFS">Пред.</a>
+ <p>
+ Создание пользователя LFS
+ </p>
+ </li>
+ <li class="next">
+ <a accesskey="n" href="aboutsbus.html" title=
+ "О SBU (Стандартная единица времени сборки)">След.</a>
+ <p>
+ О SBU (Стандартная единица времени сборки)
+ </p>
+ </li>
+ <li class="up">
+ <a accesskey="u" href="chapter04.html" title=
+ "Глава 4. Заключительный этап подготовки">Наверх</a>
+ </li>
+ <li class="home">
+ <a accesskey="h" href="../index.html" title=
+ "Линукс с нуля - Версия 12.1">Начало</a>
+ </li>
+ </ul>
+ </div>
+ </body>
+</html>