- Create the world
- Running the server
- Additional setup steps
- Managing the server
- Stopping and starting the server
- Updating
- Troubleshooting
There are two different ways to start a screeps server.
If you do not have an existing server directory, just start the Docker container with the command line argument init
, and everything gets done for you. The LOCAL_UID
environment variable ensures that the files that are created in the mounted volume have the correct owner set. You can enter any valid (host) uid here. When omitted the default uid is 9001
.
docker run --rm -it -v ${PWD}/screeps:/screeps -e LOCAL_UID=$(id -u) -e STEAM_KEY=YOUR_STEAM_KEY_HERE qnimbus/docker-screeps init
Now it's all set to run the Screeps server.
Make sure you have a server directory (from aprevious installations or by running the 'init' command above).
You can use 'docker-compose' to start the screeps server, create the screeps_net bridged network and start the redis and mongodb instances.
docker-compose -f docker-compose.yml up -d
If you want to start each container manually follow the steps below.
- Make sure you are in the server directory
- Create the custom bridged network
- Start mongo & redis containers
- Run the server
docker run --rm -it --name screeps --network screeps_net -v ${PWD}/screeps:/screeps -p 21025:21025 -p 21026:21026 -d -e LOCAL_UID=$(id -u) qnimbus/docker-screeps
To build your own (customized) container locally, run the following command:
docker build . -t qnimbus/docker-screeps
Navigate to https://steamcommunity.com/dev/apikey and generate or copy your Steam API key.
You need to add the screeps, mongo and redis containers to a custom bridged network so the container names are resolvable via DNS on the individual containers. If you do not have a separate custom bridged network you can create one as follows:
docker network create --attachable -d "bridge" --subnet 172.28.0.0/16 screeps_net
Note: The subnet can be changed to your individual needs as well as the network name ('screeps_net')
docker run --rm --name redis --network screeps_net -d -v redis-volume:/data redis
docker run --rm --name mongo --network screeps_net -d -v mongo-volume:/data/db mongo
In order to push your code to your private server you need a password (using screepsmod-auth
) for your user. You can configure a password by pointing your browser at
http://127.0.0.1:21025/authmod/password/ or by typing setPassword('your_password')
into the screeps console when logged in on the screeps client.
Mods can be installed by running:
docker run --rm -v ${PWD}:/screeps -e LOCAL_UID=$(id -u) qnimbus/docker-screeps yarn add screepsmod-auth
The CLI can be accessed by running:
docker exec -it screeps npx screeps cli
To reset server state & data:
system.resetAllData()
You can create autonomous NPC bot players on your private server. They work as regular players, but you can specify their AI scripts in bots option at your mods.json file. Initially there is one AI loaded into your server, called simplebot, but you can always add more, and share with other players.
To view all bot related command and list current active bots, type:
> help(bots);
> bots.removeUser('JackBot'); // Take note: this is the actual bot instance name, not 'bot-tooangel' for example.
Stop:
docker stop screeps
Start:
docker start screeps
- Stop the server:
docker stop screeps
- Remove the server:
docker rm screeps
- Remove current image
docker rmi qnimbus/docker-screeps
- Follow Running the server
When running the docker commands from a Windows Git Bash shell (MSYS) you may need to prepend the MSYS_NO_PATHCONV=1
environment variable to the commands, like so:
MSYS_NO_PATHCONV=1 docker run --rm -it -v ${PWD}:/screeps -e LOCAL_UID=$(id -u) -e STEAM_KEY=YOUR_STEAM_KEY_HERE qnimbus/docker-screeps init