VamShop Блог

 

VamShop 3 — Vagrant + Scotch Box

Ноябрь 22, 2018

Прошлая статья — VamShop 3 — Настройка Vagrant + Chef

Была больше вступительной, т.е. больше теоретической и объясняющей, что такое vagrant, для чего он нужен, как самому настраивать виртуальную машину с нуля, с помощью chef, добавляя модули (рецепты) из книги рецептов (cookbook).

Но это не единственный вариант настройки виртуального окружения с vagrant.

Можно сделать всё гораздо проще.

В vagrant есть готовые образы виртуальных машин, с уже настроенным окружением, так называемые боксы.

Официальный сайт с боксами — https://app.vagrantup.com/boxes/search

К примеру, скачивается уже готовый образ с настроенным стэком LAMP (Linux+Apache+MySQL+PHP).

В этом случае Вам вообще ничего не надо делать, просто выполнили в папке с файлами vamshop команду:

vagrant up

и у Вас запустилось готовое к работе окружение.

В данном примере будет использоваться готовый набор — Scotch Box

Официальный сайт: https://box.scotch.io/

Это готовый набор, всё, что может Вам понадобиться для работы с php проектами.

Итак, что же мы делаем, как нам запустить этот бокс.

Всё просто, меняем наш стандартный конфиг Vagrantfile в папке с файлами vamshop и меняем его содержимое на:

# -*- mode: ruby -*-
# vi: set ft=ruby :

Vagrant.configure("2") do |config|

    # /*=====================================
    # =            FREE VERSION!            =
    # =====================================*/
    # This is the free (still awesome) version of Scotch Box.
    # Please go Pro to support the project and get more features.
    # Check out https://box.scotch.io to learn more. Thanks

    config.vm.box = "scotch/box"
    config.vm.network "private_network", ip: "192.168.33.10"
    config.vm.hostname = "vamshop"
    config.vm.synced_folder ".", "/var/www/public", :mount_options => ["dmode=777", "fmode=766"]

    # Optional NFS. Make sure to remove other synced_folder line too
    #config.vm.synced_folder ".", "/var/www/public", :nfs => { :mount_options => ["dmode=777","fmode=766"] }

end

По умолчанию VamShop 3 уже идёт именно с этим конфигом.

Всё, теперь запускаем наше окружение командой:

vagrant up

Будет загружен бокс scotchbox и запущено всё необходимое окружение.

Screenshot from 2018-11-22 14-13-16.png

Всё готово.

Machine booted and ready — все загрузилось и готово к работе.

Теперь открываете браузер и указываете адрес нашей виртуальной машины: 192.168.33.10

Сразу же откроется установка VamShop:

Screenshot from 2018-11-22 14-34-49.png

Подробнее про scotchbox, какие логины, пароли по умолчанию установлены к mysql, всё это на официальном сайте: https://box.scotch.io/

Я просто сразу напишу, что доступ к базе следующий:

сервер — localhost

логин — root

пароль — root

база — scotchbox

т.е. Вы сразу же можете установить VamShop указав эти данные.

и у Вас уже готов к работе VamShop, установленный и рабочий.

Надо ещё сказать, что vagrant пробрасывает внутрь виртуальной машины Вашу папку с магазином.

т.е. у Вас получается вроде как и изолированное окружение, но все рабочие файлы у Вас берутся с Вашего основного диска.

Это очень удобно, нет дублирования файлов у Вас на основном диске и внутри виртуальной машины.

Всё это прописано в конфиге Vagrantfile, т.е. папка /var/www/public внутри виртуальной машины это Ваша папка на основном диске компьютера. Если Вам надо что-то исправить в коде, Вы просто правите файлы на своём диске и они так же будут исправлены внутри изолированного виртуального окружения.

Кроме того, можно установить не через браузер VamShop, а через консоль, для этого после запуска vagrant, подключайте по ssh к виртуальной машине:

vagrant ssh

Подключившись, в терминале видно, что Вы в виртуальной машине с запущенным scotchbox образом, смотрите скрин:

Screenshot from 2018-11-22 15-02-25.png

Переходите в папку веб-сервера:

cd /var/www/public

и запускайте установку через консоль, командой:

bin/cake vamshop/install.install

Скрипт Вас попросит указать доступ к базе данных, логин и пароль к админке.

Либо можно так, указав все параметры сразу в команде:

bin/cake vamshop/install.install -u root -p root -d Mysql -n scotchbox -h localhost -t 3306 admin password

Всё, затем открываете в браузере http://192.168.33.10 и у Вас рабочая копия VamShop.

Вход в админку http://192.168.33.10/admin

логин: admin

пароль: password

Это если Вы выполнили команду выше, либо елси Вы указали свой логин и пароль для админки, тогда указывайте свои данные для входа.

 

Можно сделать ещё проще, производить установку прямо при запуске vagrant, добавив в конфиг Vagrantfile что-то типа:

  config.vm.provision :shell, :inline => "cd /var/www/public && bin/cake vamshop/install.install -u root -p root -d Mysql -n scotchbox -h localhost -t 3306 admin password"

Тогда прямо после запуска виртуального окружения сразу открывайте браузер и переходите на http://192.168.33.10 и у Вас будет установленный VamShop.

Просто так делать не всегда удобно, потому что при каждом старте виртуального окружения у Вас будет всё сбрасываться и устанавливаться по-новой при каждом запуске виртуального окружения, а это не всегда нужно.

 

Давайте напоследок ещё раз, как теперь выглядит рабочий процесс запуска VamShop и всего необходимого окружения у Вас на компьютере с использованием Vagrant + Scotch Box:

 

1. Открыли терминал (консоль) и собрали VamShop в текущей директории командой:

composer create-project vamshop/vamshop-app ./

Screenshot from 2018-11-22 14-26-06.png

Composer загрузит скелет приложения VamShop, который в свою очередь загрузит все необходимые зависимости: VamShop модули, CakePHP, необходимые библиотеки.

Composer в конце загрузки Вас спросит установить необходимые права доступа на файлы и папки:

Set Folder Permissions ? (Default to Y) [Y,n]? Y

Указываете на клавиатуре Y и кнопку Enter.

Screenshot from 2018-11-22 14-28-37.png

Будут выставлены необходимые для работы права доступа на файлы и папки, обновлено значение Security.salt в /app/Config.php

Генерируется каждый раз уникальное значение для каждого магазина. В дальнейшем данное значение будет испольовано, к примеру, при работе с API VamShop,  а имено при авторизации с помощью JWT токенов. Но данная заметка не об этом, статьи про VamShop API есть отдельная, почитайте, если интересно.

Всё. VamShop полностью собран и готов к работе.

2. Запускаем виртуальное окружение:

vagrant up

Screenshot from 2018-11-22 14-32-29.pngScreenshot from 2018-11-22 14-33-29.png

Увидели Machine booted and ready

Значит всё хорошо, виртуальное окружение готово.

3. Открываем в браузере адрес: 192.168.33.10

Screenshot from 2018-11-22 14-34-49.pngScreenshot from 2018-11-22 14-35-13.png

и проходим установку до конца.

Всё, у Вас полностью рабочая копия VamShop со всем необходимым.

Если не нравится отркрывать ip адрес, можете задать имя.

В файле /etc/hosts добавьте строку:

192.168.33.10 vamshop

Тогда в браузере можно открывать адрес http://vamshop

P.S. Что б всё это работало так же быстро и удобно, как я описываю, у Вас должен быть установлен необходимый софт (virtualbox, vagrant, composer).

Leave Your Comment

 
 

Google