First of all, make a clone or fork of this repository and replace all occurrences of myapp
with a name of your choice.
Start a "micro" Amazon EC2 instance and use one of the following AMIs, depending on where you chose to launch it:
- US west:
ami-ad7e2ee8
- US east:
ami-ccf405a5
- EU west:
ami-fb9ca98f
- Asia Pacific (Singapore):
ami-0c423c5e
These AMIs where taken from http://uec-images.ubuntu.com/releases/10.10/release/
Go with the defaults in the "wizard" presented. Chose to create a new key pair when asked and be sure to make a secure backup of the private key that you will download. A good place to put your private key is in ~/.ssh/myapp.pem
and then chmod 0600 ~/.ssh/myapp.pem
so no one else can read it but you.
When the instance is green and "started", log in to the machine:
ssh -i ~/.ssh/myapp.pem [email protected]
Note: Replace XXX.amazonaws.com
with the hostname or address of your instance
sudo apt-get update
sudo apt-get install nginx git-core daemon
sudo chown -R www-data:www-data /var/www
Node.js:
sudo apt-get install build-essential libssl-dev
cd
mkdir src
git clone https://github.com/joyent/node.git src/node
cd src/node
# Optionally: git checkout v0.4.3
./configure
JOBS=2 make
sudo make install
NPM:
sudo true && curl http://npmjs.org/install.sh | sudo sh
sudo npm install connect connect_json move
sudo mkdir /var/myapp
sudo chown www-data:www-data /var/myapp
If your git repository is public (i.e. viewable by anyone):
sudo -Hu www-data git clone https://github.com/you/myapp.git /var/myapp
If your git repository is private:
sudo -Hu www-data ssh-keygen -t rsa # chose "no passphrase"
sudo cat /var/www/.ssh/id_rsa.pub
# Add the key as a "deploy key" at https://github.com/you/myapp/admin
sudo -Hu www-data git clone [email protected]:you/myapp.git /var/myapp
Your Node.js web server:
sudo ln -s /var/myapp/init.d/myapp-httpd /etc/init.d/
sudo update-rc.d myapp-httpd defaults
sudo invoke-rc.d myapp-httpd start
Optional myapp-processor
:
sudo ln -s /var/myapp/init.d/myapp-processor /etc/init.d/
sudo update-rc.d myapp-processor defaults
sudo invoke-rc.d myapp-processor start
There are three different kinds of setups to chose from:
myapp-http
-- HTTP onlymyapp-https
-- HTTPS with HTTP redirecting to HTTPSmyapp-https-http
-- HTTPS and HTTP
If you are using HTTPS, make sure you have added your SSL certificate and key at /var/myapp/ssl/ssl.crt
and /var/myapp/ssl/ssl.key
.
Replace myapp-https
below with the configuration of your choice:
sudo ln -sf /var/myapp/etc/nginx/sites-available/myapp-https \
/etc/nginx/sites-enabled/default
sudo invoke-rc.d nginx restart
Your web app should now be operational.
If everything works, continue by reading WORKFLOW.md