Compare commits

...

18 Commits

4 changed files with 49 additions and 27 deletions

View File

@@ -11,8 +11,12 @@ ENV DATA_DIR="/serverdata"
ENV STEAMCMD_DIR="${DATA_DIR}/steamcmd"
ENV SERVER_DIR="${DATA_DIR}/serverfiles"
ENV GAME_ID="template"
ENV GAME_NAME="template"
ENV IDENTIFIER="dockeroasis_1"
ENV GAME_PARAMS="template"
ENV CUSTOMER_KEY="YOURKEY"
ENV PROVIDER_KEY="YOURKEY"
ENV BACKENDAPIURLOVERRIDE="backend.last-oasis.com"
ENV SLOTS=20
ENV GAME_PORT=27015
ENV VALIDATE=""
ENV UMASK=000

View File

@@ -1,36 +1,46 @@
# 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 Last Oasis and run it.
**Please see the different Tags/Branches which games are available.**
**Customer & Provider Key:** You have to first create your own Provider Key here: https://myrealm.lastoasis.gg and fill in the generated Provider Key and Custom Key in the template.
## Example Env params for CS:Source
**ATTENTION:** First Startup can take very long since it downloads the gameserver files!
**Update Notice:** Simply restart the container if a newer version of the game is available.
## Example Env params
| Name | Value | Example |
| --- | --- | --- |
| STEAMCMD_DIR | Folder for SteamCMD | /serverdata/steamcmd |
| 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_NAME | SRCDS gamename | cstrike |
| GAME_PARAMS | Values to start the server | -secure +maxplayers 32 +map de_dust2 |
| 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: '920720 -beta YOURBRANCH' (without quotes, replace YOURBRANCH with the branch or version you want to install). | 920720 |
| IDENTIFIER | Enter your preferred server identifier. | Last Oasis Docker |
| SRV_PASSWORD | Enter your preferred server password here, leave empty for no password. | Docker |
| SLOTS | Enter the maximum server slots. | 20 |
| CUSTOMER_KEY | Your Customer Key goes here (You can get your Customer Key here: https://myrealm.lastoasis.gg Log in -> click on the Hosting drop down and select Providers). | YOURCUSTOMERKEY |
| PROVIDER_KEY | Your Provider Key goes here (You can get your Provider Key here: https://myrealm.lastoasis.gg Log in -> click on the Hosting drop down -> select Providers -> click Add Key -> enter a Name and click Add). | YOURPROVIDERKEY |
| GAME_PARAMS | Values to start the server | -port=5555 -QueryPort=27015 -NoLiveServer -EnableCheats |
| UID | User Identifier | 99 |
| GID | Group Identifier | 100 |
| GAME_PORT | Port the server will be running on | 27015 |
| VALIDATE | Validates the game data | true |
| USERNAME | Leave blank for anonymous login | blank |
| PASSWRD | Leave blank for anonymous login | blank |
## Run example
```
docker run --name CSSource -d \
-p 27015:27015 -p 27015:27015/udp \
docker run --name LastOasis -d \
-p 5555:5555/udp -p 27015:27015/udp \
--env 'GAME_ID=232330' \
--env 'GAME_NAME=cstrike' \
--env 'GAME_PORT=27015' \
--env 'GAME_PARAMS=-secure +maxplayers 32 +map de_dust2' \
--env 'IDENTIFIER=Last Oasis Docker' \
--env 'SRV_PASSWORD=Docker' \
--env 'SLOTS=20' \
--env 'CUSTOMER_KEY=YOURCUSTOMERKEY' \
--env 'PROVIDER_KEY=YOURPROVIDERKEY' \
--env 'GAME_PARAMS=-port=5555 -QueryPort=27015 -NoLiveServer -EnableCheats' \
--env 'UID=99' \
--env 'GID=100' \
--volume /path/to/steamcmd:/serverdata/steamcmd \
--volume /path/to/cstrikesource:/serverdata/serverfiles \
ich777/steamcmd:latest
--volume /path/to/lastoasis:/serverdata/serverfiles \
ich777/steamcmd:lastoasis
```
This Docker was mainly edited for better use with Unraid, if you don't use Unraid you should definitely try it!

View File

@@ -51,18 +51,25 @@ else
fi
echo "---Prepare Server---"
if [ ! -f ${DATA_DIR}/.steam/sdk32/steamclient.so ]; then
if [ ! -d ${DATA_DIR}/.steam/sdk32 ]; then
mkdir -p ${DATA_DIR}/.steam/sdk32
if [ ! -f ${DATA_DIR}/.steam/sdk64/steamclient.so ]; then
if [ ! -d ${DATA_DIR}/.steam/sdk64 ]; then
mkdir -p ${DATA_DIR}/.steam/sdk64
fi
cp -R ${STEAMCMD_DIR}/linux32/* ${DATA_DIR}/.steam/sdk32/
cp -R ${STEAMCMD_DIR}/linux64/* ${DATA_DIR}/.steam/sdk64/
fi
if $(! grep "903950" ${SERVER_DIR}/Mist/Binaries/Linux/steam_appid.txt >/dev/null 2>&1) ; then
echo "903950" > ${SERVER_DIR}/Mist/Binaries/Linux/steam_appid.txt
fi
chmod -R ${DATA_PERM} ${DATA_DIR}
echo "---Server ready---"
echo "---Sleep zZzZz---"
sleep infinity
echo "---Start Server---"
cd ${SERVER_DIR}
${SERVER_DIR}/srcds_run -game ${GAME_NAME} ${GAME_PARAMS} -console +port ${GAME_PORT}
cd ${SERVER_DIR}/Mist/Binaries/Linux
if [ -f ${SERVER_DIR}/Mist/Binaries/Linux/MistServer ]; then
./MistServer -log -force_steamclient_link -messaging -backendapiurloverride="${BACKENDAPIURLOVERRIDE}" -identifier="${IDENTIFIER}" -CustomerKey=${CUSTOMER_KEY} -ProviderKey=${PROVIDER_KEY} -slots=${SLOTS} -overrideconnectionaddress ${GAME_PARAMS}
elif [ -f ${SERVER_DIR}/Mist/Binaries/Linux/MistServer-Linux-Shipping ]; then
./MistServer-Linux-Shipping -log -force_steamclient_link -messaging -backendapiurloverride="${BACKENDAPIURLOVERRIDE}" -identifier="${IDENTIFIER}" -CustomerKey=${CUSTOMER_KEY} -ProviderKey=${PROVIDER_KEY} -slots=${SLOTS} -overrideconnectionaddress ${GAME_PARAMS}
else
echo "---Something went wrong, can't find the executable, putting container into sleep mode!---"
sleep infinity
fi

View File

@@ -13,7 +13,7 @@ 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---"
chmod -f +x /opt/scripts/start-user.sh.sh ||:
chmod -f +x /opt/scripts/start-user.sh ||:
/opt/scripts/start-user.sh || echo "---Optional Script has thrown an Error---"
else
echo "---No optional script found, continuing---"
@@ -26,8 +26,9 @@ chown -R ${UID}:${GID} ${DATA_DIR}
echo "---Starting...---"
term_handler() {
kill -SIGTERM "$killpid"
wait "$killpid" -f 2>/dev/null
kill -SIGINT $(pidof MistServer-Linux-Shipping)
tail --pid=$(pidof MistServer-Linux-Shipping) -f 2>/dev/null
sleep 0.5
exit 143;
}