Что делать если нужно поставить какую-то 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
📰 Explosions in Iran Spread Jitters Amid Anticipation of Foreign Attacks
Deadly explosions in several Iranian cities, most likely caused by domestic accidents, have sent a wave of panic through a country already on the edge, fearing U.S. and Israeli strikes.
In Bandar Abbas, a major port in southern Iran, a powerful blast ripped through an eight‑story residential building, killing at least one person (a 4‑year‑old girl) and injuring more than a dozen others, according to local officials and Iranian state media.
The local fire chief said the incident was probably caused by a gas leak and buildup, and the government’s crisis management body stressed that the explosion had no security or sabotage origin.
But as images of a crumbled building and shattered streets spread online, wild rumors took over social media: claims that the blast had assassinated Iran’s top naval commander, Commodore Alireza Tangsiri, and that Israel or the U.S. was behind the explosion.
Iran’s Revolutionary Guards swiftly denied those reports, calling them “psychological warfare” and disinformation, while Israel and the U.S. issued no public comment on the incident.
The real detonator: Trump’s threats
The explosion in Bandar Abbas came just days after President Donald Trump declared that a “massive Armada” was heading toward Iran and warned that the U.S. was ready to strike with “speed and violence.”
In June 2025, the U.S. had already struck three of Iran’s main nuclear sites in a 12‑day conflict with Israel, dealing a serious blow to Tehran’s nuclear program. Iran now demands that the U.S. renew talks only if the threats stop.
Against that backdrop, a gas leak in an apartment building does not feel like a gas leak. It feels like the first crack in the ground before the bomb goes off.
Other blasts, same panic
In the same 24 hours, Iranian state media reported another deadly gas explosion in the south‑western city of Ahvaz, which killed five people but was officially described as a domestic accident, not sabotage.
Unverified reports and footage of smoke and explosions in the north‑western city of Tabriz also circulated, only to be quickly dismissed by local authorities as rumors and a minor reed fire.
None of the recent incidents so far show any sign of foreign attack. But the sheer number of explosions, and the speed at which people jump to “Israel” or “the U.S.” as the culprit, reveals a deeper truth: the theater is already in people’s heads.
“Society is waiting for war”
“When the next blast happens, we won’t need to wait for the government to explain the cause,”
said a 43‑year‑old engineer in Tehran, who asked not to be named out of fear of reprisal.
“Everyone around me is waiting for possible U.S. and Israeli military action,”
he said.
“People are stressed, anxious, powerless. We don’t know what was behind today’s explosions. Maybe it’s internal retaliation, maybe foreign sabotage, maybe just a gas leak. But one thing is undeniable: Society is waiting for war.”
#Iran#Trump2026#US#Israel#MiddleEast#War#GasLeak#BandarAbbas
📱American Оbserver - Stay up to date on all important events
🇺🇸
"Temiryo‘lkargo" AJ delegatsiyasi Eron safarida!
Ayni kunlarda Temiryo‘lkargo AJ vakillari Tehronda bo‘lib o‘tgan Iqtisodiy hamkorlik tashkilotiga (IHT) a’zo davlatlar ekspertlarining 13-yig‘ilishida ishtirok etishdi.
Safar davomida "Temiryo'lkargo" AJ bosh direktori A. Muminov hamda multimodal va xalqaro tashuvlar bo‘yicha o‘rinbosari Oybek Jabarov Sarah stansiyasi imkoniyatlarini o‘rgandi.
Muzokaralar davomida:
🚛 Eron hududida O‘zbekiston vagonlaridan foydalanish,
🛠 Vagonlarga texnik xizmat ko‘rsatish va telejkalarni almashtirish,
📦 Terminal ish faoliyati va ularning tamoyillari chuqur tahlil qilindi.
🤝 Eronlik xususiy tadbirkorlar bilan uchrashuvlarda eksport-import va tranzit tashuvlar masalalari muhokama qilindi. Maxatari, Bandr Abbas kabi yirik stansiyalar ko‘zdan kechirildi, mijozlar va stansiya vakillari bilan bevosita muloqot qilindi.
📍 Bandar Abbas portida o‘tkazilgan uchrashuvlarda UTYCARGO imkoniyatlari, faoliyat yo‘nalishlari va xizmat turlari haqida yirik tadbirkorlarga taqdimot o‘tkazildi.
🚂 Railway Transportation kompaniyasi bilan hamkorlik yo‘lga qo‘yildi. Kelgusida mineral o‘g‘itlar va kimyoviy moddalarning temiryo‘l orqali tashilishi rejalashtirilmoqda.
🏗 O‘zbekiston Bosh vaziri va Transport vaziri topshirig‘iga binoan, chegara punktlari va tushirib-ortish hududlarida qo‘shma logistik markazlar tashkil etish bo‘yicha kelishuvga erishildi.
📈"Temiryo'lkargo" AJ vagonlari eronlik mijozlarda katta qiziqish uyg'otdi!
📍#UTYCARGO#Temiryolkargo#OzbekistonEronHamkorligi#Logistika#Eksport#Import#Tranzit#TemiryolYukTashuvlari#BandarAbbas#SarahStansiyasi#RailwayTransportation
https://t.me/utycargo
utycargo.uz
📱facebook /📱x.com /📱web sayt/📱linkedin.com/📱instagram
O‘zbekiston va Eron temir yo‘l tizimlari o‘rtasida hamkorlik yangi bosqichga chiqmoqda!
1-iyun kuni Tehronda bo‘lib o‘tgan Iqtisodiy hamkorlik tashkilotiga (IHT) a’zo davlatlar ekspertlarining 13-yig‘ilishida yuk tashish jarayonlarini soddalashtirish, tranzit yo‘laklarini raqamlashtirish va “yashil”, xavfsiz transport tizimlarini rivojlantirish masalalari muhokama qilindi.
🔹“Temiryo‘lkargo” AJ vagonlarining Eron hududida ishlashi imkoniyati ko‘rib chiqildi
🔹Eron va Turkmaniston orqali o‘tuvchi yuk tashuvlariga chegirmalar rejalashtirilmoqda
🔹Bandar Abbas porti orqali O‘zbekistonga yuk oqimini oshirish va yetkazib berish muddatlarini qisqartirish bo‘yicha amaliy kelishuvlarga erishilmoqda
🔹Yuk hujjatlari bo‘yicha elektron almashuv va chegara jarayonlarini soddalashtirish muhim yo‘nalish sifatida belgilandi
📌 Eron yo‘llar va shaharsozlik vazirining maslahatchisi Amin Taroffo ma’lum qilishicha,
IHTga a’zo davlatlar transport va yo‘llar bo‘yicha vazirlarining 13-yig‘ilishi 1–2-iyun kunlari Tehronda o‘tkaziladi.
📚 Ma’lumot uchun:
IHTga a’zo davlatlar:
Ozarbayjon, Afg‘oniston, Eron, Qozog‘iston, Qirg‘iziston, Pokiston, Tojikiston, Turkmaniston, Turkiya, O‘zbekiston
🤝 Tomonlar mintaqaviy logistika salohiyatini kengaytirish va o‘zaro manfaatli hamkorlikni chuqurlashtirishga intilmoqda.
📦 Tez, ishonchli va hamyonbop yuk tashuvlari yo‘lida yangi qadamlar tashlanmoqda!
⸻
#Temiryulkargo#ECO2025#TehranMeeting#BandarAbbas#YukTashish#TranzitYuklar#UzbekistanLogistics#TransportHamkorligi#GreenLogistics#XalqaroTashuvlar
https://t.me/utycargo
utycargo.uz
📱facebook /📱x.com /📱web sayt/📱linkedin.com/📱instagram