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

Различия

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

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

Предыдущая версия справа и слева Предыдущая версия
Следующая версия
Предыдущая версия
wiki:programs_installation [2012/05/29 20:25]
СперанскийСперанскийСперанскийDictum ac factum [Сборка пакета]
wiki:programs_installation [2014/03/13 17:39] (текущий)
FantineyFantineyFantiney [Ссылки] +ссылка
Строка 1: Строка 1:
-====== Компиляция и установка программ из исходных текстов======+====== Компиляция и установка программ из исходников======
 Не редко необходимые пакеты можно найти только в виде исходных текстов,​ в данной статье описывается метод установки пакета из исходных текстов. Не редко необходимые пакеты можно найти только в виде исходных текстов,​ в данной статье описывается метод установки пакета из исходных текстов.
 ======Распаковка====== ======Распаковка======
Строка 13: Строка 13:
 Например,​ команда <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** определяет метод сжатия автоматически и дополнительных опций в данном случае не требуется. Например,​ команда <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** определяет метод сжатия автоматически и дополнительных опций в данном случае не требуется.
  
 +После распаковки необходимо перейти в полученный каталог,​ все описываемые ниже команды выполняются в каталоге с исходными текстами пакета.
 +<code bash>cd <​имя_пакета>​*</​code>​
 ======Сборка пакета====== ======Сборка пакета======
 Для сборки программ в GNU/Linux используется (в основном) программа **make**, которая запускает инструкции из **Makefile**,​ но поскольку дистрибутивов GNU/Linux много, и они все разные,​ то для того чтобы собрать программу,​ нужно для каждого дистрибутива отдельно прописывать пути,​где какие лежат библиотеки и заголовочные файлы. Программисты не могут изучать каждый дистрибутив и для каждого отдельно создавать **Makefile**. Поэтому придумали конфигураторы,​ которые "​изучают"​ систему,​ и в соответствии с полученными знаниями создают **Makefile**. Но на конфигураторе они не остановились и придумали конфигураторы конфигураторов =)...на этом они остановились :-) Для сборки программ в GNU/Linux используется (в основном) программа **make**, которая запускает инструкции из **Makefile**,​ но поскольку дистрибутивов GNU/Linux много, и они все разные,​ то для того чтобы собрать программу,​ нужно для каждого дистрибутива отдельно прописывать пути,​где какие лежат библиотеки и заголовочные файлы. Программисты не могут изучать каждый дистрибутив и для каждого отдельно создавать **Makefile**. Поэтому придумали конфигураторы,​ которые "​изучают"​ систему,​ и в соответствии с полученными знаниями создают **Makefile**. Но на конфигураторе они не остановились и придумали конфигураторы конфигураторов =)...на этом они остановились :-)
Строка 18: Строка 20:
 Для сборки нам нужны компиляторы:​ они прописаны в зависимостях пакета **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**. Теперь всё скомпилировано и готово для установки.
 ======Установка====== ======Установка======
 Усилия потраченные на ''​Правильную установку''​ в последствии с лихвой окупятся в случае удаления или обновления устанавливаемого программного обеспечения. Усилия потраченные на ''​Правильную установку''​ в последствии с лихвой окупятся в случае удаления или обновления устанавливаемого программного обеспечения.
-=====Правильная установка(checkinstall)===== +=====Правильная установка(Вариант №1)===== 
-<note important>​Данная утилита, будучи запущенной вместо make install задаст несколько вопросов, ​после чего сама соберёт и установит deb-пакет. При обновлении никаких ​проблем с вычисткой старого хлама у вас не будет. ​ +Установка при помощи утилиты **checkinstall**. Для ​установки выполните 
-Минус данного способа:​ **checkinstall** понимает не все исходники,​ поскольку автор программы может написать особые скрипты по установке и **checkinstall** их не поймёт.</​note>​+<code bash>​sudo apt-get install checkinstall</​code>​ 
 +<note important>​Минус данного способа:​ **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
Строка 52: Строка 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 ​important>​Минус данного способа заключается в том, что если вы устанавливаете напрямую через make install, то нормально удалить или обновить пакет вы, скорее всего, не сможете. Более того, установка новой версии поверх старой,​ скорее всего, затрёт ваши изменения в конфигах. make install делает ровно то, что ему сказано — производит установку файлов в нужные места, игнорируя тот факт, что там что-то уже есть. После этого процесса совершенно никакой информации о том, что и куда ставилось,​ получить в удобоваримом виде невозможно. Иногда,​ конечно,​ Makefile поддерживает действие uninstall, но это встречается не так часто, да и не факт, что корректно работает. Кроме того, вам будет необходимо хранить для деинсталяции распакованное дерево исходников и правил сборки.</​note>​+<​note ​warning>​Минус данного способа заключается в том, что если вы устанавливаете напрямую через make install, то нормально удалить или обновить пакет вы, скорее всего, не сможете. Более того, установка новой версии поверх старой,​ скорее всего, затрёт ваши изменения в конфигах. make install делает ровно то, что ему сказано — производит установку файлов в нужные места, игнорируя тот факт, что там что-то уже есть. После этого процесса совершенно никакой информации о том, что и куда ставилось,​ получить в удобоваримом виде невозможно. Иногда,​ конечно,​ Makefile поддерживает действие uninstall, но это встречается не так часто, да и не факт, что корректно работает. Кроме того, вам будет необходимо хранить для деинсталяции распакованное дерево исходников и правил сборки.</​note>​
 Для установки необходимо выполнить Для установки необходимо выполнить
 <code bash>​sudo make install</​code>​ <code bash>​sudo make install</​code>​
 Для удаления пакета,​ установленного данным способом необходимо выполнить в корневой директории исходников программы (там где вы запускали make install). Для удаления пакета,​ установленного данным способом необходимо выполнить в корневой директории исходников программы (там где вы запускали make install).
-<code bash>​make uninstall</​code> ​+<code bash>sudo make uninstall</​code> ​
 ======Ошибки====== ======Ошибки======
 Часто на этапе конфигурации конфигуратор сообщает,​ что нехватает той или иной библиотеки. Название библиотеки,​ которое он сообщает,​ не всегда соответствует названию пакета в Ubuntu. Из собственного опыта могу посоветовать поискать в [[wiki:​synaptic|Синаптике]] нужный пакет, исключив префикс lib, если нашлось несколько пакетов различающихся приставкой -dev в названии,​ то вам нужно установить именно -dev пакет (обычно он тянет за собой и не -dev пакет). Часто на этапе конфигурации конфигуратор сообщает,​ что нехватает той или иной библиотеки. Название библиотеки,​ которое он сообщает,​ не всегда соответствует названию пакета в Ubuntu. Из собственного опыта могу посоветовать поискать в [[wiki:​synaptic|Синаптике]] нужный пакет, исключив префикс lib, если нашлось несколько пакетов различающихся приставкой -dev в названии,​ то вам нужно установить именно -dev пакет (обычно он тянет за собой и не -dev пакет).
Строка 87: Строка 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 установка компиляция программирование ​исходники}}