npm: ошибка при установке пакетов в Vagrant

Во время выполнения команды npm install в расшаренной директории Vagrant (Windows хост, Ubuntu гостевая) происходит ошибка вида protocol error, symlink '../acorn/bin/acorn' -> '/vagrant/node_modules/.bin/acorn'. Эта распространенная проблема при работе с пакетными менеджерами в Vagrant под Windows и связана с некорректной работой симлинков при стандартном VirtualBox-ом механизме синхронизации папок между Windows хостом и Linux гостем. Решается либо сменой способа синхронизации, либо отказом от использования симлинков.

У npm к счастью есть опция отказа от симлинков:

npm install --no-bin-links

Babun как терминал в PyCharm

Продолжаю осваивать Windows, как бы это забавно не звучало для веб-разработчика в 2K16. Захотелось, чтобы в качестве терминала в PyCharm запускался Babun, а не стандартный cmd.exe.

Делается так:

  • Нужно зайти в настройки Settings — Tools — Terminal.
  • Задать путь к bash.exe в директории установки Babun. По умолчанию C:\Users\YOUR-USER\.babun\cygwin\bin\bash.exe.

Снимок экрана (1)

Windows, Vagrant, Virtualenv — Protocol error

При попытке инициализировать виртуальное окружение в расшареной папке Вагранта под Виндоус получаю ошибку OSError: [Errno 71] Protocol error.

Лечится вызовом виртуаленв с опцией —always-copy.

virtualenv -p python3 env --always-copy

Vagrant — не обновляются файлы в расшаренной папке

Сетап такой: Windows 7 на хост машине и CentOS 7 на гостевой машине. Вагрант при таком сочетании выбрал механизм синхронизации расшаренных папок rsync (можно увидеть при старте виртуальной машины). Отлично, но rsync не умеет отслеживать изменения в файлах в реальном времени, только по явной команде. Эта команда Вагрантом вызывается только при старте или перезагрузке машины — vagrant up или vagrant reload соответственно.

Вручную можно вызвать так.

vagrant rsync

Или можно заставить rsync все-таки отслеживать изменения файлов, но тогда придется оставить процесс запущенным в терминале на все время работы с виртуальной машиной

vagrant rsync-auto

Подробности можно найти в блоге Вагранта.

Django под Windows — рецепт солянки

Настройка Linux среды Python/Django разработки под Windows с помощью VirtualBox и PyCharm на примере Debian

Ингридиенты

  1. Ноутбук с предустановленной Windows 8.1: 1,5 кг
  2. VirtualBox: 1 литр
  3. Debian: 0.5 тушки (можно заменить на целую тушку Ubuntu или другой Linux, который есть в вашем магазине, но с Debian наваристее)
  4. VirtualBox Guest Addition: 1 горсть
  5. PyCharm: 1 луковица
  6. deb-пакеты: 5-10 пакетов
  7. Python модули: все, что у вас есть в холодильнике
  8. Эстетическое неприятие дуалбут и необходимость работы с Photoshop: по вкусу

Время приготовления: 2 суток.

Установить VirtualBox

  1. Скачать и установить основной дистрибутив VirtualBox.
  2. Скачать и установить пакет дополнений гостевой ОС (см. вставку в соответствующем пункте).

Установить Debian 7

Проще всего использовать netinst образ соответствующий архитектуре вашей системы. Варить около получаса. Не пересаливать предустановленными пакетами.

Установить гостевые дополнения в VirtualBox

Внимание! При использовании версии дополнений 4.3.10 возникает ошибка во время монтирования общих папок! https://www.virtualbox.org/ticket/12879 Скачать образ дополнений 4.3.11 https://www.virtualbox.org/download/testcase/VBoxGuestAdditions_4.3.11-93070.iso

  1. Подключить скачанный образ. Устройства — Приводы оптических дисков — Выбрать образ оптического диска.
  2. Смонтировать cdrom

    # mount /dev/sr0 /media/cdrom
    
  3. Установить make, gcc, bzip2

    # apt-get install make gcc bzip2
    
  4. Запустить run скрипт с диска

    # cd /media/cdrom
    # ./VBoxLinuxAdditions.run
    

Настроить общие папки

Общие папки очень удобны для разработки, позволяя избежать загрузки файлов по FTP в гостевую ОС и исполнять код прямо из папки проекта хостящей ОС.

  1. Добавить новую общую папку. НастройкиОбщие папкиДобавить. Указать путь (например E:\Dev\django) к папке и ее имя (например, django). Поставить галку возле Создать постоянную папку.
  2. Примонтировать устройство в гостевой ОС

    # mount -t vboxsf django /home/myuser/django -o rw,dmode=775,uid=1000,gid=1000
    
  3. Если папка появилась в нужной точке в необходимом виде, то можно добавить правило в /etc/fstab для автоматического монтирования при старте системы.

    django /home/myuser/django vboxsf rw,dmode=775,uid=1000,gid=1000 0 0
    

    ВНИМАНИЕ! Не допускай опечатку в слове vboxsf!

Установить все необходимые для разработки пакеты

  1. Python

    # apt-get install python-dev
    
  2. MySQL

    # apt-get install mysql-server mysql-client python-mysqldb libmysqlclient-dev
    
  3. PIL

    # apt-get install python-imaging
    
  4. Модули Python

    # apt-get install python-pip
    # pip install -U pip
    # pip install virtualenv
    

Настроить SSH доступ к гостевой ОС

  1. Установить OpenSSH сервер.

    # apt-get install openssh-server
    
  2. Пробросить произвольный порт хостящей ОС на 22 порт гостевой ОС. УстройстваСетьНастроить сеть. По умолчанию тут уже настроен тип подключения NAT. Зайти в раздел Проброс портов и настроить запись вида: имя — ssh, порт хоста — например, 3022, порт гостя — 22. Настроить подключение в Putty к 127.0.0.1:3022.

Установить и настроить MySQL Workbench

  1. Скачать
  2. Настроить соединение по SSH через проброшенный порт и гостевого пользователя
  3. Использовать по назначению

Настроить проект в PyCharm

  1. Настроить удаленный интерпретатор
  2. Установить python-зависимости
  3. Добавить необходимую запись в C:\Windows\System32\drivers\etc\hosts хоста
  4. Добавить необходимую запись в /etc/hosts гостевой ОС
  5. Пробросить порт с хоста (например, 8800) на 8000 порт гостевой ОС
  6. Настроить конфигурацию запуска dev-сервера в PyCharm. Задать отображение (меппинг) локальной рабочей директории на удаленную, чтобы удаленный интерпретатор обнаружил manage.py скрипт. В качестве хоста указать 0.0.0.0 для того, чтобы dev-сервер отвечал на любом сетевом интерфейсе. Порт оставить 8000.

Установить дополнительно

  1. 4t Tray Minimizer — позволяет сворачивать произвольную программу в системный трей, чтобы убрать раздражающее «залипание» на VirtualBox при Alt+Tab переключении.
  2. Установить PostgreSQL и инструменты для работы с ней аналогично MySQL.

Побочные эффекты

  1. В данный момент в PyCharm (2.7) недоступны пункты меню Run Django conaole и Run manage.py task при использовании удаленного интерпретатора — тикет в трекере.