Compare commits

...

48 Commits
hl ... rust

Author SHA1 Message Date
eeb85556ad scripts/start-server.sh aktualisiert 2024-04-10 08:22:07 +02:00
f14a1dc3fe scripts/start-server.sh aktualisiert 2024-04-10 08:20:35 +02:00
30700f775f geändert: Dockerfile
geändert:       README.md
	geändert:       scripts/start-server.sh
2023-12-17 11:03:47 +01:00
eac5e63c4d „scripts/start-server.sh“ ändern 2023-02-05 22:24:25 +01:00
081ddedfea „Dockerfile“ ändern 2023-02-05 22:24:05 +01:00
d3d5934ad5 „scripts/start-server.sh“ ändern 2023-02-05 22:23:05 +01:00
0750068ca6 „scripts/start.sh“ ändern 2022-10-25 11:09:00 +02:00
e2ec99e499 „Dockerfile“ ändern 2022-05-06 10:52:03 +02:00
57aab8c7d3 „README.md“ ändern 2022-04-18 14:06:13 +02:00
dc3549bfe2 „scripts/start.sh“ ändern 2022-04-18 14:04:37 +02:00
43174efe10 „scripts/start.sh“ ändern 2022-04-07 17:15:39 +02:00
b326166d44 „README.md“ ändern 2022-01-29 12:25:15 +01:00
371ab7fe00 „README.md“ ändern 2022-01-29 12:22:47 +01:00
f5c2a67935 „scripts/start-server.sh“ ändern 2022-01-29 11:27:07 +01:00
4949e254bc „scripts/start.sh“ ändern 2022-01-29 11:25:47 +01:00
793d6ec39a „Dockerfile“ ändern 2022-01-29 11:11:35 +01:00
c5a37f3b49 „scripts/start-server.sh“ ändern 2021-05-13 07:55:40 +02:00
86a2f8df1d „Dockerfile“ ändern 2021-05-12 09:24:15 +02:00
1d71725f68 „scripts/start-server.sh“ ändern 2021-05-12 09:23:54 +02:00
cb6a834697 „Dockerfile“ ändern 2021-05-12 09:08:08 +02:00
a7d7932e64 „Dockerfile“ ändern 2021-05-12 09:06:55 +02:00
42289cdf22 „scripts/start-server.sh“ ändern 2021-05-12 09:05:45 +02:00
6b57321b20 „scripts/start.sh“ ändern 2021-03-10 15:01:56 +01:00
43bd6d7772 „Dockerfile“ ändern 2021-03-10 15:01:09 +01:00
4c682e1bf1 „scripts/start.sh“ ändern 2020-04-28 17:01:31 +02:00
06996ce77d „.drone.yml“ löschen 2020-03-08 21:06:26 +01:00
b14f052be6 „.drone.yml“ hinzufügen
Some checks reported errors
continuous-integration/drone/push Build was killed
2020-03-05 20:22:02 +01:00
e8b15b0fec „scripts/start-server.sh“ ändern 2020-02-25 14:37:58 +01:00
d6e571306b „scripts/start.sh“ hinzufügen 2020-02-25 14:37:45 +01:00
6634fa2927 „Dockerfile“ ändern 2020-02-25 14:28:38 +01:00
b6919f1eb6 „Dockerfile“ ändern 2020-01-07 16:56:33 +01:00
25217bb65b „Dockerfile“ ändern 2019-11-11 11:30:47 +01:00
2a4e76bad4 „scripts/start-server.sh“ ändern 2019-11-11 11:24:53 +01:00
1b7da01cab „scripts/start-server.sh“ ändern 2019-06-04 15:01:01 +02:00
f64d2934d6 „Dockerfile“ ändern 2019-06-04 14:49:44 +02:00
afd3bcf56d „Dockerfile“ ändern 2019-06-04 14:48:40 +02:00
1bc269133d „scripts/start-server.sh“ ändern 2019-06-04 14:48:33 +02:00
8d4cd6dd52 „Dockerfile“ ändern 2019-06-04 14:35:11 +02:00
72f414543c „scripts/start-server.sh“ ändern 2019-06-04 14:34:09 +02:00
63c028c511 „scripts/start-server.sh“ ändern 2019-06-04 13:40:29 +02:00
00e650d120 „Dockerfile“ ändern 2019-06-04 12:41:17 +02:00
af4f947705 „scripts/start-server.sh“ ändern 2019-06-04 12:40:56 +02:00
b683db6b1f „scripts/start-server.sh“ ändern 2019-06-04 12:33:54 +02:00
a9333a0352 „scripts/start-server.sh“ ändern 2019-05-21 11:57:20 +02:00
f3b120f82d „scripts/start-server.sh“ ändern 2019-05-20 22:58:31 +02:00
b380bc7f24 Update start-server.sh 2019-04-29 17:32:41 +02:00
c463e82651 Update start-server.sh 2019-04-29 13:20:07 +02:00
1c1fbc6826 Update Dockerfile 2019-04-29 12:54:18 +02:00
4 changed files with 206 additions and 54 deletions

View File

@@ -1,9 +1,11 @@
FROM ubuntu FROM ich777/debian-baseimage
MAINTAINER ich777 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 && \
RUN apt-get -y install lib32gcc1 apt-get -y install --no-install-recommends lib32gcc-s1 libsqlite3-0 libgdiplus unzip && \
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"
@@ -11,26 +13,33 @@ ENV SERVER_DIR="${DATA_DIR}/serverfiles"
ENV GAME_ID="template" ENV GAME_ID="template"
ENV GAME_NAME="template" ENV GAME_NAME="template"
ENV GAME_PARAMS="template" ENV GAME_PARAMS="template"
ENV GAME_PORT=27015 ENV GAME_PORT=28015
ENV QUERY_PORT=28016
ENV RCON_PORT=28017
ENV APP_PORT=28018
ENV SERVER_NAME="RustDocker"
ENV SERVER_DISCRIPTION="Simple Unraid Rust Docker"
ENV OXIDE_MOD="false"
ENV CARBON_MOD="false"
ENV FORCE_OXIDE_INSTALLATION="true"
ENV VALIDATE="" ENV VALIDATE=""
ENV UMASK=000
ENV UID=99 ENV UID=99
ENV GID=100 ENV GID=100
ENV USERNAME="" ENV USERNAME=""
ENV PASSWRD="" ENV PASSWRD=""
ENV USER="steam"
ENV DATA_PERM=770
RUN mkdir $DATA_DIR RUN mkdir $DATA_DIR && \
RUN mkdir $STEAMCMD_DIR mkdir $STEAMCMD_DIR && \
RUN mkdir $SERVER_DIR mkdir $SERVER_DIR && \
RUN useradd -d $DATA_DIR -s /bin/bash --uid $UID --gid $GID steam useradd -d $DATA_DIR -s /bin/bash $USER && \
RUN chown -R steam $DATA_DIR chown -R $USER $DATA_DIR && \
ulimit -n 2048
RUN ulimit -n 2048
ADD /scripts/ /opt/scripts/ ADD /scripts/ /opt/scripts/
RUN chmod -R 770 /opt/scripts/ RUN chmod -R 770 /opt/scripts/
RUN chown -R steam /opt/scripts
USER steam
#Server Start #Server Start
ENTRYPOINT ["/opt/scripts/start-server.sh"] ENTRYPOINT ["/opt/scripts/start.sh"]

View File

@@ -1,45 +1,44 @@
# SteamCMD in Docker optimized for Unraid # SteamCMD in Docker optimized for Unraid
This Docker will download and install SteamCMD. It will also install Counter-Strike: Source and run it. Update Notice: Simply restart the container if a newer version of the game is available. This Docker will download and install SteamCMD. It will also install RUST and run it.
**Update Notice:** Simply restart the container if a newer version of the game is available.
## Env params ## 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 | SteamID for server | 232330 | | GAME_ID | The GAME_ID that the container downloads at startup. If you want to use a beta version of the game enter this: '258550 -beta staging' or '258550 -beta prerelease' (without quotes). | 258550 |
| GAME_NAME | SRCDS gamename | cstrike | | GAME_PARAMS | Enter here your extra game startup parameters if needed starting with (eg: '+rcon.port 27016 +rcon.password YOURPASSWORD' don't forget to add also a new port mapping with container and host port set to the corresponding RCON port) | +server.maxplayers 10 |
| GAME_PARAMS | Values to start the server | -secure +maxplayers 32 +map de_dust2 | | SERVER_NAME | Name of the Server goes here | RustDockerServer |
| SERVER_DISCRIPTION | Server Description goes here | Simple Unraid Rust Docker Server |
| OXIDE_MOD | Set to 'true' (without quotes) to enable Oxide Mod, otherwise leave empty (the container will check on every start/restart if there is a newer version available). | false |
| CARBON_MOD | Set to 'true' (without quotes) to enable Carbon Mod, otherwise leave empty (the container will check on every start/restart if there is a newer version available). | false |
| GAME_PORT | Game port on which the server is running (has to match the port mapping in your container). | 28015 |
| 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 | false |
| 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, Steam recommends to create a seperate account for dedicated servers***
>**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 ## Run example
``` ```
docker run --name CSSource -d \ docker run --name RUST -d \
-p 27015:27015 -p 27015:27015/udp \ -p 28015:28015/udp \
--env 'GAME_ID=232330' \ --env 'GAME_ID=258550' \
--env 'GAME_NAME=cstrike' \ --env 'SERVER_NAME=RustDockerServer' \
--env 'GAME_PORT=27015' \ --env 'SERVER_DISCRIPTION=Simple Unraid Rust Docker Server' \
--env 'GAME_PARAMS=-secure +maxplayers 32 +map de_dust2' \ --env 'GAME_PARAMS=+server.maxplayers 10' \
--env 'GAME_PORT=28015' \
--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/rust:/serverdata/serverfiles \
ich777/steamcmd:latest ich777/steamcmd:rust
``` ```
>**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/

View File

@@ -20,44 +20,146 @@ fi
echo "---Update Server---" echo "---Update Server---"
if [ "${USERNAME}" == "" ]; then if [ "${USERNAME}" == "" ]; then
if [ "${VALIDATE}" == "true" ]; then if [ "${VALIDATE}" == "true" ]; then
echo "---Validating installation---"
${STEAMCMD_DIR}/steamcmd.sh \ ${STEAMCMD_DIR}/steamcmd.sh \
+login anonymous \
+force_install_dir ${SERVER_DIR} \ +force_install_dir ${SERVER_DIR} \
+login anonymous \
+app_update ${GAME_ID} validate \ +app_update ${GAME_ID} validate \
+quit +quit
else else
${STEAMCMD_DIR}/steamcmd.sh \ ${STEAMCMD_DIR}/steamcmd.sh \
+login anonymous \
+force_install_dir ${SERVER_DIR} \ +force_install_dir ${SERVER_DIR} \
+login anonymous \
+app_update ${GAME_ID} \ +app_update ${GAME_ID} \
+quit +quit
fi fi
else else
if [ "${VALIDATE}" == "true" ]; then if [ "${VALIDATE}" == "true" ]; then
echo "---Validating installation---"
${STEAMCMD_DIR}/steamcmd.sh \ ${STEAMCMD_DIR}/steamcmd.sh \
+login ${USERNAME} ${PASSWRD} \
+force_install_dir ${SERVER_DIR} \ +force_install_dir ${SERVER_DIR} \
+login ${USERNAME} ${PASSWRD} \
+app_update ${GAME_ID} validate \ +app_update ${GAME_ID} validate \
+quit +quit
else else
${STEAMCMD_DIR}/steamcmd.sh \ ${STEAMCMD_DIR}/steamcmd.sh \
+login ${USERNAME} ${PASSWRD} \
+force_install_dir ${SERVER_DIR} \ +force_install_dir ${SERVER_DIR} \
+login ${USERNAME} ${PASSWRD} \
+app_update ${GAME_ID} \ +app_update ${GAME_ID} \
+quit +quit
fi fi
fi fi
if [ "${OXIDE_MOD}" == "true" ] && [ "${CARBON_MOD}" == "true" ]; then
echo "---Oxide and Carbon mod enabled, you can only enable one at a time, putting container into sleep mode.--"
sleep infinity
fi
if [ "${OXIDE_MOD}" == "true" ]; then
echo "---Oxide Mod enabled!---"
CUR_V="$(find ${SERVER_DIR} -maxdepth 1 -name "OxideMod-*.zip" | cut -d '-' -f2)"
LAT_V="$(wget -qO- https://api.github.com/repos/OxideMod/Oxide.Rust/releases/latest | grep tag_name | cut -d '"' -f4)"
if [ -z ${LAT_V} ]; then
if [ -z ${CUR_V%.*} ]; then
echo "---Can't get latest Oxide Mod version and found no installed version, putting server into sleep mode!---"
sleep infinity
else
echo "---Can_t get latest Oxide Mod version, falling back to installed v${CUR_V%.*}!---"
LAT_V="${CUR_V%.*}"
fi
fi
if [ -z "${CUR_V%.}" ]; then
echo "---Oxide Mod not found, downloading!---"
rm -f ${SERVER_DIR}/OxideMod-*.zip
cd ${SERVER_DIR}
if wget -q -nc --show-progress --progress=bar:force:noscroll -O ${SERVER_DIR}/OxideMod-${LAT_V}.zip "https://github.com/OxideMod/Oxide.Rust/releases/download/${LAT_V}/Oxide.Rust-linux.zip" ; then
echo "---Successfully downloaded Oxide Mode v${LAT_V}!---"
else
echo "---Something went wrong, can't download Oxide Mod v${LAT_V}, putting server in sleep mode---"
sleep infinity
fi
unzip -o ${SERVER_DIR}/OxideMod-${LAT_V}.zip -d ${SERVER_DIR}
elif [ "${LAT_V}" != "${CUR_V%.*}" ]; then
cd ${SERVER_DIR}
rm -rf ${SERVER_DIR}/OxideMod-*.zip
echo "---Newer version of Oxide Mod v${LAT_V} found, currently installed: v${CUR_V%.*}---"
if wget -q -nc --show-progress --progress=bar:force:noscroll -O ${SERVER_DIR}/OxideMod-${LAT_V}.zip "https://github.com/OxideMod/Oxide.Rust/releases/download/${LAT_V}/Oxide.Rust-linux.zip" ; then
echo "---Successfully downloaded Oxide Mod v${LAT_V}!---"
else
echo "---Something went wrong, can't download Oxide Mod v${LAT_V}, putting server in sleep mode---"
sleep infinity
fi
unzip -o ${SERVER_DIR}/OxideMod-${LAT_V}.zip -d ${SERVER_DIR}
elif [ "$LAT_V" == "${CUR_V%.*}" ]; then
echo "---Oxide Mod v${CUR_V%.*} is Up-To-Date!---"
fi
if [ "${FORCE_OXIDE_INSTALLATION}" == "true" ]; then
unzip -o ${SERVER_DIR}/OxideMod-${LAT_V}.zip -d ${SERVER_DIR}
fi
fi
if [ "${CARBON_MOD}" == "true" ]; then
echo "---Carbon Mod enabled!---"
CUR_V="$(find ${SERVER_DIR} -maxdepth 1 -name "CarbonMod-*.tar.gz" | cut -d '-' -f2)"
LAT_V="$(wget -qO- https://api.github.com/repos/CarbonCommunity/Carbon/releases/latest | grep tag_name | cut -d '"' -f4)"
if [ -z ${LAT_V} ]; then
if [ -z ${CUR_V%.tar.gz} ]; then
echo "---Can't get latest Carbon Mod version and found no installed version, putting server into sleep mode!---"
sleep infinity
else
echo "---Can_t get latest Carbon Mod version, falling back to installed v${CUR_V%.tar.gz}!---"
LAT_V="${CUR_V%.tar.gz}"
fi
fi
if [ -z "${CUR_V%.tar.gz}" ]; then
echo "---Carbon Mod not found, downloading!---"
rm -f ${SERVER_DIR}/CarbonMod-*.tar.gz
cd ${SERVER_DIR}
if wget -q -nc --show-progress --progress=bar:force:noscroll -O ${SERVER_DIR}/CarbonMod-${LAT_V}.tar.gz "https://github.com/CarbonCommunity/Carbon/releases/download/${LAT_V}/Carbon.Linux.Release.tar.gz" ; then
echo "---Successfully downloaded Carbon Mode ${LAT_V}!---"
else
echo "---Something went wrong, can't download Carbon Mod ${LAT_V}, putting server in sleep mode---"
sleep infinity
fi
tar -xvf ${SERVER_DIR}/CarbonMod-${LAT_V}.tar.gz -C ${SERVER_DIR}
#unzip -o ${SERVER_DIR}/CarbonMod-${LAT_V}.zip -d ${SERVER_DIR}
elif [ "${LAT_V}" != "${CUR_V%.tar.gz}" ]; then
cd ${SERVER_DIR}
rm -rf ${SERVER_DIR}/CarbonMod-*.tar.gz
echo "---Newer version of Carbon Mod ${LAT_V} found, currently installed: v${CUR_V%.tar.gz}---"
if wget -q -nc --show-progress --progress=bar:force:noscroll -O ${SERVER_DIR}/CarbonMod-${LAT_V}.tar.gz "https://github.com/CarbonCommunity/Carbon/releases/download/${LAT_V}/Carbon.Linux.Release.tar.gz" ; then
echo "---Successfully downloaded Carbon Mod ${LAT_V}!---"
else
echo "---Something went wrong, can't download Carbon Mod ${LAT_V}, putting server in sleep mode---"
sleep infinity
fi
tar -xvf ${SERVER_DIR}/CarbonMod-${LAT_V}.tar.gz ${SERVER_DIR}
elif [ "$LAT_V" == "${CUR_V%.tar.gz}" ]; then
echo "---Carbon Mod ${CUR_V%.tar.gz} is Up-To-Date!---"
fi
if [ "${FORCE_CARBON_INSTALLATION}" == "true" ]; then
tar -xvf ${SERVER_DIR}/CarbonMod-${LAT_V}.tar.gz -C ${SERVER_DIR}
fi
source "${SERVER_DIR}/carbon/tools/environment.sh"
fi
echo "---Prepare Server---" echo "---Prepare Server---"
chmod -R ${DATA_PERM} ${DATA_DIR}
sleep infinity echo "---Setting Library path---"
export LD_LIBRARY_PATH=:/bin/RustDedicated_Data/Plugins/x86_64
mkdir ${DATA_DIR}/.steam/sdk32 echo "---Server ready---"
cp -R ${SERVER_DIR}/bin/* ${DATA_DIR}/.steam/sdk32/
chmod -R 770 ${DATA_DIR}
echo "---Start Server---" echo "---Start Server---"
${SERVER_DIR}/srcds_run -game ${GAME_NAME} ${GAME_PARAMS} -console +port ${GAME_PORT} cd ${SERVER_DIR}
if [ ! -f ${SERVER_DIR}/RustDedicated ]; then
echo "---Can't find game executable, putting server into sleep mode!---"
sleep infinity
else
${SERVER_DIR}/RustDedicated -batchmode -server.port ${GAME_PORT} -server.queryport ${QUERY_PORT} -rcon.port ${RCON_PORT} -app.port ${APP_PORT} -server.hostname "${SERVER_NAME}" -server.description "${SERVER_DISCRIPTION}" ${GAME_PARAMS}
fi

42
scripts/start.sh Normal file
View File

@@ -0,0 +1,42 @@
#!/bin/bash
echo "---Ensuring UID: ${UID} matches user---"
usermod -u ${UID} ${USER}
echo "---Ensuring GID: ${GID} matches user---"
groupmod -g ${GID} ${USER} > /dev/null 2>&1 ||:
usermod -g ${GID} ${USER}
echo "---Setting umask to ${UMASK}---"
umask ${UMASK}
echo "---Checking for optional scripts---"
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---"
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---"
fi
echo "---Taking ownership of data...---"
chown -R root:${GID} /opt/scripts
chmod -R 750 /opt/scripts
chown -R ${UID}:${GID} ${DATA_DIR}
echo "---Starting...---"
term_handler() {
kill -SIGINT $(pidof RustDedicated)
tail --pid=$(pidof RustDedicated) -f 2>/dev/null
sleep 0.5
exit 143;
}
trap 'kill ${!}; term_handler' SIGTERM
su ${USER} -c "/opt/scripts/start-server.sh" &
killpid="$!"
while true
do
wait $killpid
exit 0;
done