Server for twigslot.com
git clone https://github.com/twigslot/twig-server
cd twig-server
cp .env.example .env
# make sure neo4j fully loaded before loading the rest,
# otherwise service "server" complains
docker-compose up -d neo4j
docker-compose logs -f neo4j
# after neo4j loaded you can bring up the rest
docker-compose up -d
Note that building the images the first time takes longer, but after docker caches some image layers, the waiting time becomes more bearable.
Make sure the following ports are free on your host.
3000
for the login/signup UI, currently from Ory but will eventually be replaced4433
for Ory Kratos API, an identity management system4434
for Ory Kratos Admin API, untouched for the most part5000
for the TwigSlot Flask API server, where majority of development will take place7474, 7473, 7687
for a local Neo4J instance (currently unused), though we are currently using Neo4J cloud.
You may use docker ps
to see the port mappings.
After development, docker-compose down
to free up cpu resouces and host ports.
In order to debug the Flask api server (./server.py
) within the docker container or enable hot reload, you can build it with
docker-compose \
-f docker-compose.yml \
-f docker-compose-debug.yml \
up -d --build --force-recreate server
If you're developing on mac, which does not have native docker virtualization support, http://localhost:3000
and related servers may not be accessible. We will use SSH portforwarding to solve this.
If you run docker on mac using eval $(docker-machine env default)
, the networking issues are due to the fact that docker containers run inside a virtualbox container. A quick fix for this is to run
ssh docker@$(docker-machine ip default) -N -f \
-L 3000:localhost:3000 \
-L 5000:localhost:5000 \
-L 5001:localhost:5001 \
-L 4433:localhost:4433 \
-L 4434:localhost:4434 \
-L 4455:localhost:4455
A password will be prompted for the virtualbox container, which is tcuser
by default.
This is abit complicated as it involves many moving parts, so this reference is more for myself. You may contact me if you wish to help support deployment.
docker build -t tch1001/twig_server:v1.1 . \
-f ./containers/flask/Dockerfile
docker push tch1001/twig_server:v1.1
kubectl apply -f <all the files>