207 похожих чатов

Не уверен, можно ли здесь такое спрашивать. В общем, по

поводу распространения программы, пакетирования. Конкретно интересует Linux. Сначала ориентировался на AppImage, но целевые системы на базе Debian, поэтому в идеале хотелось, чтобы это был deb пакет. Но при этом хотелось бы таскать все зависимости с собой, как в AppImage, в том числе libstdc++ и libgcc_s (так как собирается всё на свеженьком GCC, но на старом glibc). Идея такая: положить все либы в /usr/lib/<appname>/, основной executable файл положить туда же, а в /usr/bin/ положить скрипт, который будет выставлять нужный LD_LIBRARY_PATH и вызывать executable файл программы (такой способ использует, например, ardour, как описано здесь https://stackoverflow.com/a/14500152). Какие есть подводные камни? Больше всего интересует, не сломаю ли другие программы?

7 ответов

19 просмотров

/opt/<app>/bin/<app> — это скрипт, который как и сказали, выставляет LD_LIBRARY_PATH. Сам бинарь переименован в <app>-bin.

Maksim- Автор вопроса

Не Open Source, коммерческое. GUI. Мы собираем на какой-то старой Ubuntu. То ли 14.04, то ли 16.04, сейчас не скажу. В общем, с glibc проблем нет (если я правильно понимаю, этого и пытаются избежать, собираясь на старой системе).

Maksim- Автор вопроса

Красота. Звучит, как то, что нужно. Спасибо, что поделились своим опытом.

Ну вот для работы WebEngine это необходимо. А в чём конкретно проблема? 😊

Maksim- Автор вопроса

А, я вот как раз WebEngine выпиливаю. Но так-то другие executable файлы у нас имеются, и запускать их нужно, так что наследование LD_LIBRARY_PATH в этом плане хорошо. Но программа может запускать сторонние приложения на компьютере (какой-нибудь текстовый редактор по выбору пользователя для редактирования файла), что в теории может привести к каким-нибудь конфликтам либ. В принципе, я так понимаю, в этом случае нужно просто из environment перед запуском выпилить LD_LIBRARY_PATH.

На 6 одна, на 7 другая

Maksim- Автор вопроса

Детали, детали. Собираюсь в докере с какой-то старой убунтой, где glibc относительно старый (2.23). На целевой системе 2.24, если не ошибаюсь. Соответственно, старше 2.24 никак нельзя. Приложение коммерческое, линковаться статически тоже нельзя. В докер образе из исходников собран новый GCC (то ли 10, то ли 11, не помню). Хотелось бы использовать как можно новее всегда, периодически обновляться. На целевой системе, соответсвенно, нет ни нового компилятора, ни новой стд либы, поэтому планируется libstdlibc++ и libgcc_s закинуть к программе. Я проверял, это работает. Судя по https://distrowatch.com/table.php?distribution=centos, по версии glibc, 7-ая версия ещё подходит, а вот 8-ая уже нет.

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта