В моей книге Python Crash Course, 2-е издание, рекомендуется поместить ll_env (каталог venv) в .gitignore.
Там говорится: «Мы говорим Git игнорировать весь каталог ll_env, потому что мы можем заново создать это автоматически в любое время"
Но на мой взгляд это очень плохой ход, потому что откатить установку пакетов я не смогу.
Нужно ли мне это делать? Почему?
@Giggest, что если я случайно изменил что-то в пакетах, но не знаю, что именно (например, установка какого-то пакета изменила что-то в версиях других пакетов) и не создал файл требований.txt, когда в прошлый раз все было в порядке? Как потом откатиться в то рабочее состояние? Если я отслежу венв, то смогу всё восстановить. Может я чего-то не понимаю?
Хорошей практикой является не позволять git отслеживать ваш venv.
Виртуальные среды могут содержать тысячи файлов, а их размер может достигать гигабайт. Передача их в Git может перегрузить и загромождать репозиторий исходного кода ненужными файлами и вызвать путаницу у любого, кто пытается клонировать и запустить исходный код на своем компьютере.
Виртуальные среды по своей природе одноразовые. Они содержат пакеты, скачанные из Интернета. Их можно легко воссоздать, поэтому нет необходимости фиксировать такие большие файлы в git.
Виртуальные среды воспроизводимы. Проекты Django в идеале поставляются с файлом requirements.txt
, созданным с помощью pip freeze > requirements.txt
. Этот файл показывает список установленных пакетов и библиотек в вашем проекте. Вы можете легко переустановить все содержимое папки venv в любом месте, где есть подключение к Интернету.
Дополнительную информацию смотрите в этой статье.
что, если я случайно что-то изменил в пакетах, но не знаю, что именно (например, установка какого-то пакета изменила что-то в версиях других пакетов) и не создал require.txt, в прошлый раз все было ОК? Как потом откатиться в то рабочее состояние? Если я отслежу венв, то смогу всё восстановить. Может я чего-то не понимаю?
Я бы сказал, что всегда полезно иметь файл require.txt для проектов Python не только для вас, но и для других, кто может быть заинтересован в вашем проекте. При этом, пока у вас есть доступ к локальному репозиторию, вы всегда можете заморозить pip, чтобы увидеть, какие пакеты установлены. Если он находится на удаленном компьютере и у вас больше нет доступа или его нет у других заинтересованных пользователей, то вам подойдет файл require.txt.
Обычно вы используете команду
pip freeze > requirements.txt
, чтобы сделать копию установленных библиотек, затем создается текстовый файл, в котором содержатся текущие версии пакетов, чтобы вы могли их затем установитьpip install -r requirements.txt
, и вам ни для чего не нужен venv на git.