Skip to content

Sneakers is a simple, fast way to mimick Openminds Shared and Cloud hosting environments using vagrant/virtualbox, and provisioned by Chef.

Notifications You must be signed in to change notification settings

Brammm-forks/sneakers

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

95 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Openminds logo

Openminds Sneakers

Description

Sneakers is a simple, fast way to mimick Openminds Shared and Cloud hosting environments. We do this using vagrant/virtualbox provisioned by Chef. You can develop your websites and test it straight on the VM (Virtual Machine) without the need for deploying or doing complex tasks. If your website works in our Sneakers, it should work on our production servers.

Dependencies

Only three, and in that order:

Currently supported

These are the servers we can currently mimick:

  • Cloud hosting PHP 5.3
  • Cloud hosting PHP 5.4
  • Cloud hosting Ruby 1.9.3
  • Shared hosting PHP 5.3 (shared-017)
  • Shared hosting PHP 5.4 (shared-018)
  • Shared hosting Ruby 1.9.3 (pro-007, pro-008)

soon(-ish): shared varnish support

Getting started

Clone this repository:

git clone git://github.com/openminds/sneakers.git

Make sure all submodules are up-to-date:

git submodule update --init

Copy the config file:

cp config.yml.example config.yml

Edit the config file to represent your apps. You can add as many as you want (as long as your physical memory permits it), this example has two apps:

myapp:
  app_directory: "/Users/steven/Developer/myapp"
  type: "php54"
  http_port: 9000
  memory: 1024

myotherapp:
  app_directory: "/Users/steven/Developer/myotherapp"
  type: "ruby193"
  http_port: 9001
  memory: 1024
  • myapp: This will be the name of your VM (unique identifier), change it to whatever makes sense to you.
  • app_directory: The directory your app resides on the host machine (i.e. your laptop)
  • type: Type of app you will use, this can be php53, php54, ruby193, ..
  • http_port: The VM will forward port 80 to another port on your machine. pick a port that's unused on your local machine.
  • memory: How much memory your VM may use. Be carefull, the more memory your VM has, the less your host machine has.

Caveats:

  • each app will run in its own VM, so make sure that if you add multiple apps that they all have a different http_port set up.
  • this is a yml file, indentation is important.

To start a VM:

vagrant up myapp

(make sure to specify the app name, or you will start all VM's)

To stop a VM:

vagrant halt myapp

To destroy a VM:

vagrant destroy myapp

To destroy all VM's:

vagrant destroy

If you run vagrant by itself, help will be displayed showing all available subcommands. In addition to this, you can run any Vagrant command with the -h flag to output help about that specific command.

Develop your app in the directory you've given with the app_directory parameter. When you surf to http://localhost:9000 (or not 9000 but another port you've set with http_port) you should see your website as it would show on an Openminds production server.

Databases

You should have a database with a database user named after your app. In this example that would be myapp or myotherapp. Password will always be vagrant. The mysql root user also has password vagrant. phpMyAdmin is available under http://localhost:9000/phpmyadmin (change port 9000 if applicable).

To list the credentials of the default example:

* database: myapp
* database user: myapp
* database password: vagrant

* database root user: root
* database root password: vagrant

* phpMyADmin: http://localhost:9000/phpmyadmin

Issues and Feedback

Please submit issues through Github 'issues', or mail us at [email protected]. Feel free to give feedback.

Todo's

  • Mimick Shared Varnish
  • Capistrano deploy.rb config generator

About

Sneakers is a simple, fast way to mimick Openminds Shared and Cloud hosting environments using vagrant/virtualbox, and provisioned by Chef.

Resources

Stars

Watchers

Forks

Packages

No packages published