User:Mainframe98/Vagrant on Windows
This guide attempts to list all the required steps to install MediaWiki-Vagrant on a windows machine.
Pre installation steps
edit- Check if you meet the requirements:
- Installed version of Windows is 64 bit
- Hyper-V is disabled - Required to use VirtualBox, Hyper-V support might be unstable
- Hardware Virtualization Technology (VT-x or AMD-V) in the BIOS is enabled and the computer supports Hardware Virtualization
- Download the software required
Installation
edit- Install Vagrant and if downloaded Git and VirtualBox
- If you want to use ssh from the windows command line, install Git using the
Use Git and optional Unix tools from the Windows Command Prompt
installation option when installing Git. This is not required, as you may use another ssh client like PuTTY instead.[1] Please do note that not using this installation option causes Vagrant to display an error about a missing ssh client. This message may be ignored.
- If you want to use ssh from the windows command line, install Git using the
- Clone https://gerrit.wikimedia.org/r/mediawiki/vagrant by using in your home directory/(My) Documents
git clone --recursive https://gerrit.wikimedia.org/r/mediawiki/vagrant
- SSH:
git clone --recursive ssh://<USERNAME>@gerrit.wikimedia.org:29418/mediawiki/vagrant.git
- Instead of using
git clone
, you can also just extract the zip file.
- SSH:
- Run
setup.bat
which is located in the newly cloned folder- You can also run
setup.sh
if you use a shell like Git Bash.
- You can also run
- Run
vagrant hiera mediawiki::branch REL1_42
, to specify the version (MediaWiki 1.42.3), omit statement entirely to use the master branch (1.44) - Run
Vagrant up
Connecting through ssh (when not using vagrant ssh
)
edit
This example uses PuTTY.
- Write down the ssh information about the vagrant virtual machine retrieved from running
vagrant ssh-config
- Example output:
Host default HostName 127.0.0.1 User vagrant Port 2222 UserKnownHostsFile /dev/null StrictHostKeyChecking no PasswordAuthentication no IdentityFile C:/HashiCorp/Vagrant/mediawiki-vagrant/.vagrant/machines/default/virtualbox/private_key IdentitiesOnly yes LogLevel FATAL ForwardX11 yes
- Generate a private key file that can be read by PuTTY using PuTTY gen (Found on the same page as the PuTTY download)
- Open PuTTY gen and load the private key file (IdentityFile, in the example above)
- Export it by choosing "Save private key", and store it somewhere save.
- Add the private key file by navigating in PuTTY to Connection, SSH, Auth. Click "Browse..." to load the generated file.
Errors
editRelevant information from running vagrant up
, Cloning mediawiki/core fails, and other packages that use mediawiki as dependency fail as a result too.
==> default: Notice: /Stage[main]/Mediawiki/Git::Clone[mediawiki/core]/Exec[git_clone_mediawiki/core]/returns: Cloning into '/vagrant/mediawiki'... ==> default: Notice: /Stage[main]/Mediawiki/Git::Clone[mediawiki/core]/Exec[git_clone_mediawiki/core]/returns: error: RPC failed; result=56, HTTP code = 200 ==> default: Notice: /Stage[main]/Mediawiki/Git::Clone[mediawiki/core]/Exec[git_clone_mediawiki/core]/returns: fatal: The remote end hung up unexpectedly ==> default: Notice: /Stage[main]/Mediawiki/Git::Clone[mediawiki/core]/Exec[git_clone_mediawiki/core]/returns: fatal: early EOF ==> default: Notice: /Stage[main]/Mediawiki/Git::Clone[mediawiki/core]/Exec[git_clone_mediawiki/core]/returns: fatal: index-pack failed ==> default: Error: /usr/bin/git clone --recurse-submodules --branch 'REL1_27' https://gerrit.wikimedia.org/r/p/mediawiki/core.git /vagrant/mediawiki returned 128 instead of one of [0] ==> default: Error: /Stage[main]/Mediawiki/Git::Clone[mediawiki/core]/Exec[git_clone_mediawiki/core]/returns: change from notrun to 0 failed: /usr/bin/git clone --recurse-submodules --branch 'REL1_27' https://gerrit.wikimedia.org/r/p/mediawiki/core.git /vagrant/mediawiki returned 128 instead of one of [0] ==> default: Notice: /Stage[main]/Mediawiki/Php::Composer::Install[/vagrant/mediawiki]/Exec[composer-install--vagrant-mediawiki]: Dependency Exec[git_clone_mediawiki/core] has failures: true