Compare commits

...

41 Commits

Author SHA1 Message Date
4ad44c6236 README.md aktualisiert 2023-08-29 19:37:48 +02:00
c2f12e4973 Dockerfile aktualisiert 2023-08-29 19:24:00 +02:00
5bb0fd1b97 scripts/start-server.sh aktualisiert 2023-08-29 19:23:38 +02:00
795dd23ff6 scripts/start-server.sh aktualisiert 2023-08-29 19:10:07 +02:00
06a69209e6 scripts/start.sh aktualisiert 2023-08-29 19:05:24 +02:00
3dc0a90fe0 scripts/start-watchdog.sh hinzugefügt 2023-08-29 19:05:09 +02:00
4b6613b811 scripts/start-server.sh aktualisiert 2023-08-29 19:04:24 +02:00
1ad09f8f97 scripts/start-Xvfb.sh hinzugefügt 2023-08-29 17:56:45 +02:00
22f77bcd6a Dockerfile aktualisiert 2023-08-29 17:55:18 +02:00
53f2c85cc3 Dockerfile aktualisiert 2023-08-29 17:04:59 +02:00
1f180eba29 scripts/start.sh aktualisiert 2023-08-29 16:52:33 +02:00
341fe7ab26 Dockerfile aktualisiert 2023-08-29 16:51:21 +02:00
8452d04cd3 Dockerfile aktualisiert 2023-08-29 14:31:29 +02:00
8420cc945a Dockerfile aktualisiert 2023-08-29 14:30:58 +02:00
73f5b651d7 Dockerfile aktualisiert 2023-08-29 14:28:51 +02:00
c695153cb8 Dockerfile aktualisiert 2023-08-29 14:11:37 +02:00
a0952e7858 Dockerfile aktualisiert 2023-08-29 14:09:17 +02:00
29d9a371be Dockerfile aktualisiert 2023-08-28 20:38:31 +02:00
7472226716 Dockerfile aktualisiert 2023-08-28 20:34:31 +02:00
92014b7df1 scripts/start-server.sh aktualisiert 2023-08-28 20:32:06 +02:00
d5ab33a6da scripts/start-server.sh aktualisiert 2023-08-27 18:16:12 +02:00
2066dd1372 README.md aktualisiert 2023-08-27 18:11:08 +02:00
ede2475c59 Dockerfile aktualisiert 2023-08-27 17:59:01 +02:00
77c56e7ddc scripts/start-server.sh aktualisiert 2023-08-27 17:58:05 +02:00
a5fa9fa20b config/ServerSettings.ini gelöscht 2023-08-27 17:57:25 +02:00
f11eaf0015 config/Engine.ini gelöscht 2023-08-27 17:57:22 +02:00
11071e951e Dateien nach "config" hochladen 2023-08-27 17:57:18 +02:00
fa186d191d scripts/start-server.sh aktualisiert 2023-08-27 17:56:25 +02:00
8f93ce03cb scripts/start.sh aktualisiert 2023-08-27 17:53:32 +02:00
454730e8dc Dockerfile aktualisiert 2023-08-27 17:51:57 +02:00
8cda691904 scripts/start-server.sh aktualisiert 2023-08-27 17:14:57 +02:00
6b69441ce5 „scripts/start.sh“ ändern 2022-10-25 11:02:35 +02:00
2562d194f5 „Dockerfile“ ändern 2022-05-06 10:16:46 +02:00
7265410450 „Dockerfile“ ändern 2022-04-25 12:37:07 +02:00
6391c97177 „scripts/start.sh“ ändern 2022-04-18 10:43:02 +02:00
c46277eacf „scripts/start.sh“ ändern 2022-04-07 17:20:00 +02:00
e30084bb15 „README.md“ ändern 2022-01-10 14:14:46 +01:00
02e471d02d „README.md“ ändern 2022-01-10 14:12:04 +01:00
ec253bc1dd „scripts/start-server.sh“ ändern 2022-01-10 14:02:07 +01:00
3578a738a3 „scripts/start.sh“ ändern 2022-01-10 14:01:30 +01:00
cb2ccad743 „Dockerfile“ ändern 2022-01-10 13:54:34 +01:00
9 changed files with 120 additions and 124 deletions

View File

@@ -1,18 +1,18 @@
FROM ich777/winehq-baseimage FROM ich777/winehq-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 dpkg --add-architecture i386 && \ RUN dpkg --add-architecture i386 && \
apt-get update && \ apt-get update && \
apt-get -y install lib32gcc1 screen xvfb && \ apt-get -y install lib32gcc-s1 screen xvfb winbind mariadb-server && \
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 GAME_ID="template" ENV GAME_ID="template"
ENV WS_CONTENT="" ENV GAME_PARAMS="-world 1"
ENV GAME_PARAMS=""
ENV VALIDATE="" ENV VALIDATE=""
ENV UMASK=000 ENV UMASK=000
ENV UID=99 ENV UID=99
@@ -27,7 +27,12 @@ RUN mkdir $DATA_DIR && \
mkdir $SERVER_DIR && \ mkdir $SERVER_DIR && \
useradd -d $DATA_DIR -s /bin/bash $USER && \ useradd -d $DATA_DIR -s /bin/bash $USER && \
chown -R $USER $DATA_DIR && \ chown -R $USER $DATA_DIR && \
ulimit -n 2048 ulimit -n 2048 && \
/etc/init.d/mariadb start && \
mysql -u root -e "CREATE USER IF NOT EXISTS 'steam'@'%' IDENTIFIED BY 'lifyo';FLUSH PRIVILEGES;" && \
mysql -u root -e "GRANT ALL PRIVILEGES ON *.* TO 'steam'@'%' IDENTIFIED BY 'lifyo';" && \
mysql -u root -e "GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'LiFYO';FLUSH PRIVILEGES;" && \
echo "\n[mysqld]\ndatadir=/serverdata/serverfiles/.database/" >> /etc/alternatives/my.cnf
ADD /scripts/ /opt/scripts/ ADD /scripts/ /opt/scripts/
RUN chmod -R 770 /opt/scripts/ RUN chmod -R 770 /opt/scripts/

View File

@@ -1,45 +1,43 @@
# 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 Life is Feudal: Your Own and run it.
Initial server configuration:
**Servername:** LiF Docker **Password:** Docker **Admin Password:** adminDocker
**ATTENTION:** First startup can take very long since it downloads the gameserver files and it also installs the runtimes which can take quite some time!
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_PARAMS | Values to start the server if needed. | empty |
| GAME_NAME | SRCDS gamename | cstrike | | 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: '320850 -beta YOURBRANCH' (without quotes, replace YOURBRANCH with the branch or version you want to install). | 320850 |
| 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 | 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 LifeIsFeudal-YourOwn -d \
-p 27015:27015 -p 27015:27015/udp \ -p 28000-28003 -p 28000-28003/udp \
--env 'GAME_ID=232330' \ --env 'GAME_ID=320850' \
--env 'GAME_NAME=cstrike' \
--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/lifeisfeudal-yo:/serverdata/serverfiles \
ich777/steamcmd:latest ich777/steamcmd:lifyo
``` ```
>**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

@@ -1,5 +0,0 @@
[OnlineSubsystem]
ServerName=Docker ConanExile
ServerPassword=Docker

View File

@@ -1,3 +0,0 @@
[ServerSettings]
MaxNudity=2
AdminPassword=adminDocker

2
config/server_config.xml Normal file
View File

@@ -0,0 +1,2 @@
<?xml version="1.0" encoding="UTF-8"?>
<server_data port="25564" name="Stormworks Docker" save_name="autosave_server" max_players="32" password="Docker" day_night_length="60" sunrise="0.25" sunset="0.791" infinite_resources="false" unlock_all_islands="false" settings_menu="false" base_island="data/tiles/island12.xml" settings_menu_lock="false" infinite_batteries="false" infinite_fuel="false" engine_overheating="false" ceasefire="false" infinite_ammo="false" no_clip="false" map_teleport="false" vehicle_spawn="false" photo_mode="false" respawning="false" cleanup_vehicle="false" clear_fow="false" third_person="true" third_person_vehicle="true" vehicle_damage="false" player_damage="false" npc_damage="false" aggressive_animals="false" sea_monsters="false" lightning="true" teleport_vehicle="true" fast_travel="true" starting_currency="20000" despawn_on_leave="false" map_show_players="false" map_show_vehicles="false" show_3d_waypoints="false" show_name_plates="false" override_weather="false" override_time="false" override_wind="false" physics_timestep="0" wildlife_enabled="true" fish_spawn_rate="2" unlock_components="true" dlc_weapons="false" dlc_arid="false"/>

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

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

View File

@@ -23,15 +23,15 @@ if [ "${USERNAME}" == "" ]; then
echo "---Validating installation---" echo "---Validating installation---"
${STEAMCMD_DIR}/steamcmd.sh \ ${STEAMCMD_DIR}/steamcmd.sh \
+@sSteamCmdForcePlatformType windows \ +@sSteamCmdForcePlatformType windows \
+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 \
+@sSteamCmdForcePlatformType windows \ +@sSteamCmdForcePlatformType windows \
+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
@@ -40,96 +40,24 @@ else
echo "---Validating installation---" echo "---Validating installation---"
${STEAMCMD_DIR}/steamcmd.sh \ ${STEAMCMD_DIR}/steamcmd.sh \
+@sSteamCmdForcePlatformType windows \ +@sSteamCmdForcePlatformType windows \
+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 \
+@sSteamCmdForcePlatformType windows \ +@sSteamCmdForcePlatformType windows \
+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 [ ! -z "${WS_CONTENT}" ]; then
echo "---Installing Workshop Content with ID('s): ${WS_CONTENT}---"
${STEAMCMD_DIR}/steamcmd.sh \
+@sSteamCmdForcePlatformType windows \
+login anonymous \
+force_install_dir ${SERVER_DIR} \
+workshop_download_item 440900 ${WS_CONTENT// / +workshop_download_item 440900 } \
+quit
if [ ! -d ${SERVER_DIR}/ConanSandbox/Mods ]; then
if [ ! -d ${SERVER_DIR}/ConanSandbox ]; then
echo "-----------------------------------"
echo "------Something went wrong can't find folder-"
echo "---'ConanSandbox' putting server into sleep mode---"
echo "-"
sleep infinity
fi
echo "---Folder 'Mods' not found, creating...---"
mkdir ${SERVER_DIR}/ConanSandbox/Mods
fi
if [ ! -f ${SERVER_DIR}/ConanSandbox/Mods/modlist.txt ]; then
echo "---File 'modlist.txt' not found, creating...---"
touch ${SERVER_DIR}/ConanSandbox/Mods/modlist.txt
fi
echo "---Putting workshop content into modlist---"
#install mods in order
> ${SERVER_DIR}/ConanSandbox/Mods/modlist.txt
for WS_ITEM in ${WS_CONTENT}; do
find ${SERVER_DIR}/steamapps/workshop/content/440900/${WS_ITEM}/ -name *.pak >> ${SERVER_DIR}/ConanSandbox/Mods/modlist.txt
done
fi
echo "---Prepare Server---" echo "---Prepare Server---"
echo "---Looking for config files---"
if [ ! -d ${SERVER_DIR}/ConanSandbox/Saved/Config/WindowsServer ]; then
if [ ! -d ${SERVER_DIR}/ConanSandbox ]; then
echo "-----------------------------------------------------------"
echo "---Something went wrong can't find folder 'ConanSandbox'---"
echo "--------------Putting Server into sleep mode---------------"
sleep infinity
fi
if [ ! -d ${SERVER_DIR}/ConanSandbox/Saved ]; then
mkdir ${SERVER_DIR}/ConanSandbox/Saved
fi
if [ ! -d ${SERVER_DIR}/ConanSandbox/Saved/Config ]; then
mkdir ${SERVER_DIR}/ConanSandbox/Saved/Config
fi
if [ ! -d ${SERVER_DIR}/ConanSandbox/Saved/Config/WindowsServer ]; then
mkdir ${SERVER_DIR}/ConanSandbox/Saved/Config/WindowsServer
fi
fi
if [ ! -f ${SERVER_DIR}/ConanSandbox/Saved/Config/WindowsServer/Engine.ini ]; then
echo "---'Engine.ini' not found, downloading template---"
cd ${SERVER_DIR}/ConanSandbox/Saved/Config/WindowsServer
if wget -q -nc --show-progress --progress=bar:force:noscroll https://raw.githubusercontent.com/ich777/docker-steamcmd-server/conanexiles/config/Engine.ini ; then
echo "---Sucessfully downloaded 'Engine.ini'---"
else
echo "---Something went wrong, can't download 'Engine.ini', putting server in sleep mode---"
sleep infinity
fi
else
echo "---'Engine.ini' found---"
fi
if [ ! -f ${SERVER_DIR}/ConanSandbox/Saved/Config/WindowsServer/ServerSettings.ini ]; then
echo "---'ServerSettings.ini' not found, downloading template---"
cd ${SERVER_DIR}/ConanSandbox/Saved/Config/WindowsServer
if wget -q -nc --show-progress --progress=bar:force:noscroll https://raw.githubusercontent.com/ich777/docker-steamcmd-server/conanexiles/config/ServerSettings.ini ; then
echo "---Sucessfully downloaded 'ServerSettings.ini'---"
else
echo "---Something went wrong, can't download 'ServerSettings.ini', putting server in sleep mode---"
sleep infinity
fi
else
echo "---'ServerSettings.ini' found---"
fi
export WINEARCH=win64 export WINEARCH=win64
export WINEPREFIX=/serverdata/serverfiles/WINE64 export WINEPREFIX=/serverdata/serverfiles/WINE64
export DISPLAY=:99
echo "---Checking if WINE workdirectory is present---" echo "---Checking if WINE workdirectory is present---"
if [ ! -d ${SERVER_DIR}/WINE64 ]; then if [ ! -d ${SERVER_DIR}/WINE64 ]; then
echo "---WINE workdirectory not found, creating please wait...---" echo "---WINE workdirectory not found, creating please wait...---"
@@ -146,11 +74,60 @@ if [ ! -d ${SERVER_DIR}/WINE64/drive_c/windows ]; then
else else
echo "---WINE properly set up---" echo "---WINE properly set up---"
fi fi
echo "---Checking config---"
if grep -q "<name>My own LiF server</name>" ${SERVER_DIR}/config/world_1.xml ; then
echo "---Adding initial config parameters to config file---"
sed -i 's/\<My own LiF server\>/LiF Docker/g' ${SERVER_DIR}/config/world_1.xml
sed -i s/"<password><\/password>"/"<password>Docker<\/password>"/g ${SERVER_DIR}/config/world_1.xml
sed -i s/"<adminPassword><\/adminPassword>"/"<adminPassword>adminDocker<\/adminPassword>"/g ${SERVER_DIR}/config/world_1.xml
else
echo "---Config check done---"
fi
echo "---Checking if database is in place---"
if [ ! -d ${SERVER_DIR}/.database ]; then
echo "---Database not found, setting up databbase...---"
mkdir -p ${SERVER_DIR}/.database
cp -R /var/lib/mysql/* ${SERVER_DIR}/.database/
else
echo "---Database found---"
fi
echo "---Checking if database configuration is in place---"
if [ ! -f ${SERVER_DIR}/config_local.cs ]; then
echo "---Database configuration not found, configuring...---"
cp ${SERVER_DIR}/docs/config_local.cs ${SERVER_DIR}/config_local.cs
sed -i 's/\<root\>/steam/g' ${SERVER_DIR}/config_local.cs
sed -i 's/\<rootPassword\>/lifyo/g' ${SERVER_DIR}/config_local.cs
else
echo "---Database connection found---"
fi
echo "---Starting MariaDB---"
screen -S MariaDB -d -m mysqld_safe
sleep 2
echo "---Starting Xvfb---"
screen -S Xvfb -d -m /opt/scripts/start-Xvfb.sh
sleep 2
echo "---Checking for old display lock files---" echo "---Checking for old display lock files---"
find /tmp -name ".X99*" -exec rm -f {} \; > /dev/null 2>&1 find /tmp -name ".X99*" -exec rm -f {} \; > /dev/null 2>&1
chmod -R ${DATA_PERM} ${DATA_DIR} chmod -R ${DATA_PERM} ${DATA_DIR}
echo "---Server ready---" echo "---Server ready---"
echo "---Start Server---" echo "---Start Server---"
cd ${SERVER_DIR} if [ ! -f ${SERVER_DIR}/ddctd_cm_yo_server.exe ]; then
xvfb-run --auto-servernum --server-args='-screen 0 640x480x24:32' wine64 ${SERVER_DIR}/ConanSandboxServer.exe -log ${GAME_PARAMS} echo "---Something went wrong, can't find the executable, putting container into sleep mode!---"
sleep infinity
else
cd ${SERVER_DIR}
screen -S LiFYO -d -m wine64 ddctd_cm_yo_server.exe ${GAME_PARAMS}
echo "---Waiting for logs...---"
sleep 3
/opt/scripts/start-watchdog.sh &
cd ${SERVER_DIR}/logs
cd $(ls -1d */ | tail -1)
tail -n 9999 -f $(ls -t | head -n 1)
fi

View File

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

View File

@@ -1,27 +1,37 @@
#!/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 ||:
echo "---Found optional script, executing---" cp -f /opt/scripts/user.sh /opt/scripts/start-user.sh > /dev/null 2>&1 ||:
chmod +x /opt/scripts/user.sh
/opt/scripts/user.sh 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 else
echo "---No optional script found, continuing---" echo "---No optional script found, continuing---"
fi fi
echo "---Starting...---" echo "---Taking ownership of data...---"
chown -R ${UID}:${GID} /opt/scripts chown -R root:${GID} /opt/scripts
chmod -R 750 /opt/scripts
chown -R ${UID}:${GID} /var/lib/mysql
chown -R ${UID}:${GID} /var/run/mysqld
chown -R ${UID}:${GID} ${DATA_DIR} chown -R ${UID}:${GID} ${DATA_DIR}
chmod -R 770 /var/lib/mysql
chmod -R 770 /var/run/mysqld
echo "---Starting...---"
term_handler() { term_handler() {
kill -SIGTERM "$killpid" kill -SIGINT $(pidof ddctd_cm_yo_server.exe)
wait "$killpid" -f 2>/dev/null tail --pid=$(pidof ddctd_cm_yo_server.exe) -f 2>/dev/null
exit 143; exit 143;
} }