Что делать если нужно поставить какую-то Python-библиотеку а root-прав нет? То есть в систему библиотеку никак и ничего не поставить.
Есть как минимум два способа это решить правильно!
🔸 Сделать виртуальное окружение и ставить там что угодно.
Это позволит создать полностью независимое исполняемое окружение для ваших приложений.
Все библиотеки будут храниться в домашней директории юзера а значит доступ на запись имеется.
Создать очень просто:
python3 -m venv ~/venvs/myenvname
Теперь активируем окружение
# Linux
source ~/venvs/myenvname/bin/activate
# Windows
%userprofile%\venvs\myenvname\Scripts\activate.bat
Можно ставить любые библиотеки и запускать приложение.
Это стандартный метод работы с любым проектом. Если еще не используете его, то пора начинать. Даже при наличии root доступа!
🔸 Бывает, что нет возможности запустить приложение из своего виртуального окружения. Например, его запускает какой-то сервис от вашего юзера и вставить активацию окружения вы не можете.
В этом случае можно установить библиотеки для Python не глобально в систему, а только для юзера.
Выполните этот код в консоли:
python3 -m site
Вы получите что-то такое:
sys.path = [
'/home/user',
'/usr/lib/python37.zip',
'/usr/lib/python3.7',
'/usr/lib/python3.7/lib-dynload',
'/home/user/.local/lib/python3.7/site-packages',
...
]
USER_BASE: '/home/user/.local'
USER_SITE: '/home/user/.local/lib/python3.7/site-packages'
ENABLE_USER_SITE: True
Нас интересует параметр USER_SITE. Это путь к пользовательским библиотекам, которые доступны по умолчанию, если они есть.
Именно сюда будут устанавливаться модули если добавить флаг --user при установке чего-либо через pip
pip install --user requests
Для этой команды не нужны root-права.
После неё можно запускать системный интерпретатор без виртуальных окружений и установленная библиотека будет доступна для текущего юзера.
Параметр USER_BASE показывает корневую директорию для хранения user-библиотек. Её можно изменить с помощью переменной окружения PYTHONUSERBASE
export PYTHONUSERBASE=~/pylibs
python3 -m site
...
USER_BASE: '/home/user/pylibs'
USER_SITE: '/home/user/pylibs/lib/python3.7/site-packages'
Получается некоторое подобие виртуального окружения для бедных 😁 которое можно менять через эту переменную (не делайте так!Лучше venv!)
🔸 Дописывание пути в PYTHONPATH
Этот способ не входит в список "двух правильных", но тоже рабочий. Здесь придётся сделать всё несколько сложней.
Сначала ставим библиотеку в любое место указывая путь установки
pip3 install -t ~/mylibs modulename
Библиотека установится без привязки к какому-либо интерпретатору. То есть по умолчанию не будет видна. Теперь в нужный момент добавляем этот путь в sys.path или в PYTHONPATH.
Не буду советовать так делать. Единственный раз когда этот способ мне пригодился и решил поставленную задачу, это при создании общей библиотеки для кластера компьютеров.
Модули лежат в сети и подгружаются для всех из одного и того же места. То есть обновлять файлы требуется только один раз а не на всех хосты отдельно.
Минусы такого подхода:
▫️Нужно всем хостам пробить нужный путь в .bashrc или ещё куда-то чтобы он сетапился на старте.
▫️Чем больше хостов тем больше нагрузка на сеть. Иногда такой способ не подходит именно по этой причине. Тогда Ansible вам в помощь.
▫️Не очень подходит если хосты с разными операционками. Некоторые библиотеки различаются для Linux и Windows (там, где есть бинарники) и приходится мудрить более сложные схемы.
#tricks#basic
🚢Кризисы в регионе обрушили доходы Суэцкого канала.
Геополитическая нестабильность на Ближнем Востоке и атаки на коммерческое судоходство в Красном море привели к падению доходов Египта от эксплуатации Суэцкого канала.
По заявлению президента Египта Абделя Фаттаха ас-Сиси, совокупные потери страны от снижения транзита через канал достигли примерно $10 млрд (около 500 млрд египетских фунтов) с конца 2023 года.
Суэцкий канал остается одним из ключевых маршрутов мировой торговли, через который проходит около 12–15% глобального морского товарооборота. Однако из-за атак на суда и роста страховых премий многие компании начали перенаправлять суда в обход мыса Доброй Надежды, что увеличило время рейсов и расходы на топливо.
Несмотря на падение доходов, администрация канала подчеркивает, что движение судов продолжается в обоих направлениях, а навигационные услуги предоставляются круглосуточно.
По прогнозу Международного валютного фонда, доходы канала в 2024/2025 финансовом году составят ок $3,6 млрд, что примерно на 45% ниже уровня предыдущего года.
Для сравнения: в 2022/23 финансовом году доходы Суэцкого канала достигали $9,4 млрд, а в 2023 г ожидались $10 млрд.
Снижение трафика через канал усиливает давление на глобальные логистические цепочки и фрахтовые ставки, поскольку обходные маршруты увеличивают расстояние между Азией и Европой примерно на 3–4 тыс. морских миль.
📌Suez Canal Authority (SCA) — государственная организация Египта, управляющая Суэцким каналом, который был открыт для судоходства в 1869 году.
Канал является одной из важнейших транспортных артерий мировой торговли и полностью принадлежит государству Египет, обеспечивая значительную часть валютных поступлений страны.
#SuezCanal#Shipping#GlobalTrade#MaritimeEconomy#Logistics
The groundbreaking for the modern Suez Canal began on 25 April 1859. It was completed on 17 November 1869 under the leadership of Ferdinand de Lesseps. The canal connects the Red Sea to the Mediterranean, revolutionizing global trade. Earlier attempts to build a similar waterway, like those by Pharaoh Necho II (610 BC) and Ptolemy II (285 BC), were unsuccessful due to technical and natural challenges.
🌊🗺🛳️
[Read more 1]
[Read more 2]
@googlefactss
#SuezCanal#History#AncientHistory#Egypt#GlobalTrade
If you have ideas or feedback contact us:
@Googlefactss_Feedback_bot
🚢Maersk временно перенаправляет часть сервисов в обход Суэца.
Датская группа A.P. Moller – Maersk на ближайшие три недели перенаправит часть рейсов контейнерных сервисов ME11 и MECL с маршрута через Суэцкий канал на обход вокруг мыса Доброй Надежды.
Решение принято из-за «непредвиденных ограничений» в регионе Красного моря.
Компания подчёркивает, что изменения носят временный характер, и по возможности продолжит использовать Суэц для других сервисов. Клиенты получат обновлённые графики перевозок.
Ранее в рамках альянса Gemini Cooperation с Hapag-Lloyd сообщалось, что один совместный сервис планируется выполнять через Красное море и Суэцкий канал при сопровождении военно-морских сил, без масштабного изменения всей сети.
Перенаправление рейсов увеличивает транзитное время и потребление топлива, снижая эффективное предложение тоннажа. В условиях сохраняющейся геополитической напряжённости в регионе Красного моря подобные решения усиливают давление на расписания и ставки в сегменте дальних линейных контейнерных перевозок.
📌A.P. Moller – Maersk A/S — датская интегрированная логистическая и судоходная группа, основанная в 1904 году.
Акции обращаются на бирже Nasdaq Copenhagen; контроль осуществляется через фонд A.P. Moller Foundation (семья Мёллер).
#Maersk#SuezCanal#ContainerShipping#RedSea#GlobalLogistics
🚀 Goldman Sachs Revises Oil Price Forecasts for Second Quarter
Goldman Sachs has adjusted its oil price forecasts for the second quarter, citing changes in risk premiums and increased crude flow through the Suez Canal. According to BlockBeats, the financial institution has lowered its Brent crude price prediction to $90 per barrel and its West Texas Intermediate (WTI) crude forecast to $87 per barrel as of April 9.
#GoldmanSachs#OilPriceForecasts#BrentCrude#WTICrude#SuezCanal#CrudeFlow#RiskPremiums#April2026