Skip to content

Latest commit

 

History

History
106 lines (96 loc) · 2.86 KB

README.md

File metadata and controls

106 lines (96 loc) · 2.86 KB

#Chess Platform (server) a django chess platform server that uses:

  • celery for async work (like finding best chess move when playing against AI)
  • postgresql database for fast concurrent use
  • channels to push data to users instead of polling
  • stockfish to find best move in a given position
  • supervisor to make sure the server is always running (after reboot and crashes)
  • nginx to serve static files
  • daphne to run the django asgi

#Installation Notes (Debian) ##Step 1:Software you need

apt-get redis-server supervisor python-dev python-virtualenv postgresql postgresql-contrib libpq-dev git git-core stockfish build-essential nginx libevent-dev

##Step 2: Set up project, users and database log in to postgres user and create a new database and a database user

$ su postgres
$ createuser --interactive -P
Enter name of role to add: chess
Enter password for new role:
Enter it again: 
Shall the new role be a superuser? (y/n) n
Shall the new role be allowed to create databases? (y/n) n
Shall the new role be allowed to create more new roles? (y/n) n

$ createdb --owner chess chessdb
$ logout

set up the user the application will run on

$ sudo groupadd --system app
$ sudo useradd --system --gid app --shell /bin/bash --home /apps/chess-server chess

set up project directory

$ mkdir /apps/
$ chown chess /apps/

$ su - chess
$ cd /apps
$ git clone https://github.com/reaVen-/chess-server.git
$ cd chess-server
$ virtualenv .
$ source bin/activate
$ pip install --upgrade pip
$ pip install -r requirements.txt

configure django with your database (set database passwords etc)

$ cp example_configs/local_settings.py chess
$ nano chess/local_settings.py

build the initial database

$ python manage.py migrate
$ python manage.py collectstatic

test the server

$ python manage.py runserver

##Step 3: Configure daphne to run your app test that daphne works

$ daphne chess.asgi:channel_layer -h 0.0.0.0 -p 8888

make sure celery and daphne is always running afer reboot, crash etc with supervisor (root terminal)

$ cp /apps/chess-server/example_configs/celery-chess.conf /etc/supervisor/conf.d/
$ cp /apps/chess-server/example_configs/daphne-chess.conf /etc/supervisor/conf.d/

create logs directory in /apps/chess-server/

$ mkdir logs

make supervisor see the changes (root terminal)

$ supervisorctl reread
$ supervisorctl update

##Step 4: Make nginx serve static files set up nginx (root terminal)

$ cp /apps/chess-server/example_configs/chess.nginxconf /etc/nginx/sites-available/chess
$ ln -s /etc/nginx/sites-available/chess /etc/nginx/sites-enabled/chess
$ service nginx restart

you may have to delete the default nginx config (root terminal)

$ rm /etc/nginx/sites-enabled/default

#Finished That's it you're server should be running you can monitor the logs with for example

tail -f logs/celery-worker.log
```