Компиляция и установка программ из исходников Сравнение версий

Различия

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

Ссылка на это сравнение

Предыдущая версия справа и слева Предыдущая версия
Следующая версия
Предыдущая версия
wiki:programs_installation [2012/05/29 20:16]
[Правильная установка(создание deb-пакета)]
wiki:programs_installation [2014/03/13 17:39] (текущий)
[Ссылки] +ссылка
Строка 1: Строка 1:
-====== Компиляция и установка программ из исходников ====== +====== Компиляция и установка программ из исходников====== 
 +Не редко необходимые пакеты можно найти только в виде исходных текстов,​ в данной статье описывается метод установки пакета из исходных текстов.
 ======Распаковка====== ======Распаковка======
 Программы обычно распространяются в упакованных архивах,​ это файлы с расширениями <​code><​some_app_name>​.tar.gz ​ (иногда .tgz) Программы обычно распространяются в упакованных архивах,​ это файлы с расширениями <​code><​some_app_name>​.tar.gz ​ (иногда .tgz)
Строка 10: Строка 10:
 Данный файл по размеру будет чуть больше,​ чем суммарный размер файлов,​ которые были архивированы. Поэтому (а может и по другой причине) используют упаковщики - программы,​ которые позволяют уменьшить размер файла без потери данных. Данный файл по размеру будет чуть больше,​ чем суммарный размер файлов,​ которые были архивированы. Поэтому (а может и по другой причине) используют упаковщики - программы,​ которые позволяют уменьшить размер файла без потери данных.
  
-Не многие упаковщики умеют работать с несколькими файлами,​ но зато с одним справляются на ура. Результатом работы упаковщика **gzip** будет файл с расширением **.gz**. Так, файл, заканчивающийся на **.tar.gz** - это результат работы двух программ+Программа **tar** умеет распаковывать,​ поэтому не нужно вызывать **gunzip**, а можно просто указать программе **tar**, что файл нужно cначала распаковать. 
- +Например,​ команда <code bash>tar -xvf <​some_app_name>​.tar.gz</​code>​сразу распакует и разархивирует. Отличие файлов с расширениями<​code><​some_app_name>​.tar.gz</​code>​и<​code><​some_app_name>​.tar.bz2</​code>​лишь в том, что использовались разные упаковщики, ​программа **tar** определяет метод ​сжатия автоматически и дополнительных опций в данном случае не требуется.
-**tar.gz** ​аналогичен файлу с расширением **.zip**, только **.zip** не позволяет сохранить все атрибуты и права доступа. +
-Таким образом,​ чтобы распаковать файл **.tar.gz**,​ нужно воспользоваться двумя программами. **gunzip** распакует файл, например,​ с помощью команды <code bash>​gunzip -d <​some_app_name>​.tar.gz</​code>​в результате получим файл<​code><​some_app_name>​.tar</​code>​ +
-а команда <code bash>tar -x  <​some_app_name>​.tar</​code>​ разархивирует его. +
- +
-К счастью для нас, GNU-версия программы ​**tar** умеет распаковывать,​ поэтому не нужно вызывать **gunzip**, а можно просто указать программе **tar**, что файл нужно cначала распаковать. +
-Например,​ команда <code bash>tar -z -x <​some_app_name>​.tar.gz</​code>​сразу распакует и разархивирует. Отличие файлов с расширениями<​code><​some_app_name>​.tar.gz</​code>​и<​code><​some_app_name>​.tar.bz2</​code>​лишь в том, что использовались разные упаковщики, ​для второго файла использовалась команда **bzip2**. Для распаковки <​some_app_name>​.tar.bz2 ​ можно выполнить ​команду<code bash>tar -j -x <​some_app_name>​.tar.bz2</​code>​+
  
 +После распаковки необходимо перейти в полученный каталог,​ все описываемые ниже команды выполняются в каталоге с исходными текстами пакета.
 +<code bash>cd <​имя_пакета>​*</​code>​
 ======Сборка пакета====== ======Сборка пакета======
 Для сборки программ в GNU/Linux используется (в основном) программа **make**, которая запускает инструкции из **Makefile**,​ но поскольку дистрибутивов GNU/Linux много, и они все разные,​ то для того чтобы собрать программу,​ нужно для каждого дистрибутива отдельно прописывать пути,​где какие лежат библиотеки и заголовочные файлы. Программисты не могут изучать каждый дистрибутив и для каждого отдельно создавать **Makefile**. Поэтому придумали конфигураторы,​ которые "​изучают"​ систему,​ и в соответствии с полученными знаниями создают **Makefile**. Но на конфигураторе они не остановились и придумали конфигураторы конфигураторов =)...на этом они остановились :-) Для сборки программ в GNU/Linux используется (в основном) программа **make**, которая запускает инструкции из **Makefile**,​ но поскольку дистрибутивов GNU/Linux много, и они все разные,​ то для того чтобы собрать программу,​ нужно для каждого дистрибутива отдельно прописывать пути,​где какие лежат библиотеки и заголовочные файлы. Программисты не могут изучать каждый дистрибутив и для каждого отдельно создавать **Makefile**. Поэтому придумали конфигураторы,​ которые "​изучают"​ систему,​ и в соответствии с полученными знаниями создают **Makefile**. Но на конфигураторе они не остановились и придумали конфигураторы конфигураторов =)...на этом они остановились :-)
  
-Для сборки нам нужны компиляторы:​ они прописаны в зависимостях пакета **build-essential**,​ так что достаточно установить его со всеми зависимостями. Ещё нужны **autoconf** и все ​automake ​которые найдёте :-).+Для сборки нам нужны компиляторы:​ они прописаны в зависимостях пакета **build-essential**,​ так что достаточно установить его со всеми зависимостями. Ещё нужны **autoconf** и **automake**.
  
-Итак, чтобы собрать что-то из исходников,​ нужно сначала собрать конфигуратор;​ как собрать конфигуратор,​ описано в файле configure.in. ​А собирается ​конфигуратор ​следующими командами<​code>​bootstrap</​code><​code>​autogen.sh</​code>​т.е. достаточно запустить этот ​скрипт. А если ​нет скриптов bootstrap или autogen.sh, то можно выполнить последовательно следующие команды:<​code bash>​aclocal+Итак, чтобы собрать что-то из исходников,​ нужно сначала собрать конфигуратор;​ как собрать конфигуратор,​ описано в файле configure.in. 
 +Для ​сборки конфигуратора необходимо ​выполнить<​code ​bash>./bootstrap</​code> ​или ​<​code ​bash>./autogen.sh</​code> ​Если таких скриптов в архиве не оказалось, то можно выполнить последовательно следующие команды:<​code bash>​aclocal
 autoheader autoheader
 automake --gnu --add-missing --copy --foreign automake --gnu --add-missing --copy --foreign
-autoconf -f -Wall</​code>​Все эти команды используют файл **configure.in**. После выполнения этих команд создастся файл **configure**. ​Вот теперь если ​вы запустите конфигуратор ​командой <code bash>​./​configure</​code>​(находясь ​в папке с исходными ​кодами), он проанализирует вашу ​системуи сообщит,​ чего хватает/не хватает. Возможно покажет, какие опции будущей ​программы будут доступны и/или пути, куда будет установлена скомпилированная программа (после выполнения **make install**). Конфигуратор построит Makefile основываясь на полученных знаниях и файле **makefile.am**. Можно передать конфигуратору опции, предусмотренные в исходниках программы,​ которые позволяют включать/​отключать те или иные возможности программы,​ обычно узнать о них можно командой <code bash>​./​configure --help</​code>​Также есть набор стандартных опций, вроде <​file>​--prefix=</​file>​ , которая указывает,​ какой каталог использовать для установки. Для Ubuntu обычно <code bash>​--prefix=/​usr</​code>​или<​code bash>​--prefix=/​usr/​local</​code>​**БЕЗ** слеша в конце!+autoconf -f -Wall</​code>​Все эти команды используют файл **configure.in**. ​ 
 +После выполнения этих команд создастся файл **configure**. ​После этого необходимо запустить конфигуратор для проверки наличия всех зависимостей, а также установки дополнительных ​опций сборки (если возможно) ​и просмотра результата установки (опциональноможет не быть 
 +<code bash>./​configure</​code>​ 
 +Конфигуратор построит Makefile основываясь на полученных знаниях и файле **makefile.am**. Можно передать конфигуратору опции, предусмотренные в исходниках программы,​ которые позволяют включать/​отключать те или иные возможности программы,​ обычно узнать о них можно командой <code bash>​./​configure --help</​code>​Также есть набор стандартных опций, вроде <​file>​--prefix=</​file>​ , которая указывает,​ какой каталог использовать для установки. Для Ubuntu обычно <code bash>​--prefix=/​usr</​code>​или<​code bash>​--prefix=/​usr/​local</​code>​**БЕЗ** слеша в конце!
 Теперь можно запустить процесс сборки самой программы командой <code bash>​make</​code>​Для сборки достаточно привелегий обычного пользователя. Окончанием сборки можно считать момент,​ когда команды в [[doc:​консоль|консоли]] перестанут "​беспорядочно"​ выполняться и не будет слова **error**. Теперь всё скомпилировано и готово для установки. Теперь можно запустить процесс сборки самой программы командой <code bash>​make</​code>​Для сборки достаточно привелегий обычного пользователя. Окончанием сборки можно считать момент,​ когда команды в [[doc:​консоль|консоли]] перестанут "​беспорядочно"​ выполняться и не будет слова **error**. Теперь всё скомпилировано и готово для установки.
 ======Установка====== ======Установка======
-=====Неправильная установка===== +Усилия потраченные на ''​Правильную установку'' ​в последствии с лихвой окупятся в случае ​удаления или обновления устанавливаемого программного обеспечения
-<note important>​Минус данного способа заключается в том, что если вы устанавливаете напрямую ​через make install, то нормально удалить или обновить пакет вы, скорее всего, ​не сможете. Более того, установка новой версии поверх старой, скорее ​всего, затрёт ваши изменения в конфигах. make install делает ровно то, что ему сказано — производит ​установку ​файлов в нужные места, игнорируя тот факт, что там что-то уже есть. После ​этого процесса совершенно никакой информации о том, что и куда ставилось, получить в удобоваримом виде невозможно. Иногда, ​конечно,​ Makefile ​поддерживает действие uninstall, но это ​встречается не так часто, ​да и не факт, что корректно работает. Кроме того, вам будет необходимо хранить для деинсталяции распакованное дерево исходников и правил сборки.</​note>​ +=====Правильная установка(Вариант №1)===== 
-Для установки необходимо выполнить +Установка при помощи утилиты **checkinstall**. Для ​установки выполните 
-<code bash>​sudo make install</​code>​ +<code bash>​sudo apt-get install checkinstall</​code>​ 
-Для удаления ​пакета, ​установленного данным способом необходимо ​выполнить в корневой директории исходников ​программы (там ​где вы запускали make install). +<note important>​Минус данного способа:​ **checkinstall** понимает не все исходники,​ поскольку автор программы может написать особые скрипты по установке и **checkinstall** их не поймёт.</​note>​
-<code bash>​make uninstall</​code> ​ +
-=====Правильная установка(checkinstall)===== +
-<note important>​Данная утилита, будучи запущенной вместо make install задаст несколько вопросов, ​после чего сама соберёт и установит deb-пакет. При обновлении никаких ​проблем с вычисткой старого хлама у вас не будет. ​ +
-Минус данного способа:​ **checkinstall** понимает не все исходники,​ поскольку автор программы может написать особые скрипты по установке и **checkinstall** их не поймёт.</​note>​+
 Для создания и установки deb-пакета необходимо выполнить Для создания и установки deb-пакета необходимо выполнить
-<code bash>​checkinstall</​code>​ +<code bash>sudo checkinstall</​code>​ 
-=====Правильная установка(создание deb-пакета в ручную)===== +=====Правильная установка(Вариант №2)===== 
-<note important>​Основное отличие от предыдущего способа заключается в том, что в данном случае вы создаете пакет вручную и отслеживаете все вносимые изменения. Так же этот способ подойдет вам, если исходники не поддерживают сборку пакета с checkinstall.</​note>​+Быстрое ​создание deb-пакета ​"вручную". 
 +<note important>​Основное отличие от предыдущего способа заключается в том, что в данном случае вы создаете пакет вручную и отслеживаете все вносимые изменения. Так же этот способ подойдет вам, если исходники не поддерживают сборку пакета с **checkinstall**.</​note>​
   * Производим установку во временную директорию,​ где получаем весь набор устанавливаемых файлов:​   * Производим установку во временную директорию,​ где получаем весь набор устанавливаемых файлов:​
 <code bash>​fakeroot <code bash>​fakeroot
Строка 63: Строка 60:
   * Получаем на выходе tempinstall.deb,​ который и устанавливаем ​   * Получаем на выходе tempinstall.deb,​ который и устанавливаем ​
 <code bash>​sudo dpkg -i tempinstall.deb</​code>​ <code bash>​sudo dpkg -i tempinstall.deb</​code>​
 +=====Установка (вариант №3)=====
 +Процедура создания deb-пакета подробно описана в данной [[wiki:​создание_deb_пакетов|статье]].
 +=====Неправильная установка=====
 +<note warning>​Минус данного способа заключается в том, что если вы устанавливаете напрямую через make install, то нормально удалить или обновить пакет вы, скорее всего, не сможете. Более того, установка новой версии поверх старой,​ скорее всего, затрёт ваши изменения в конфигах. make install делает ровно то, что ему сказано — производит установку файлов в нужные места, игнорируя тот факт, что там что-то уже есть. После этого процесса совершенно никакой информации о том, что и куда ставилось,​ получить в удобоваримом виде невозможно. Иногда,​ конечно,​ Makefile поддерживает действие uninstall, но это встречается не так часто, да и не факт, что корректно работает. Кроме того, вам будет необходимо хранить для деинсталяции распакованное дерево исходников и правил сборки.</​note>​
 +Для установки необходимо выполнить
 +<code bash>​sudo make install</​code>​
 +Для удаления пакета,​ установленного данным способом необходимо выполнить в корневой директории исходников программы (там где вы запускали make install).
 +<code bash>​sudo make uninstall</​code> ​
 ======Ошибки====== ======Ошибки======
 Часто на этапе конфигурации конфигуратор сообщает,​ что нехватает той или иной библиотеки. Название библиотеки,​ которое он сообщает,​ не всегда соответствует названию пакета в Ubuntu. Из собственного опыта могу посоветовать поискать в [[wiki:​synaptic|Синаптике]] нужный пакет, исключив префикс lib, если нашлось несколько пакетов различающихся приставкой -dev в названии,​ то вам нужно установить именно -dev пакет (обычно он тянет за собой и не -dev пакет). Часто на этапе конфигурации конфигуратор сообщает,​ что нехватает той или иной библиотеки. Название библиотеки,​ которое он сообщает,​ не всегда соответствует названию пакета в Ubuntu. Из собственного опыта могу посоветовать поискать в [[wiki:​synaptic|Синаптике]] нужный пакет, исключив префикс lib, если нашлось несколько пакетов различающихся приставкой -dev в названии,​ то вам нужно установить именно -dev пакет (обычно он тянет за собой и не -dev пакет).
Строка 92: Строка 97:
 ====== Ссылки ====== ====== Ссылки ======
  
-Обсуждение проблем с компиляцией и установкой программ в Ubuntu на форуме [[http://​forum.ubuntu.ru/​index.php?​board=13.0|forum.ubuntu.ru]]+  * Обсуждение проблем с компиляцией и установкой программ в Ubuntu на форуме [[http://​forum.ubuntu.ru/​index.php?​board=13.0|forum.ubuntu.ru]] 
 +  * Внесены изменения по мотивам [[http://​habrahabr.ru/​post/​130868/​|Хабрахабр]] 
 +  * [[http://​habrahabr.ru/​post/​78094/​|Подробной HowTo по сборке бинарных deb пакетов]]
  
-{{tag>​Howto установка компиляция программирование}}+{{tag>​Howto установка компиляция программирование ​исходники}}