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 ${LAR}/necesse +app_update 1169370 validate +quit \n\ i=1 \n\ variable="MOD_$i" \n\ value=${!variável} \n\ if test ! -z "$valor"; then \n\ mkdir -p .config/Necesse/mods \n\ rm .config/Necesse/mods/* \n\ fi \n\ while test ! -z "$valor"; 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=${!variável} \n\ mv steamapps/workshop/content/**/**/*.jar .config/Necesse/mods \n\ done \n\ java -jar ${LAR}/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 ${LAR}/necesse +app_update 1169370 validate +quit ENTRYPOINT ["./entrypoint"] EXPOSE 14159
Prédio
docker build . -t necesse-server
Teste
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:
versão: '3.7' services: necesse-server: reiniciar: unless-stopped build: . portos: - "14159:14159" volumes: - tipo: bind source: /srv/docker/necesse-config/ target: /home/necesse/.config/Necesse/ command: ["-mundo", "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:
versão: '3.7' services: necesse-server: reiniciar: unless-stopped build: . portos: - "14159:14159" volumes: - tipo: bind source: /srv/docker/necesse-config/ target: /home/necesse/.config/Necesse/ command: ["-mundo", "myworldname"] environment: STEAM_USER: ASteamAccountWhichOwnsNecesse STEAM_PASSWORD: SteamPassword MOD_1: 2833909781 # Better Enchantment Mod
Isso é tudo o que estamos compartilhando hoje para isso Necesse guia. Este guia foi originalmente criado e escrito por Mike Rohsoft. Caso não atualizemos este guia, você pode encontrar a atualização mais recente seguindo este link.