No description, website, or topics provided.
Switch branches/tags
Nothing to show
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
Mask_RCNN @ 46f8ea5
conf
scripts
src
tests/stresstest
.gitignore
.gitmodules
README.md
examples.txt

README.md

ImageMonkey is a free, public open source dataset. With all the great machine learning frameworks available it's pretty easy to train pre-trained Machine Learning models with your own image dataset. However, in order to do so you need a lot of images. And that's usually the point where it get's tricky. You either have to create the training images yourself or scrape them together from various datasources. ImageMonkey aims to solve this problem, by providing a platform where users can drop their photos, tag them with a label, and put them into public domain.


Alt Text

This repository contains the sourcecode of the ImageMonkey Playground. The ImageMonkey Playground is an online image classification service where users can upload photos which then are classified by a ML model trained with the currently available dataset.

Base System Configuration

  • create a new user 'playgroundwithadduser playground`
  • disable root login via ssh by changing the PermitRootLogin line in /etc/ssh/sshd_config to PermitRootLogin no)
  • block all ports except port 22, 443 and 80 (on eth0) with:
#!bash

iptables -P INPUT DROP && iptables -A INPUT -i eth0 -p tcp --dport 22 -j ACCEPT
iptables -A INPUT -i eth0 -p tcp --dport 443 -j ACCEPT
iptables -A INPUT -i eth0 -p tcp --dport 80 -j ACCEPT
  • allow all established connections with:
#!bash

iptables -A INPUT  -m state --state ESTABLISHED,RELATED -j ACCEPT
iptables -A OUTPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
  • allow all loopback access with:
#!bash
iptables -A INPUT -i lo -j ACCEPT
iptables -A OUTPUT -o lo -j ACCEPT
  • install iptables-persistent to load firewall rules at startup

  • save firewall rules with: iptables-save > /etc/iptables/rules.v4

  • verify that rules are loaded with iptables -L

  • install supervisor with apt-get install supervisor

  • add imagemonkey user to supervisor group with adduser imagemonkey supervisor

  • create logging directories for all the services:

    mkdir -p /var/log/imagemonkey-playground
    mkdir -p /var/log/imagemonkey-playground-autoannotator
    mkdir -p /var/log/imagemonkey-playground-grabcut
    mkdir -p /var/log/imagemonkey-playground-train
    mkdir -p /var/log/imagemonkey-playground-web
    
  • copy conf/supervisor/* to /etc/supervisor/conf.d/

  • run `supervisorctl reread && supervisorctl update && supervisorctl restart all

  • use visudo and add the following entry playground ALL = (root) NOPASSWD:/usr/bin/supervisorctl restart all after the line %sudo ALL=(ALL:ALL) ALL to restart supervisord controlled processes with sudo as non-root user

  • install docker

  • make it possible to let users other than root run docker with:


    #Add the docker group if it doesn't already exist.
    sudo groupadd docker
    
    #Add user 'playgroun' to the docker group.
    sudo gpasswd -a playground docker
    
    #Restart the docker daemon.
    sudo service docker restart
    
    #Change owner of the following files
    chown root:docker /var/run/docker.sock
    chown root:docker /usr/bin/docker