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 STEAMCMD_DIR="${DATA_DIR}/steamcmd"
ENV SERVER_DIR="${DATA_DIR}/serverfiles" ENV SERVER_DIR="${DATA_DIR}/serverfiles"
ENV GAME_ID="template" ENV GAME_ID="template"
ENV GAME_NAME="template" ENV IDENTIFIER="dockeroasis_1"
ENV GAME_PARAMS="template" 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 GAME_PORT=27015
ENV VALIDATE="" ENV VALIDATE=""
ENV UMASK=000 ENV UMASK=000

View File

@@ -1,36 +1,46 @@
# 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 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 | | 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: '920720 -beta YOURBRANCH' (without quotes, replace YOURBRANCH with the branch or version you want to install). | 920720 |
| GAME_NAME | SRCDS gamename | cstrike | | IDENTIFIER | Enter your preferred server identifier. | Last Oasis Docker |
| GAME_PARAMS | Values to start the server | -secure +maxplayers 32 +map de_dust2 | | 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 | | 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 |
## Run example ## Run example
``` ```
docker run --name CSSource -d \ docker run --name LastOasis -d \
-p 27015:27015 -p 27015:27015/udp \ -p 5555:5555/udp -p 27015:27015/udp \
--env 'GAME_ID=232330' \ --env 'GAME_ID=232330' \
--env 'GAME_NAME=cstrike' \ --env 'IDENTIFIER=Last Oasis Docker' \
--env 'GAME_PORT=27015' \ --env 'SRV_PASSWORD=Docker' \
--env 'GAME_PARAMS=-secure +maxplayers 32 +map de_dust2' \ --env 'SLOTS=20' \
--env 'CUSTOMER_KEY=YOURCUSTOMERKEY' \
--env 'PROVIDER_KEY=YOURPROVIDERKEY' \
--env 'GAME_PARAMS=-port=5555 -QueryPort=27015 -NoLiveServer -EnableCheats' \
--env 'UID=99' \ --env 'UID=99' \
--env 'GID=100' \ --env 'GID=100' \
--volume /path/to/steamcmd:/serverdata/steamcmd \ --volume /path/to/steamcmd:/serverdata/steamcmd \
--volume /path/to/cstrikesource:/serverdata/serverfiles \ --volume /path/to/lastoasis:/serverdata/serverfiles \
ich777/steamcmd:latest ich777/steamcmd:lastoasis
``` ```
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!

View File

@@ -51,18 +51,25 @@ 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/sdk32 ]; then if [ ! -d ${DATA_DIR}/.steam/sdk64 ]; then
mkdir -p ${DATA_DIR}/.steam/sdk32 mkdir -p ${DATA_DIR}/.steam/sdk64
fi 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 fi
chmod -R ${DATA_PERM} ${DATA_DIR} chmod -R ${DATA_PERM} ${DATA_DIR}
echo "---Server ready---" echo "---Server ready---"
echo "---Sleep zZzZz---"
sleep infinity
echo "---Start Server---" echo "---Start Server---"
cd ${SERVER_DIR} cd ${SERVER_DIR}/Mist/Binaries/Linux
${SERVER_DIR}/srcds_run -game ${GAME_NAME} ${GAME_PARAMS} -console +port ${GAME_PORT} 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 if [ -f /opt/scripts/start-user.sh ]; then
echo "---Found optional script, executing---" 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---" /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---"
@@ -26,8 +26,9 @@ chown -R ${UID}:${GID} ${DATA_DIR}
echo "---Starting...---" echo "---Starting...---"
term_handler() { term_handler() {
kill -SIGTERM "$killpid" kill -SIGINT $(pidof MistServer-Linux-Shipping)
wait "$killpid" -f 2>/dev/null tail --pid=$(pidof MistServer-Linux-Shipping) -f 2>/dev/null
sleep 0.5
exit 143; exit 143;
} }