Deploying Trains Server: Linux or Mac OS X
Deploy the Trains Server in Linux or Mac OS X using our prebuilt Docker image.
Trains on Docker Hub
For Trains docker images, including previous versions, see Trains in Docker Hub. However, pulling the Trains Docker image directly is not required. We provide a docker compose YAML file that does this for you. The docker compose file is included in the instructions on this page.
For Linux users only:
- You must be logged in as a user with sudo privileges.
- Use bash for all command-line instructions in this installation.
To launch Trains Server on Linux or Mac OS X:
- Install Docker. The instructions depend upon your operating system:
- Verify the Docker CE installation. Execute the command:
The expected is output is:
sudo docker run hello-world
Hello from Docker! This message shows that your installation appears to be working correctly. To generate this message, Docker took the following steps: 1. The Docker client contacted the Docker daemon. 2. The Docker daemon pulled the "hello-world" image from the Docker Hub. (amd64) 3. The Docker daemon created a new container from that image which runs the executable that produces the output you are currently reading. 4. The Docker daemon streamed that output to the Docker client, which sent it to your terminal.
- For Linux, only, install docker-compose. Execute the following commands (for more information,
see Install Docker Compose in the Docker documentation):
sudo curl -L "https://github.com/docker/compose/releases/download/1.24.1/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose sudo chmod +x /usr/local/bin/docker-compose
- Increase vm.max_map_count for ElasticSearch in Docker. Execute the following commands, depending upon your operating system:
echo "vm.max_map_count=262144" > /tmp/99-trains.conf sudo mv /tmp/99-trains.conf /etc/sysctl.d/99-trains.conf sudo sysctl -w vm.max_map_count=262144 sudo service docker restart
Mac OS X:
screen ~/Library/Containers/com.docker.docker/Data/vms/0/tty sysctl -w vm.max_map_count=262144
- Remove any previous installation of Trains Server.
This clears all existing Trains SDK databases.
sudo rm -R /opt/trains/
- Create local directories for the databases and storage.
sudo mkdir -p /opt/trains/data/elastic sudo mkdir -p /opt/trains/data/mongo/db sudo mkdir -p /opt/trains/data/mongo/configdb sudo mkdir -p /opt/trains/data/redis sudo mkdir -p /opt/trains/logs sudo mkdir -p /opt/trains/config sudo mkdir -p /opt/trains/data/fileserver
- For Mac OS X, only, do the following:
- Open the Docker app.
- Select Preferences.
- On the File Sharing tab, add /opt/trains.
- Grant access to the Dockers, depending upon your operating system.
sudo chown -R 1000:1000 /opt/trains
Mac OS X:
sudo chown -R $(whoami):staff /opt/trains
- Download the Trains Server docker-compose YAML file.
cd /opt/trains curl https://raw.githubusercontent.com/allegroai/trains-server/master/docker-compose.yml -o docker-compose.yml
- Run docker-compose with the downloaded configuration file.
sudo docker-compose -f docker-compose.yml up
Your server is now running on http://localhost:8080.
After deploying Trains Server, the services expose the following ports:
- Web server on port 8080.
- API server on port 8008.
- File server on port 8081.
For detailed instructions, see Trains Server in Linux or Mac OS X, see Upgrading Trains Server.