metaclass: (Default)
metaclass ([personal profile] metaclass) wrote2009-05-09 01:32 am

фиг там спать с этими вашими линуксами

А вот скажите мне, как в линуксе ищутся shared object, то бишь библиотеки?
Не могу понять, как получается, что там где я собрал Qt креатором проект, он работает, а на другом дебиане - нет. Пишет, что не может загрузить libQtSql.so.4

ldd выдает отличающиется списки используемых либ:

libQtSql.so.4 => not found
libQtGui.so.4 => not found
libQtNetwork.so.4 => not found
libQtCore.so.4 => not found


libQtSql.so.4 => /home/user/qtsdk-2009.02/qt/lib/libQtSql.so.4 (0xb7ebe000)
libQtGui.so.4 => /home/user/qtsdk-2009.02/qt/lib/libQtGui.so.4 (0xb74a4000)
libQtNetwork.so.4 => /home/user/qtsdk-2009.02/qt/lib/libQtNetwork.so.4 (0xb7178000)
libQtCore.so.4 => /home/user/qtsdk-2009.02/qt/lib/libQtCore.so.4 (0xb6f25000)

По аналогии с вендой - скопировал нужные либы в папку к проге - фиг, все равно не видит :)


Установка qt либ из репозитория не помогла - ldd теперь их видит, но прога не работает - версия либ (4.2) раньше той на которой я прогу собирал (4.5)

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

А вот если я захочу вместо Qt4.2 поставить Qt4.5, сломается что нибудь в системе или нет? И как это сделать, не поломав голову менеджеру пакетов?

[identity profile] qehgt.livejournal.com 2009-05-08 10:44 pm (UTC)(link)
LD_LIBRARY_PATH установи

[identity profile] nolar.livejournal.com 2009-05-08 10:54 pm (UTC)(link)
Коммент выше, или поправь /etc/ld.so.conf + /etc/ld.so.conf.d/*.conf
И man ldconfig в тему этого

[identity profile] metaclass.livejournal.com 2009-05-08 10:58 pm (UTC)(link)
Да, это дело я уже только что прочитал.

[personal profile] alll 2009-05-08 11:50 pm (UTC)(link)
Емнип, когда-то помогала перезагрузка ldconfig, если библиотеки только что установленные.

[identity profile] max-posedon.livejournal.com 2009-05-09 02:58 am (UTC)(link)
LD_LIBRARY_PATH=. (умолчание в windows), это пиздец и антигуманно, посмотрите на msvc-шный runtime, для его такое отключили, и не просто так.

[identity profile] metaclass.livejournal.com 2009-05-09 06:16 am (UTC)(link)
Пиздец - это отсутствие такой функции.
Почему микрософт пошел по тому же пути - вопрос достаточно сложный, помнится мне, ВСЕ пользователи Firebird в гугл-группе попросили разработчиков отломать нахер это от embedded engine, который часто используется в таком же стиле, как я хотел запустить эту прогу, т.н. xcopy deployment.
Впрочем, на эту тему тут уже неоднократно, кажется, спорили. Похоже, никто не понимает, зачем писать программы, изолированные и запускающиеся независимо от основной системы, т.к. редко сталкиваются с деплойментом прог в реальных условиях.

[identity profile] ykaliuta.livejournal.com 2009-05-09 07:22 am (UTC)(link)
вообще man ld.so

[identity profile] blacklion.livejournal.com 2009-05-09 07:24 am (UTC)(link)
По аналогии с вендой - скопировал нужные либы в папку к проге - фиг, все равно не видит :)
Гы-гы.
Ищет он в том, что при старте системы сказали ldconfig'у и там, где ты поставил переменную окружения LD_LIBRARY_PATH

[identity profile] blacklion.livejournal.com 2009-05-09 07:25 am (UTC)(link)
Пиздец - это отсутствие такой функции.
Ну, и явной точки нету в PATH тоже. Это гибче — добавь system-wide LD_LIBRARY_PATH=. и будет как в винде. А теперь сделай в винде наоборот :)

[identity profile] blacklion.livejournal.com 2009-05-09 07:26 am (UTC)(link)
А ещё негуманно что у винды PATH и LD_LIBRARY_PATH — одно и то же. В результате от сортировки PATH зависит где возмётся библиотека.

[identity profile] blacklion.livejournal.com 2009-05-09 07:27 am (UTC)(link)
Похоже, никто не понимает, зачем писать программы, изолированные и запускающиеся независимо от основной системы, т.к. редко сталкиваются с деплойментом прог в реальных условиях.
Понимаешь, эта задача в *IX решается шелл-скриптом на 10 строк. А вот в винде ничего ты изменить не можешь — как есть так и есть.

[identity profile] zamotivator.livejournal.com 2009-05-10 09:33 am (UTC)(link)
Вместо Qt4.2 поставить Qt4.5

Ничего не сломается. У Qt ABI совместимость в рамках мажорной ветки

[identity profile] metaclass.livejournal.com 2009-05-10 11:25 am (UTC)(link)
4.5 за собой тянет зависимость от GLIBC_2.4, если не принимать специальных мер. Т.е. с Qt самим я уже разобрался, а вот что делать с glibc пока неясно. Если менять LD_LIBRARY_PATH - валится с сегфолтом, нужно либо разбираться более подробно, либо убирать зависимости.

[identity profile] zamotivator.livejournal.com 2009-05-10 11:39 am (UTC)(link)
glibc менять это как бы очень хреново.
Либо статическая сборка (плохо для LGPL) либо смириться с более раней версией glibc, либо удовлетворяться тестируемым репозитарием (lили lenny), либо искать обходные пути типа LD_LIBRARY_PATH + run скрипт.

А вообще - мужик ты умный, и прочитай всё-таки как установка и распространение программ происходит в линуксе, что там с билдингом, прочим.

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

Можешь у [livejournal.com profile] vitus_wagner на этот счёт посоветоваться - у него билд-система собирает программу под все мыслимые и немыслимые дистры + платформы без особых затрах - одной кнопкой.

[identity profile] metaclass.livejournal.com 2009-05-10 11:46 am (UTC)(link)
Я думаю, тут для начала достаточно будет собрать под этчем и запустить под ленни, и заодно попросить кого-нибудь из знакомых на других дистрибах проверить. Дебиан, по слухам, консервативен, значит будет более ранние версии держать, чем другие дистрибы.
А со сборкой пакетов придется разобраться, это как факт.

[identity profile] zamotivator.livejournal.com 2009-05-10 11:48 am (UTC)(link)
Попробу поищи бекпорты qt под etch.
В debian всегда есть бекпорты - порт новых версий библиотек под старые версии дистров.

Я тебе на ubuntu-janty x86_64 могу проверить =)

[identity profile] zamotivator.livejournal.com 2009-05-10 11:49 am (UTC)(link)
Ну, ubuntu она debian-like, и формат пакетов такой же.

[identity profile] metaclass.livejournal.com 2009-05-10 11:52 am (UTC)(link)
И там зависимости от новой глибц буквально в четырех функциях - проверка переполнения стека компилятором, отключается флагом компилятора, и еще три функции слежения за изменениями в файловой системе, нужно где-то там QT_NO_INOTIFY впихнуть при его пересборке.