Jelajahi Sumber

Merge pull request #4 from Musare/docker

Docker
Wesley McCann 9 tahun lalu
induk
melakukan
1a7d7d31c5
10 mengubah file dengan 106 tambahan dan 224 penghapusan
  1. 5 68
      README.md
  2. 0 30
      Vagrantfile
  3. 23 0
      backend/Dockerfile
  4. 3 5
      backend/app.js
  5. 4 0
      backend/package.json
  6. 0 120
      bootstrap.sh
  7. 20 0
      docker-compose.yml
  8. 1 1
      frontend/App.vue
  9. 26 0
      frontend/Dockerfile
  10. 24 0
      frontend/nginx.conf

+ 5 - 68
README.md

@@ -2,11 +2,7 @@
 Musare in NodeJS, Express, SocketIO and VueJS.
 
 ## Requirements
- * [Virtualbox](https://www.virtualbox.org/)
- * [Vagrant](https://www.vagrantup.com/)
-
-##### Important Notes
-The latest version of `Vagrant (1.8.5)` has some issues with inserting ssh keys into the machine. It's a show stopping bug that they aren't going to fix until the [next release](https://github.com/mitchellh/vagrant/issues/7610#issuecomment-234609660). So for now, I recommend using [Vagrant 1.8.4](https://releases.hashicorp.com/vagrant/1.8.4/). You'll also need to use a slightly [older version of Virtualbox](https://www.virtualbox.org/wiki/Download_Old_Builds_5_0) because of this.
+ * [Docker](https://www.docker.com/)
 
 ## Getting Started
 Once you've installed the required tools:
@@ -17,72 +13,13 @@ Once you've installed the required tools:
 
   > The `secret` key can be whatever. It's used by express's session module. The `apis.youtube.key` value can be obtained by setting up a [YouTube API Key](https://developers.google.com/youtube/v3/getting-started).
 
-4. `vagrant up`
-5. `vagrant reload`
+4. `docker-compose build`
+5. `docker-compose up`
 
 This will ensure that the services we've created start up correctly.
 
-Once this is done you should be able to access Musare in your local browser at [172.16.1.2](http://172.16.1.2). To access the RethinkDB admin panel, go to [172.16.1.2:8080](http://172.16.1.2:8080) in your local web browser.
-
-You can also now access your machine using:
-
-`vagrant ssh`
-
-Or if you have [mosh](https://mosh.org/) installed (and have ran `vagrant plugin install vagrant-mosh`), you can run:
-
-`vagrant mosh`
-
-If changes are made to `bootstrap.sh`, you will need to run `vagrant provision`.
-
-You can run `vagrant` to view more options.
-
-### Development
-Make sure to `vagrant ssh` from the root of the repo before calling these (make sure your ssh'd into the vagrant machine).
-
-```bash
-# Start backend server
-cd /musare; sudo nodemon -L backend/app.js --ignore 'frontend/*'
-
-# Build frontend in development mode
-cd /musare/frontend; npm run development
-
-# Build frontend in production mode
-cd /musare/frontend; npm run production
+Once this is done you should be able to access Musare in your local browser at [localhost](http://localhost:8080/).
 
-# Automatically build frontend in development mode when files change
-cd /musare/frontend; npm run development-watch
-```
-
-### Production (these can also be used in development)
-Make sure to `vagrant ssh` from the root of the repo before calling these (make sure your ssh'd into the vagrant machine).
-
-```bash
-# Start the production server
-sudo service musare start
-
-# Start the mongodb database server
-sudo service mongodb start
-```
-
-##### Logs
-
-You can view logs at the following locations:
-
-* Musare: `/var/log/upstart/musare.log`
-* mongoDB: `/var/log/upstart/mongodb.log`
+  > The backend is at [localhost:8081](http://localhost:8081/).
 
 ### FAQ
-
-##### What does `vagrant up` do?
-This will pull down the Ubuntu 14.04 vagrant box and setup a virtualbox machine for you. It'll ask you what network interface you want the virtualbox machine to connect to the internet with. On macOS I typically choose `en0: Wi-Fi (AirPort)`, but it'll be different on different platforms. It will then run the commands in the `bootstrap.sh` file on this virtual machine. This will install nodejs, rethinkdb, and a bunch of other goodies. This same file could be ran on a production Ubuntu 14.04 server with very little modifications (if any at all).
-
-##### What does `vagrant ssh` and `vagrant mosh` do?
-Vagrant automagically generates and inserts a openssh keypair for you. This doesn't really have any security (as it doesn't really need to be since it's only for development). This allows you to access your machine in a very convenient way. The second command, `vagrant mosh`, is actually just a vagrant plugin. Mosh is a replacement for SSH, and if you haven't checked it out before, you really should! :)
-
-##### Why use Vagrant? I can run NodeJS and mongoDB locally
-The reason for using vagrant is simple. It gives every developer the same local development server. This removes any inconsistencies across different dev enviroments (Windows vs macOS vs Linux). It also ensures that your changes are running on an environment that exactly matches the production server.
-
-### Common issues and fixes
-
-##### Node-sass issue
-Sometimes you might get an issue with node-sass. To fix this, run `cd /musare/frontend; sudo npm rebuild node-sass --no-bin-links`.

+ 0 - 30
Vagrantfile

@@ -1,30 +0,0 @@
-# -*- mode: ruby -*-
-# vi: set ft=ruby :
-
-HOST_SSH_PORT = 2260
-
-Vagrant.configure(2) do |config|
-
-	config.vm.box = "ubuntu/trusty64"
-
-	config.vm.provider :virtualbox do |v|
-    	v.customize ["modifyvm", :id, "--memory", 1024]
-    end
-
-	config.vm.network "public_network"
-
-	config.vm.network "private_network", :ip => '172.16.1.2'
-
-	config.vm.network :forwarded_port, guest: 22, host: 2222, id: "ssh", disabled: true
-	config.vm.network :forwarded_port, guest: 22, host: HOST_SSH_PORT, auto_correct: true
-
-	config.ssh.port = HOST_SSH_PORT
-	config.ssh.guest_port = 22
-
-	config.vm.synced_folder '.', '/vagrant', disabled: true
-	config.vm.synced_folder ".", "/musare"
-
-	config.vm.provision "shell", path: "bootstrap.sh"
-
-end
-

+ 23 - 0
backend/Dockerfile

@@ -0,0 +1,23 @@
+FROM alpine
+
+RUN apk update && apk upgrade
+RUN apk add openssl
+RUN apk add curl
+RUN apk add git
+RUN apk add python
+RUN apk add nodejs
+RUN apk add gcc
+RUN apk add g++
+RUN apk add make
+
+RUN npm install nodemon -g
+
+RUN mkdir -p /opt
+WORKDIR /opt
+ADD package.json /opt/package.json
+
+RUN npm install
+
+EXPOSE 80
+
+CMD npm run development

+ 3 - 5
backend/app.js

@@ -5,7 +5,7 @@ const path = require('path'),
       fs   = require('fs'),
       os   = require('os');
 
-process.env.NODE_CONFIG_DIR = `${process.cwd()}/config`;
+process.env.NODE_CONFIG_DIR = `${__dirname}/config`;
 
 // npm modules
 const express          = require('express'),
@@ -26,7 +26,7 @@ const express          = require('express'),
 const global = require('./logic/global');
 
 // database
-const MongoDB = mongoose.connect('mongodb://localhost:27017/musare').connection;
+const MongoDB = mongoose.connect('mongodb://172.16.0.1:27017/musare').connection;
 
 MongoDB.on('error', (err) => {
 	console.log('Database error: ' + err.message);
@@ -110,9 +110,7 @@ function setupExpress() {
 	app.use(bodyParser.urlencoded({
 		extended: true
 	}));
-
-	app.use(express.static(__dirname + '/../frontend/build/'));
-
+	
 	app.get('*', (req, res) => {
 		res.redirect('/');
 	});

+ 4 - 0
backend/package.json

@@ -5,6 +5,10 @@
   "main": "app.js",
   "author": "Musare Team",
   "repository": "https://github.com/Musare/MusareNode",
+  "scripts": {
+    "development": "nodemon -L /opt/app",
+    "production": "node /opt/app/app.js"
+  },
   "dependencies": {
     "async": "2.0.1",
     "bcrypt": "^0.8.7",

+ 0 - 120
bootstrap.sh

@@ -1,120 +0,0 @@
-#!/usr/bin/env bash
-
-function command_exists { type "$1" &> /dev/null; }
-
-# install mosh
-if command_exists "mosh"; then
-	echo "Skipping mosh install"
-else
-	echo "Installing mosh"
-	sudo apt-get install -y mosh
-fi
-
-# install python
-if command_exists "py"; then
-	echo "Skipping python install"
-else
-	echo "Installing python"
-	sudo apt-get install -y python2.7
-fi
-
-# install build-essential
-if command_exists "build-essential"; then
-	echo "Skipping build-essential install"
-else
-	echo "Installing build-essential"
-	sudo apt-get install -y build-essential
-fi
-
-# install NodeJS
-if command_exists "nodejs"; then
-	echo "Skipping nodejs install"
-else
-	echo "Installing nodejs"
-	curl -sL https://deb.nodesource.com/setup_6.x | sudo -E bash -
-	sudo apt-get install -y nodejs
-fi
-
-# install mongodb
-if command_exists "mongo"; then
-	echo "Skipping mongodb install"
-else
-	echo "Installing mongodb"
-	sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv EA312927
-	echo "deb http://repo.mongodb.org/apt/ubuntu xenial/mongodb-org/3.2 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-3.2.list
-	sudo apt-get update
-	sudo apt-get install -y mongodb-org
-fi
-
-# setup a service for mongodb
-if [ -f /etc/init/mongodb.conf ]; then
-	echo "Skipping mongodb service"
-else
-	echo "Setting up mongoDB service"
-	sudo tee -a /etc/init/mongodb.conf > /dev/null <<EOF
-description "Service file for starting / stopping mongodb"
-author "Musare Developers"
-start on filesystem
-stop on shutdown
-console log
-script
-	exec mongod
-end script
-pre-start script
-	echo "[\`date\`] mongodb starting" >> /var/log/mongodb.log
-end script
-pre-stop script
-	rm /var/run/mongodb.pid
-	echo "[\`date\`] mongodb stopping" >> /var/log/mongodb.log
-end script
-EOF
-fi
-
-# setup a service for Musare
-if [ -f /etc/init/musare.conf ]; then
-	echo "Skipping musare service"
-else
-	echo "Setting up musare service"
-	sudo tee -a /etc/init/musare.conf > /dev/null <<EOF
-description "Service file for starting / stopping musare"
-author "Musare Developers"
-
-start on filesystem
-stop on shutdown
-
-setgid www-data
-console log
-
-script
-	until mountpoint -q /musare; do sleep 1; done
-	echo \$\$ > /var/run/musare.pid
-	cd /musare/backend/
-	nodemon -L app.js
-end script
-
-pre-start script
-	echo "[\`date\`] musare starting" >> /var/log/musare.log
-end script
-
-pre-stop script
-	rm /var/run/musare.pid
-	echo "[\`date\`] musare stopping" >> /var/log/musare.log
-end script
-EOF
-fi
-
-# automatically install all of our dependencies
-cd /musare
-
-cd backend
-npm install --no-bin-links && npm prune
-cd ../
-
-cd frontend
-npm install --no-bin-links && npm prune
-cd ../
-
-sudo npm install -g nodemon
-sudo npm install -g webpack
-
-sudo mkdir -p /data/db

+ 20 - 0
docker-compose.yml

@@ -0,0 +1,20 @@
+version: '2'
+services:
+  backend:
+    build: ./backend
+    ports:
+    - "8081:80"
+    volumes:
+    - ./backend:/opt/app
+    links:
+    - mongo
+  frontend:
+    build: ./frontend
+    ports:
+    - "8080:80"
+    volumes:
+    - ./frontend:/opt/app
+  mongo:
+    image: mongo
+    ports:
+    - "27017:27017"

+ 1 - 1
frontend/App.vue

@@ -39,7 +39,7 @@
 		},
 		ready: function() {
 			let local = this;
-			local.socket = io();
+			local.socket = io(window.location.protocol + '//' + window.location.hostname + ':8081');
 			local.socket.on("ready", status => {
 				local.loggedIn = status;
 			});

+ 26 - 0
frontend/Dockerfile

@@ -0,0 +1,26 @@
+FROM alpine
+
+RUN apk update && apk upgrade
+RUN apk add openssl
+RUN apk add curl
+RUN apk add git
+RUN apk add python
+RUN apk add nodejs
+RUN apk add gcc
+RUN apk add g++
+RUN apk add make
+RUN apk add nginx
+
+RUN npm install -g webpack
+
+RUN mkdir -p /opt
+WORKDIR /opt
+ADD package.json /opt/package.json
+
+RUN npm install
+
+RUN mkdir -p /run/nginx
+
+EXPOSE 80
+
+CMD nginx -c /opt/app/nginx.conf; cd /opt/app; npm run development-watch

+ 24 - 0
frontend/nginx.conf

@@ -0,0 +1,24 @@
+worker_processes  1;
+
+events {
+    worker_connections  1024;
+}
+
+http {
+    include       /etc/nginx/mime.types;
+    default_type  application/octet-stream;
+
+    sendfile        on;
+
+    keepalive_timeout  65;
+
+    server {
+        listen       80;
+        server_name  localhost;
+
+        location / {
+            root   /opt/app/build;
+            index  index.html;
+        }
+    }
+}