A very generic Necesse dedicated server, which updates itself on startup with or without Mods in Docker.
Dockerfile
######## Auto Updating Necesse Server ######## FROM openjdk:latest ENV USER necesse ENV HOME /home/necesse WORKDIR $HOME COPY --from=steamcmd/steamcmd:latest /usr/lib/games/steam /usr/lib/games/steam COPY --from=steamcmd/steamcmd:latest /usr/bin/steamcmd /usr/bin/steamcmd COPY --from=steamcmd/steamcmd:latest /etc/ssl/certs /etc/ssl/certs COPY --from=steamcmd/steamcmd:latest /lib /lib RUN mkdir necesse RUN printf '#!/bin/bash \n\ steamcmd +login anonymous +force_install_dir ${HOME}/necesse +app_update 1169370 validate +quit \n\ i=1 \n\ variable="MOD_$i" \n\ value=${!variable} \n\ if test ! -Z "$value"; then \n\ mkdir -p .config/Necesse/mods \n\ rm .config/Necesse/mods/* \n\ fi \n\ while test ! -Z "$value"; do \n\ steamcmd +login "$STEAM_USER" "$STEAM_PASSWORD" +force_install_dir $HOME +workshop_download_item 1169040 $value +quit \n\ i=$((i+1)) \n\ variable="MOD_$i" \n\ value=${!variable} \n\ mv steamapps/workshop/content/**/**/*.jar .config/Necesse/mods \n\ done \n\ java -jar ${HOME}/necesse/Server.jar -nogui $@ \n\ ' >> entrypoint RUN chmod +x entrypoint # If you wish a cold start container, comment the next Line in RUN steamcmd +login anonymous +force_install_dir ${HOME}/necesse +app_update 1169370 validate +quit ENTRYPOINT ["./entrypoint"] EXPOSE 14159
Gebouw
docker build . -t necesse-server
Testen
Just test it with interactive mode:
docker run -it necesse-server
But it makes more sense to run it as demon, you also can use all the default start parameters:
docker run -d necesse-server -world mynewworld
Run a Server with No/Self Managed Mods
docker run -d --mount type=bind,source=</a/directory/on/your/harddrive>,target=/home/necesse/.config/Necesse/ -p 14159:14159 necesse-server -world <worldname>
in a docker-compose.yml it would look something like this:
versie: '3.7' services: necesse-server: opnieuw opstarten: unless-stopped build: . ports: - "14159:14159" volumes: - type: bind source: /srv/docker/necesse-config/ target: /home/necesse/.config/Necesse/ command: ["-world", "myworldname"]
Run a Server with Mods
You can only download Mods from the Steam workshop if you own the Game, so you need to provide steam credentials for an account that owns the game and is not steam guard protected for running an automated Necesse server with mods.
You should provide the password with a docker secret, but for this example, it’s plaintext
docker run -d --env STEAM_USER=<ASteamAccountWhichOwnsNecesse> --env STEAM_PASSWORD=<SteamPassword> --env MOD_1=<modId> --env MOD_2=<modId> --mount type=bind,source=</a/directory/on/your/harddrive>,target=/home/necesse/.config/Necesse/ necesse-server -world <worldname>
in a docker-compose.yml:
versie: '3.7' services: necesse-server: opnieuw opstarten: unless-stopped build: . ports: - "14159:14159" volumes: - type: bind source: /srv/docker/necesse-config/ target: /home/necesse/.config/Necesse/ command: ["-world", "myworldname"] environment: STEAM_USER: ASteamAccountWhichOwnsNecesse STEAM_PASSWORD: SteamPassword MOD_1: 2833909781 # Better Enchantment Mod
Dat is alles wat we vandaag hiervoor delen Necesse gids. Deze handleiding is oorspronkelijk gemaakt en geschreven door Mike Rohsoft. Voor het geval we er niet in slagen deze handleiding bij te werken, U kunt de laatste update vinden door dit te volgen link.