This repository contains the Docker environment used to make the Asylamba project work.
Docker is a tool which allows us to virtualize our environment, producing containers with stack elements inside.
To learn more, go to the Docker website.
First, clone the project :
git clone git@github.com:rtfmcorp/asylamba-docker.git
cd asylamba-docker
Copy the environment file containing environment variables for Docker Compose, and configure the values:
cp .env.dist .env
nano .env
Now you have to copy the dist file for containers environment variables. This environment variables contain sensitive informations about security aspects of the game, like database access or game admin scripts access.
cp asylamba.dist.env asylamba.env
You can keep the default values in a local environment, but we highly recommend that you set more complex values in a remote environment.
Here is the documentation about the values :
# All variables prefixed with ASYLAMBA_ will be used as parameters in the game container
# For more informations, please refer to the game documentation
# The ID which identifies the game server to the main portal API
ASYLAMBA_SERVER_ID=0
# The DNS of the game, for static files and Ajax calls
ASYLAMBA_SERVER_HOST=local.asylamba.com
# The port of the game server. Please be sure it is an open port of the game container
ASYLAMBA_SERVER_PORT=9999
# The timeout for the socket listening, in seconds. It is the time the game is updated when no user request is performed.
# Be aware that a low value will increase the CPU usage heavily
ASYLAMBA_SERVER_CYCLE_TIMEOUT=20
# Number of listening loops before cleaning the application (garbage collector, etc...)
ASYLAMBA_SERVER_COLLECTION_CYCLES_NUMBER=25
# The start time of the game server
ASYLAMBA_SERVER_START_TIME='2017-05-29 20:00:00'
# The roleplay "year" of the game server at its start
ASYLAMBA_SEGMENT_SHIFT=650
# The host of the database server. Could be an IP address
ASYLAMBA_DATABASE_HOST=asylamba_mysql
ASYLAMBA_DATABASE_NAME=asylamba_game
ASYLAMBA_DATABASE_USER=root
ASYLAMBA_DATABASE_PASSWORD=asylamba
# Admin credentials for the database. Used for admin scripts
ASYLAMBA_DATABASE_ADMIN_USER=root
ASYLAMBA_DATABASE_ADMIN_PASSWORD=asylamba
# Number of task runners that the engine will launch
ASYLAMBA_WORKER_SCALE=3
# Timeout for the task runner socket listening, in seconds.
# Be aware that a low value will increase the CPU usage heavily
ASYLAMBA_WORKER_CYCLE_TIMEOUT=60
# Number of listening loops before cleaning the task runner
ASYLAMBA_WORKER_COLLECTION_CYCLES_NUMBER=5
# The crypting key of the security component
ASYLAMBA_SECURITY_IV=abcde
# Security keys used to access admin views. It must be changed in remote environments
ASYLAMBA_SECURITY_BUFFER_KEY=123456
ASYLAMBA_SECURITY_SERVER_KEY=123456
ASYLAMBA_SECURITY_SCRIPT_KEY=123456
ASYLAMBA_SECURITY_API_KEY=123456
# Redis configuration
ASYLAMBA_REDIS_HOST=asylamba_redis
ASYLAMBA_REDIS_PORT=6379
ASYLAMBA_REDIS_TIMEOUT=1.5
# The environment mode. Behaviour between "dev" and "prod" is not the same for many game components.
# For further information, read the game documentation
ASYLAMBA_ENVIRONMENT=dev
# When set to "enabled", the game will connect to the ASYLAMBA_GETOUT_ROOT API for certain actions such as registration
ASYLAMBA_APIMODE=disabled
# Path to the game root
ASYLAMBA_APP_ROOT=/
# Path to the logout location. It is also used for the moment as the API domain when APIMODE is enabled
ASYLAMBA_GETOUT_ROOT=/buffer/
# This is used to tell Nginx which virtual host it must enable
NGINX_ENABLED_VHOST=asylamba.local,game.asylamba.local,asylamba-preprod.cloudapp.net,s14.asylamba.com
# This one is important. If set to true, it will copy the game version in the built game image.
# If set to true, THIS WILL ERASE THE PREVIOUS CODE; DO NOT SET IT TO TRUE ON LOCAL ENV.
# Set it to true in remote environments, it will deploy the code contained in the new images you will push to production.
DEPLOY_SOURCES=false
# MySQL credentials used by the MySQL container
MYSQL_DATABASES: asylamba_game
MYSQL_ROOT_PASSWORD: asylamba
MYSQL_HOST: localhost
MYSQL_USER: asylamba
MYSQL_PASSWORD: asylamba
Then you have to clone the game sources. It must be located in the volumes/apps/asylamba-game
folder.
Please note that the following command will clone the main repository.
If you want to work for the game, you must fork it first, and then clone your fork.
cd volumes/apps
git clone git@github.com:rtfmcorp/asylamba-game.git
To make the containers run, you can use the following commands :
Please note that the tar
command must be executed once to create an archive of the game.
This archive is mandatory to build the game container.
Once the archive is here, you haven't to execute the tar
command again.
tar -C volumes/apps -cvzf applications/asylamba-game/archives/asylamba_game.tar.gz asylamba-game --exclude .git --exclude *.log
docker-compose build
docker-compose up -d
The shortcut command for this is :
make install
To stop the containers, use docker-compose stop
or make stop
.
To remove the containers (you would need to do it in case of strange problems or build new versions), use docker-compose rm
or make rm
.
To see the containers status, use docker-compose ps
or make status
shortcut command.
To see logs related to a container, use docker logs [container name]
(eg. docker logs asylamba_game
).
The game container is used as a CLI, to launch commands such as PHPUnit or Gulp.
You have two ways of accessing it, when the container is started :
docker exec -it asylamba_game /bin/bash
or the shortcut
make run
You are directly located to the game folder, where you can launch the available commands.
Simply use phpunit
to launch the game test suit.
To access PhpMyAdmin, run your containers and then access to 127.0.0.1:8082
in your browser.
The root credentials are root:asylamba
("asylamba" is the password).
The other available user is asylamba:asylamba
.
A Redis Commander interface is available in dev environment.
You can use it to view the Redis stored items.
The interface is available at the 8081
port.
First, we need to create the SSL certificates to enable HTTPS for the game.
At the Docker project root, run the following command :
sudo openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout volumes/ssl/private/nginx-selfsigned.key -out volumes/ssl/certs/nginx-selfsigned.crt
Fill the required informations to generate the files, which will be injected in the Nginx container.
If your Nginx container was up before the generation, restart it.
To install the game, run the following procedure :
cd volumes/apps
git clone git@github.com:rtfmcorp/asylamba-game.git
You can access the game with the hostname https://local.asylamba.com
.
To enable it on your computer and access it with your browser, you must add these lines to your hosts
file :
127.0.0.1 local.asylamba.com
This file is located in C:\Windows\System32\drivers\etc\hosts
on Windows and /etc/hosts
on Linux.
It should work properly by now :) !
If you want to push a new version of the game in preprod/prod environment (and if such action is granted to you ;)), you will have to build and push a new tag of the game image.
To perform this, you can use two methods. We assume in this example that you want to push v1.1.12.
The short way
make build-game
The less short way
$(eval version = $(shell git -C volumes/apps/asylamba-game describe --tags))
tar -C volumes/apps -cvzf applications/asylamba-game/archives/asylamba_game.tar.gz asylamba-game --exclude .git --exclude *.log
docker-compose build game
docker tag asylamba/game asylamba/game:$(version)
docker tag asylamba/game asylamba/game:latest
docker push docker.io/asylamba/game:$(version)
docker push docker.io/asylamba/game:latest
An explaination of the process is needed.
To deploy the game, we create a compressed archive of it first. Then, when building the image, Docker will add the archive to the image. Then we push the built image to the registry, to be available from all environments.
The short-way
make prod-upgrade
The less short way
docker-compose -f production.yml stop
docker pull asylamba/game
docker-compose -f production.yml rm game
docker-compose -f production.yml up -d
As you may see, it is quite simple, we just stop the stack, remove the old game container, pull the new one and launch the stack again. The sources contained in the new image will be deployed.
Blackfire is a profiling tool allowing us to analyze the behavior and performances of the application.
To use it, you must first get an account on https://blackfire.io and then set the following environment variables :
BLACKFIRE_CLIENT_ID
BLACKFIRE_CLIENT_TOKEN
BLACKFIRE_SERVER_ID
BLACKFIRE_SERVER_TOKEN
An export shortcut with the values associated to your account are available here.
To run a profile, you can use the following command :
docker exec asylamba_blackfire blackfire curl --proxy http://$NGINX_CONTAINER_IP:80 http://game.asylamba.local/
You must replace the $NGINX_CONTAINER_IP
variable with the right value.
To get it, fetch the IP address of your NGINX container with the following command :
docker inspect asylamba_nginx | grep IPAddress
Now you can launch the blackfire command and the profile shall appear in your Blackfire dashboard.
Any feedback and suggestion is welcome, feel free to contact us !