mirror of
https://gitlab.com/SIGBUS/nyaa.git
synced 2025-01-10 10:54:08 +00:00
feature: docker development environment (#544)
Add docker support It's self-contained so should not interfere with anything else and can easily be thrown out if nobody wants it anymore.
This commit is contained in:
parent
a6d800b4ca
commit
18ebf134d5
17
.docker/Dockerfile
Normal file
17
.docker/Dockerfile
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
FROM ubuntu:18.04
|
||||||
|
|
||||||
|
ENV LANG=en_US.utf-8 LC_ALL=en_US.utf-8 DEBIAN_FRONTEND=noninteractive
|
||||||
|
RUN apt-get -y update
|
||||||
|
|
||||||
|
COPY ./ /nyaa/
|
||||||
|
RUN cat /nyaa/config.example.py /nyaa/.docker/nyaa-config-partial.py > /nyaa/config.py
|
||||||
|
|
||||||
|
# Requirements for running the Flask app
|
||||||
|
RUN apt-get -y install build-essential git python3 python3-pip libmysqlclient-dev curl
|
||||||
|
# Helpful stuff for the docker entrypoint.sh script
|
||||||
|
RUN apt-get -y install mariadb-client netcat
|
||||||
|
|
||||||
|
WORKDIR /nyaa
|
||||||
|
RUN pip3 install -r requirements.txt
|
||||||
|
|
||||||
|
CMD ["/nyaa/.docker/entrypoint.sh"]
|
46
.docker/README.md
Normal file
46
.docker/README.md
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
# Nyaa on Docker
|
||||||
|
|
||||||
|
Docker infrastructure is provided to ease setting up a dev environment
|
||||||
|
|
||||||
|
## Quickstart
|
||||||
|
|
||||||
|
Get started by running (from the root of the project):
|
||||||
|
|
||||||
|
docker-compose -f .docker/full-stack.yml -p nyaa build nyaa-flask
|
||||||
|
docker-compose -f .docker/full-stack.yml -p nyaa up -d
|
||||||
|
|
||||||
|
This builds the Flask app container, then starts up the project. You can then go
|
||||||
|
to [localhost:8080](http://localhost:8080/) (note that some of the
|
||||||
|
services are somewhat slow to start so it may not be available for 30s or so).
|
||||||
|
|
||||||
|
You can shut it down with:
|
||||||
|
|
||||||
|
docker-compose -f .docker/full-stack.yml -p nyaa down
|
||||||
|
|
||||||
|
## Details
|
||||||
|
|
||||||
|
The environment includes:
|
||||||
|
- [nginx frontend](http://localhost:8080/) (on port 8080)
|
||||||
|
- uwsgi running the flask app
|
||||||
|
- the ES<>MariaDB sync process
|
||||||
|
- MariaDB
|
||||||
|
- ElasticSearch
|
||||||
|
- [Kibana](http://localhost:8080/kibana/) (at /kibana/)
|
||||||
|
|
||||||
|
MariaDB, ElasticSearch, the sync process, and uploaded torrents will
|
||||||
|
persistently store their data in volumes which makes future start ups faster.
|
||||||
|
|
||||||
|
To make it more useful to develop with, you can copy `.docker/full-stack.yml` and
|
||||||
|
edit the copy and uncomment the `- "${NYAA_SRC_DIR}:/nyaa"` line, then
|
||||||
|
`export NYAA_SRC_DIR=$(pwd)` and start up the environment using the new compose
|
||||||
|
file:
|
||||||
|
|
||||||
|
cp -a .docker/full-stack.yml .docker/local-dev.yml
|
||||||
|
cat config.example.py .docker/nyaa-config-partial.py > ./config.py
|
||||||
|
$EDITOR .docker/local-dev.yml
|
||||||
|
export NYAA_SRC_DIR=$(pwd)
|
||||||
|
docker-compose -f .docker/local-dev.yml -p nyaa up -d
|
||||||
|
|
||||||
|
This will mount the local copy of the project files into the Flask container,
|
||||||
|
which combined with live-reloading in uWSGI should let you make changes and see
|
||||||
|
them take effect immediately (technically with a ~2 second delay).
|
32
.docker/entrypoint-sync.sh
Executable file
32
.docker/entrypoint-sync.sh
Executable file
|
@ -0,0 +1,32 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# set +x
|
||||||
|
|
||||||
|
pushd /nyaa
|
||||||
|
|
||||||
|
echo 'Waiting for MySQL to start up'
|
||||||
|
while ! echo HELO | nc mariadb 3306 &>/dev/null; do
|
||||||
|
sleep 1
|
||||||
|
done
|
||||||
|
echo 'DONE'
|
||||||
|
|
||||||
|
echo 'Waiting for ES to start up'
|
||||||
|
while ! echo HELO | nc elasticsearch 9200 &>/dev/null; do
|
||||||
|
sleep 1
|
||||||
|
done
|
||||||
|
echo 'DONE'
|
||||||
|
|
||||||
|
echo 'Waiting for ES to be ready'
|
||||||
|
while ! curl -s -XGET 'elasticsearch:9200/_cluster/health?pretty=true&wait_for_status=green' &>/dev/null; do
|
||||||
|
sleep 1
|
||||||
|
done
|
||||||
|
echo 'DONE'
|
||||||
|
|
||||||
|
echo 'Waiting for sync data file to exist'
|
||||||
|
while ! [ -f /elasticsearch-sync/pos.json ]; do
|
||||||
|
sleep 1
|
||||||
|
done
|
||||||
|
echo 'DONE'
|
||||||
|
|
||||||
|
echo 'Starting the sync process'
|
||||||
|
/usr/bin/python3 /nyaa/sync_es.py /nyaa/.docker/es_sync_config.json
|
50
.docker/entrypoint.sh
Executable file
50
.docker/entrypoint.sh
Executable file
|
@ -0,0 +1,50 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# set +x
|
||||||
|
|
||||||
|
pushd /nyaa
|
||||||
|
|
||||||
|
echo 'Waiting for MySQL to start up'
|
||||||
|
while ! echo HELO | nc mariadb 3306 &>/dev/null; do
|
||||||
|
sleep 1
|
||||||
|
done
|
||||||
|
echo 'DONE'
|
||||||
|
|
||||||
|
if ! [ -f /elasticsearch-sync/flag-db_create ]; then
|
||||||
|
python3 ./db_create.py
|
||||||
|
touch /elasticsearch-sync/flag-db_create
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! [ -f /elasticsearch-sync/flag-db_migrate ]; then
|
||||||
|
python3 ./db_migrate.py stamp head
|
||||||
|
touch /elasticsearch-sync/flag-db_migrate
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo 'Waiting for ES to start up'
|
||||||
|
while ! echo HELO | nc elasticsearch 9200 &>/dev/null; do
|
||||||
|
sleep 1
|
||||||
|
done
|
||||||
|
echo 'DONE'
|
||||||
|
|
||||||
|
echo 'Waiting for ES to be ready'
|
||||||
|
while ! curl -s -XGET 'elasticsearch:9200/_cluster/health?pretty=true&wait_for_status=green' &>/dev/null; do
|
||||||
|
sleep 1
|
||||||
|
done
|
||||||
|
echo 'DONE'
|
||||||
|
|
||||||
|
if ! [ -f /elasticsearch-sync/flag-create_es ]; then
|
||||||
|
# @source create_es.sh
|
||||||
|
# create indices named "nyaa" and "sukebei", these are hardcoded
|
||||||
|
curl -v -XPUT 'elasticsearch:9200/nyaa?pretty' -H"Content-Type: application/yaml" --data-binary @es_mapping.yml
|
||||||
|
curl -v -XPUT 'elasticsearch:9200/sukebei?pretty' -H"Content-Type: application/yaml" --data-binary @es_mapping.yml
|
||||||
|
touch /elasticsearch-sync/flag-create_es
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! [ -f /elasticsearch-sync/flag-import_to_es ]; then
|
||||||
|
python3 ./import_to_es.py | tee /elasticsearch-sync/import.out
|
||||||
|
grep -A1 'Save the following' /elasticsearch-sync/import.out | tail -1 > /elasticsearch-sync/pos.json
|
||||||
|
touch /elasticsearch-sync/flag-import_to_es
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo 'Starting the Flask app'
|
||||||
|
/usr/local/bin/uwsgi /nyaa/.docker/uwsgi.config.ini
|
11
.docker/es_sync_config.json
Normal file
11
.docker/es_sync_config.json
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
{
|
||||||
|
"save_loc": "/elasticsearch-sync/pos.json",
|
||||||
|
"mysql_host": "mariadb",
|
||||||
|
"mysql_port": 3306,
|
||||||
|
"mysql_user": "nyaadev",
|
||||||
|
"mysql_password": "ZmtB2oihHFvc39JaEDoF",
|
||||||
|
"database": "nyaav2",
|
||||||
|
"internal_queue_depth": 10000,
|
||||||
|
"es_chunk_size": 10000,
|
||||||
|
"flush_interval": 5
|
||||||
|
}
|
71
.docker/full-stack.yml
Normal file
71
.docker/full-stack.yml
Normal file
|
@ -0,0 +1,71 @@
|
||||||
|
---
|
||||||
|
|
||||||
|
version: "3"
|
||||||
|
services:
|
||||||
|
nginx:
|
||||||
|
image: nginx:1.15-alpine
|
||||||
|
ports:
|
||||||
|
- '8080:80'
|
||||||
|
volumes:
|
||||||
|
- './nginx.conf:/etc/nginx/nginx.conf:ro'
|
||||||
|
- '../nyaa/static:/nyaa-static:ro'
|
||||||
|
depends_on:
|
||||||
|
- nyaa-flask
|
||||||
|
- kibana
|
||||||
|
|
||||||
|
nyaa-flask:
|
||||||
|
image: local/nyaa:devel
|
||||||
|
volumes:
|
||||||
|
- 'nyaa-torrents:/nyaa-torrents'
|
||||||
|
- 'nyaa-sync-data:/elasticsearch-sync'
|
||||||
|
## Uncomment this line to have to mount the local dir to the running
|
||||||
|
## instance for live changes (after setting NYAA_SRC_DIR env var)
|
||||||
|
# - "${NYAA_SRC_DIR}:/nyaa"
|
||||||
|
depends_on:
|
||||||
|
- mariadb
|
||||||
|
- elasticsearch
|
||||||
|
build:
|
||||||
|
context: ../
|
||||||
|
dockerfile: ./.docker/Dockerfile
|
||||||
|
|
||||||
|
nyaa-sync:
|
||||||
|
image: local/nyaa:devel
|
||||||
|
volumes:
|
||||||
|
- 'nyaa-sync-data:/elasticsearch-sync'
|
||||||
|
command: /nyaa/.docker/entrypoint-sync.sh
|
||||||
|
depends_on:
|
||||||
|
- mariadb
|
||||||
|
- elasticsearch
|
||||||
|
restart: on-failure
|
||||||
|
|
||||||
|
mariadb:
|
||||||
|
image: mariadb:10.0
|
||||||
|
volumes:
|
||||||
|
- './mariadb-init-sql:/docker-entrypoint-initdb.d:ro'
|
||||||
|
- '../configs/my.cnf:/etc/mysql/conf.d/50-binlog.cnf:ro'
|
||||||
|
- 'mariadb-data:/var/lib/mysql'
|
||||||
|
environment:
|
||||||
|
- MYSQL_RANDOM_ROOT_PASSWORD=yes
|
||||||
|
- MYSQL_USER=nyaadev
|
||||||
|
- MYSQL_PASSWORD=ZmtB2oihHFvc39JaEDoF
|
||||||
|
- MYSQL_DATABASE=nyaav2
|
||||||
|
|
||||||
|
elasticsearch:
|
||||||
|
image: elasticsearch:6.5.4
|
||||||
|
volumes:
|
||||||
|
- elasticsearch-data:/usr/share/elasticsearch/data
|
||||||
|
depends_on:
|
||||||
|
- mariadb
|
||||||
|
|
||||||
|
kibana:
|
||||||
|
image: kibana:6.5.4
|
||||||
|
volumes:
|
||||||
|
- './kibana.config.yml:/usr/share/kibana/config/kibana.yml:ro'
|
||||||
|
depends_on:
|
||||||
|
- elasticsearch
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
nyaa-torrents:
|
||||||
|
nyaa-sync-data:
|
||||||
|
mariadb-data:
|
||||||
|
elasticsearch-data:
|
9
.docker/kibana.config.yml
Normal file
9
.docker/kibana.config.yml
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
---
|
||||||
|
|
||||||
|
server.name: kibana
|
||||||
|
server.host: 'kibana'
|
||||||
|
server.basePath: /kibana
|
||||||
|
# server.rewriteBasePath: true
|
||||||
|
# server.defaultRoute: /kibana/app/kibana
|
||||||
|
elasticsearch.url: http://elasticsearch:9200
|
||||||
|
xpack.monitoring.ui.container.elasticsearch.enabled: true
|
1
.docker/mariadb-init-sql/.gitignore
vendored
Normal file
1
.docker/mariadb-init-sql/.gitignore
vendored
Normal file
|
@ -0,0 +1 @@
|
||||||
|
!*.sql
|
3
.docker/mariadb-init-sql/50-grant-binlog-access.sql
Normal file
3
.docker/mariadb-init-sql/50-grant-binlog-access.sql
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
GRANT REPLICATION SLAVE ON *.* TO 'nyaadev'@'%';
|
||||||
|
GRANT REPLICATION CLIENT ON *.* TO 'nyaadev'@'%';
|
||||||
|
FLUSH PRIVILEGES;
|
59
.docker/nginx.conf
Normal file
59
.docker/nginx.conf
Normal file
|
@ -0,0 +1,59 @@
|
||||||
|
|
||||||
|
user nginx;
|
||||||
|
worker_processes 1;
|
||||||
|
|
||||||
|
error_log /var/log/nginx/error.log warn;
|
||||||
|
pid /var/run/nginx.pid;
|
||||||
|
|
||||||
|
|
||||||
|
events {
|
||||||
|
worker_connections 1024;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
http {
|
||||||
|
include /etc/nginx/mime.types;
|
||||||
|
default_type application/octet-stream;
|
||||||
|
charset utf-8;
|
||||||
|
|
||||||
|
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
|
||||||
|
'$status $body_bytes_sent "$http_referer" '
|
||||||
|
'"$http_user_agent" "$http_x_forwarded_for"';
|
||||||
|
|
||||||
|
access_log /var/log/nginx/access.log main;
|
||||||
|
|
||||||
|
sendfile on;
|
||||||
|
#tcp_nopush on;
|
||||||
|
|
||||||
|
keepalive_timeout 65;
|
||||||
|
|
||||||
|
gzip on;
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen 80;
|
||||||
|
server_name localhost default;
|
||||||
|
|
||||||
|
location /static {
|
||||||
|
alias /nyaa-static;
|
||||||
|
}
|
||||||
|
|
||||||
|
# fix kibana redirecting to localhost/kibana (without the port)
|
||||||
|
rewrite ^/kibana$ http://$http_host/kibana/ permanent;
|
||||||
|
location /kibana/ {
|
||||||
|
proxy_http_version 1.1;
|
||||||
|
proxy_set_header Upgrade $http_upgrade;
|
||||||
|
proxy_set_header Connection 'upgrade';
|
||||||
|
proxy_cache_bypass $http_upgrade;
|
||||||
|
|
||||||
|
proxy_set_header Host 'kibana';
|
||||||
|
proxy_set_header X-Real-IP $remote_addr;
|
||||||
|
|
||||||
|
proxy_pass http://kibana:5601/;
|
||||||
|
}
|
||||||
|
|
||||||
|
location / {
|
||||||
|
include /etc/nginx/uwsgi_params;
|
||||||
|
uwsgi_pass nyaa-flask:5000;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
10
.docker/nyaa-config-partial.py
Normal file
10
.docker/nyaa-config-partial.py
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
# This is only a partial config file that will be appended to the end of
|
||||||
|
# config.example.py to build the full config for the docker environment
|
||||||
|
|
||||||
|
SITE_NAME = 'Nyaa [DEVEL]'
|
||||||
|
GLOBAL_SITE_NAME = 'nyaa.devel'
|
||||||
|
SQLALCHEMY_DATABASE_URI = ('mysql://nyaadev:ZmtB2oihHFvc39JaEDoF@mariadb/nyaav2?charset=utf8mb4')
|
||||||
|
# MAIN_ANNOUNCE_URL = 'http://chihaya:6881/announce'
|
||||||
|
# TRACKER_API_URL = 'http://chihaya:6881/api'
|
||||||
|
BACKUP_TORRENT_FOLDER = '/nyaa-torrents'
|
||||||
|
ES_HOSTS = ['elasticsearch:9200']
|
34
.docker/uwsgi.config.ini
Normal file
34
.docker/uwsgi.config.ini
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
[uwsgi]
|
||||||
|
# socket = [addr:port]
|
||||||
|
socket = 0.0.0.0:5000
|
||||||
|
#chmod-socket = 664
|
||||||
|
|
||||||
|
die-on-term = true
|
||||||
|
|
||||||
|
# logging
|
||||||
|
#disable-logging = True
|
||||||
|
#logger = file:uwsgi.log
|
||||||
|
|
||||||
|
# Base application directory
|
||||||
|
chdir = /nyaa
|
||||||
|
|
||||||
|
# WSGI module and callable
|
||||||
|
# module = [wsgi_module_name]:[application_callable_name]
|
||||||
|
module = WSGI:app
|
||||||
|
|
||||||
|
# master = [master process (true of false)]
|
||||||
|
master = true
|
||||||
|
|
||||||
|
# debugging
|
||||||
|
catch-exceptions = true
|
||||||
|
|
||||||
|
# performance
|
||||||
|
processes = 4
|
||||||
|
buffer-size = 8192
|
||||||
|
|
||||||
|
loop = gevent
|
||||||
|
socket-timeout = 10
|
||||||
|
gevent = 1000
|
||||||
|
gevent-monkey-patch = true
|
||||||
|
|
||||||
|
py-autoreload = 2
|
Loading…
Reference in a new issue