Compare commits

...

27 Commits

Author SHA1 Message Date
13a361314e „scripts/start-server.sh“ ändern 2023-02-21 11:13:31 +01:00
5be2e5af76 „Dockerfile“ ändern 2023-02-21 11:13:21 +01:00
5b5bf0e312 „scripts/start-server.sh“ ändern 2023-02-09 14:54:02 +01:00
1354aceda7 „scripts/start.sh“ ändern 2022-10-25 11:02:44 +02:00
8d70e52da9 „README.md“ ändern 2022-05-11 22:34:36 +02:00
e118768023 „README.md“ ändern 2022-05-11 22:34:06 +02:00
9e82f6beb3 „scripts/start-server.sh“ ändern 2022-05-11 22:21:30 +02:00
54cee6d03e „scripts/start-server.sh“ ändern 2022-05-11 22:18:42 +02:00
ab90a1de3e „scripts/start-server.sh“ ändern 2022-05-11 22:18:22 +02:00
e6cc01f5d2 „scripts/start-server.sh“ ändern 2022-05-11 22:16:17 +02:00
1711b8176c „scripts/start-server.sh“ ändern 2022-05-11 22:11:54 +02:00
753a64f008 „scripts/start.sh“ ändern 2022-05-11 22:11:16 +02:00
7f3ac0a361 „scripts/start-watchdog.sh“ ändern 2022-05-11 22:09:25 +02:00
9c0e67dd4f „scripts/start-server.sh“ ändern 2022-05-11 22:08:04 +02:00
35af39d4b9 „scripts/start-watchdog.sh“ hinzufügen 2022-05-11 22:03:01 +02:00
dbd4213520 „scripts/start-Xvfb.sh“ ändern 2022-05-11 21:49:46 +02:00
48f75d0f3b „scripts/start-server.sh“ ändern 2022-05-11 21:37:49 +02:00
a09fc7582e „scripts/start-server.sh“ ändern 2022-05-11 21:31:22 +02:00
0ca92a55b9 „Dockerfile“ ändern 2022-05-11 21:18:08 +02:00
c0a6a2a0ed „scripts/start-server.sh“ ändern 2022-05-11 21:17:08 +02:00
82138aa2af „scripts/start-Xvfb.sh“ hinzufügen 2022-05-11 20:45:17 +02:00
e506bf3fba „Dockerfile“ ändern 2022-05-11 20:40:53 +02:00
ca0c8fefe6 „Dockerfile“ ändern 2022-05-06 09:06:19 +02:00
e7c87bd8f1 „README.md“ ändern 2022-04-18 13:08:18 +02:00
2432940e23 „scripts/start-server.sh“ ändern 2022-04-13 14:31:26 +02:00
89598a9710 „scripts/start.sh“ ändern 2022-04-07 17:20:32 +02:00
83992eb6cb „scripts/start-server.sh“ ändern 2021-12-14 12:59:09 +01:00
6 changed files with 80 additions and 50 deletions

View File

@@ -1,17 +1,20 @@
FROM ich777/debian-baseimage FROM ich777/debian-baseimage
LABEL maintainer="admin@minenet.at" LABEL org.opencontainers.image.authors="admin@minenet.at"
LABEL org.opencontainers.image.source="https://github.com/ich777/docker-steamcmd-server"
RUN apt-get update && \ RUN apt-get update && \
apt-get -y install --no-install-recommends lib32gcc-s1 lib32stdc++6 && \ apt-get -y install --no-install-recommends lib32gcc-s1 lib32stdc++6 xvfb screen libxi6 && \
rm -rf /var/lib/apt/lists/* rm -rf /var/lib/apt/lists/*
ENV DATA_DIR="/serverdata" ENV DATA_DIR="/serverdata"
ENV STEAMCMD_DIR="${DATA_DIR}/steamcmd" ENV STEAMCMD_DIR="${DATA_DIR}/steamcmd"
ENV SERVER_DIR="${DATA_DIR}/serverfiles" ENV SERVER_DIR="${DATA_DIR}/serverfiles"
ENV WORLD_INDEX=0
ENV WORLD_NAME="Core Keeper Docker"
ENV GAME_ID="template" ENV GAME_ID="template"
ENV GAME_NAME="template" ENV GAME_NAME=""
ENV GAME_PARAMS="template" ENV GAME_PARAMS=""
ENV GAME_PORT=27015 ENV GAME_PORT=27015
ENV VALIDATE="" ENV VALIDATE=""
ENV UMASK=000 ENV UMASK=000

View File

@@ -1,50 +1,42 @@
# SteamCMD in Docker optimized for Unraid # SteamCMD in Docker optimized for Unraid
This Docker will download and install SteamCMD and the according game that is pulled via specifying the Tag. This Docker will download and install SteamCMD. It will also install CoreKeeper and run it.
**Please see the different Tags/Branches which games are available.** **GameID:** Your GameID will be displayed in the log after the server successfully started.
## Example Env params for CS:Source **Port Forwarding:** You don't have to forward any ports for this game because it uses the Steam Network and the GameID to establish the connection.
Update Notice: Simply restart the container if a newer version of the game is available.
## Example Env params
| Name | Value | Example | | Name | Value | Example |
| --- | --- | --- | | --- | --- | --- |
| STEAMCMD_DIR | Folder for SteamCMD | /serverdata/steamcmd | | STEAMCMD_DIR | Folder for SteamCMD | /serverdata/steamcmd |
| SERVER_DIR | Folder for gamefile | /serverdata/serverfiles | | SERVER_DIR | Folder for gamefile | /serverdata/serverfiles |
| GAME_ID | The GAME_ID that the container downloads at startup. If you want to install a static or beta version of the game change the value to: '232330 -beta YOURBRANCH' (without quotes, replace YOURBRANCH with the branch or version you want to install). | 232330 | | GAME_ID | The GAME_ID that the container downloads at startup. If you want to install a static or beta version of the game change the value to: '1963720 -beta YOURBRANCH' (without quotes, replace YOURBRANCH with the branch or version you want to install). | 1963720 |
| GAME_NAME | SRCDS gamename | cstrike | | WORLD_NAME | Enter your prefered world name here. | Core Keeper Docker |
| WORLD_INDEX | Only change when you know what you are doing! | cstrike |
| GAME_PARAMS | Values to start the server | -secure +maxplayers 32 +map de_dust2 | | GAME_PARAMS | Values to start the server | -secure +maxplayers 32 +map de_dust2 |
| UID | User Identifier | 99 | | UID | User Identifier | 99 |
| GID | Group Identifier | 100 | | GID | Group Identifier | 100 |
| GAME_PORT | Port the server will be running on | 27015 |
| VALIDATE | Validates the game data | true | | VALIDATE | Validates the game data | true |
| USERNAME | Leave blank for anonymous login | blank | | USERNAME | Leave blank for anonymous login | blank |
| PASSWRD | Leave blank for anonymous login | blank | | PASSWRD | Leave blank for anonymous login | blank |
**ATTENTION: You have to disable Steam Guard for games that require authentication, but not all games need Steam credentials, Steam recommends to create a seperate account for dedicated servers ** ## Run example
>**NOTE** GAME_ID values can be found [here](https://developer.valvesoftware.com/wiki/Dedicated_Servers_List)
> And for GAME_NAME there is no list, so a quick search should give you the result
## Run example for CS:Source
``` ```
docker run --name CSSource -d \ docker run --name CoreKeeper -d \
-p 27015:27015 -p 27015:27015/udp \ --env 'GAME_ID=1963720' \
--env 'GAME_ID=232330' \ --env 'WORLD_NAME=Core Keeper Docker' \
--env 'GAME_NAME=cstrike' \ --env 'WORLD_INDEX=0' \
--env 'GAME_PORT=27015' \
--env 'GAME_PARAMS=-secure +maxplayers 32 +map de_dust2' \
--env 'UID=99' \ --env 'UID=99' \
--env 'GID=100' \ --env 'GID=100' \
--volume /mnt/user/appdata/steamcmd:/serverdata/steamcmd \ --volume /path/to/steamcmd:/serverdata/steamcmd \
--volume /mnt/user/appdata/cstrikesource:/serverdata/serverfiles \ --volume /path/to/corekeeper:/serverdata/serverfiles \
ich777/steamcmd:latest ich777/steamcmd:corekeeper
``` ```
>**NOTE** port 26900 is the port for vac, in case of multiple servers make sure these are not the same
This Docker was mainly edited for better use with Unraid, if you don't use Unraid you should definitely try it! This Docker was mainly edited for better use with Unraid, if you don't use Unraid you should definitely try it!
This Docker is forked from mattieserver, thank you for this wonderfull Docker. This Docker is forked from mattieserver, thank you for this wonderfull Docker.
#### Support Thread: https://forums.unraid.net/topic/79530-support-ich777-gameserver-dockers/ #### Support Thread: https://forums.unraid.net/topic/79530-support-ich777-gameserver-dockers/

4
scripts/start-Xvfb.sh Normal file
View File

@@ -0,0 +1,4 @@
until Xvfb :99 -screen 0 1x1x24 -nolisten tcp; do
echo "Xvfb server crashed with exit code $?. Respawning.." >&2
sleep 1
done

View File

@@ -51,18 +51,36 @@ else
fi fi
echo "---Prepare Server---" echo "---Prepare Server---"
if [ ! -f ${DATA_DIR}/.steam/sdk32/steamclient.so ]; then if [ ! -f ${DATA_DIR}/.steam/sdk64/steamclient.so ]; then
if [ ! -d ${DATA_DIR}/.steam ]; then if [ ! -d ${DATA_DIR}/.steam/sdk64 ]; then
mkdir ${DATA_DIR}/.steam mkdir -p ${DATA_DIR}/.steam/sdk64
fi fi
if [ ! -d ${DATA_DIR}/.steam/sdk32 ]; then cp -R ${STEAMCMD_DIR}/linux64/* ${DATA_DIR}/.steam/sdk64/
mkdir ${DATA_DIR}/.steam/sdk32 fi
fi echo "---Checking for old display lock files---"
cp -R ${STEAMCMD_DIR}/linux32/* ${DATA_DIR}/.steam/sdk32/ find /tmp -name ".X99*" -exec rm -f {} \; > /dev/null 2>&1
echo "---Checking for old logfiles---"
find ${SERVER_DIR} -name "XvfbLog.*" -exec rm -f {} \; > /dev/null 2>&1
chmod +x ${SERVER_DIR}/CoreKeeperServer
if [ -f ${SERVER_DIR}/steamclient.so ]; then
rm ${SERVER_DIR}/steamclient.so
fi fi
chmod -R ${DATA_PERM} ${DATA_DIR}
echo "---Server ready---" echo "---Server ready---"
echo "---Starting Xvfb server---"
screen -S Xvfb -L -Logfile ${SERVER_DIR}/XvfbLog.0 -d -m /opt/scripts/start-Xvfb.sh
sleep 3
echo "---Start Server---" echo "---Start Server---"
export DISPLAY=:99
cd ${SERVER_DIR} cd ${SERVER_DIR}
${SERVER_DIR}/srcds_run -game ${GAME_NAME} ${GAME_PARAMS} -console +port ${GAME_PORT} if [ -f ${SERVER_DIR}/GameID.txt ]; then
rm -f ${SERVER_DIR}/GameID.txt
fi
${SERVER_DIR}/CoreKeeperServer -batchmode -logfile ${SERVER_DIR}/CoreKeeperServerLog.txt -world ${WORLD_INDEX} -worldname "${WORLD_NAME}" -datapath "${SERVER_DIR}/Save" ${GAME_PARAMS} 2 >/dev/null &
sleep 2
screen -S watchdog -d -m /opt/scripts/start-watchdog.sh
while [ ! -f ${SERVER_DIR}/GameID.txt ]; do
sleep 1
done
echo "Server Game ID: $(cat ${SERVER_DIR}/GameID.txt 2>/dev/null)"
sleep infinity

View File

@@ -0,0 +1,8 @@
#!/bin/bash
killpid="$(pidof CoreKeeperServer)"
while true
do
tail --pid=$killpid -f /dev/null
kill $(pidof sleep)
exit 0
done

View File

@@ -1,28 +1,33 @@
#!/bin/bash #!/bin/bash
echo "---Checking if UID: ${UID} matches user---" echo "---Ensuring UID: ${UID} matches user---"
usermod -u ${UID} ${USER} usermod -u ${UID} ${USER}
echo "---Checking if GID: ${GID} matches user---" echo "---Ensuring GID: ${GID} matches user---"
groupmod -g ${GID} ${USER} > /dev/null 2>&1 ||:
usermod -g ${GID} ${USER} usermod -g ${GID} ${USER}
echo "---Setting umask to ${UMASK}---" echo "---Setting umask to ${UMASK}---"
umask ${UMASK} umask ${UMASK}
echo "---Checking for optional scripts---" echo "---Checking for optional scripts---"
if [ -f /opt/scripts/user.sh ]; then cp -f /opt/custom/user.sh /opt/scripts/start-user.sh > /dev/null 2>&1 ||:
cp -f /opt/scripts/user.sh /opt/scripts/start-user.sh > /dev/null 2>&1 ||:
if [ -f /opt/scripts/start-user.sh ]; then
echo "---Found optional script, executing---" echo "---Found optional script, executing---"
chmod +x /opt/scripts/user.sh chmod -f +x /opt/scripts/start-user.sh ||:
/opt/scripts/user.sh /opt/scripts/start-user.sh || echo "---Optional Script has thrown an Error---"
else else
echo "---No optional script found, continuing---" echo "---No optional script found, continuing---"
fi fi
echo "---Starting...---" echo "---Taking ownership of data...---"
chown -R root:${GID} /opt/scripts chown -R root:${GID} /opt/scripts
chmod -R 750 /opt/scripts chmod -R 750 /opt/scripts
chown -R ${UID}:${GID} ${DATA_DIR} chown -R ${UID}:${GID} ${DATA_DIR}
echo "---Starting...---"
term_handler() { term_handler() {
kill -SIGTERM "$killpid" kill -SIGTERM $(pidof CoreKeeperServer)
wait "$killpid" -f 2>/dev/null tail --pid="$(pidof CoreKeeperServer)" -f 2>/dev/null
exit 143; exit 143;
} }