Ubuntu搭建饥荒服务器教程

Ubuntu搭建饥荒服务器教程安装编译环境Ubuntu/Debian64-Bitsudoapt-getinstalllib32gcc1screenRedHat/CentOS32-Bityum-yinstallglibclibstdc++screenlibcurlRedHat/CentOS64-Bityum-yinstallglibc.i686libstdc++.i686screenlibcurl.i686yuminstallglibc.i686下载steamCMDwget

大家好,又见面了,我是你们的朋友全栈君。

软件前提

每次饥荒更新服务器都会找不到的,请及时更新

买阿里云或者腾讯云服务器
1核2G 1M 差不多2-3 人,不是很卡,人数变多的话,就会很卡的,100 块
看自己个人需求


一般的话 2核 4G ,
8人左右,差不多 400块

系统 ubuntu20,如果选错了系统,可以点击重装系统的,在控制台都有按钮的
在这里插入图片描述

1. 安装编译环境

ubuntu

sudo add-apt-repository multiverse
sudo dpkg --add-architecture i386
sudo apt update -y
sudo apt install lib32gcc1 libcurl4-gnutls-dev:i386 lib32stdc++6 lib32z1 -y

centos 7

yum update -y
yum install https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm -y
yum install glibc.i686 libstdc++.i686 libcurl.i686 screen -y

centos 8

yum update -y
yum install https://dl.fedoraproject.org/pub/epel/epel-release-latest-8.noarch.rpm -y
yum install glibc.i686 libstdc++.i686 libcurl.i686 screen -y

2. 下载 steamCMD,安装

mkdir ~/steamcmd
cd ~/steamcmd
wget https://steamcdn-a.akamaihd.net/client/installer/steamcmd_linux.tar.gz
tar -xvzf steamcmd_linux.tar.gz

如果steam 包下载不下来

sudo apt install steamcmd -y

按住tab 键选择ok
选择I agree 统一安装
然后运行steam

运行

安装包运行

./steamcmd.sh

如果是直接安装steam,运行一下命令

steam

3. 在steam 状态下 匿名登录,安装饥荒服务器

login anonymous
force_install_dir ../dontstarvetogether_dedicated_server
app_update 343050 validate
quit

这个是下载 饥荒的服务器,需要一定的时间

343050 是饥荒在steam 中的 id

如果这里提示”Failed to init SDL priority manager: SDL not found”之类的,执行

sudo apt install libsdl2-2.0-0:i386

后再重复以上操作

3.1 查看是否安装成功

这里每个人的安装地方都不同,如果是用我的代码,那就应该是这个地方。可以用sftp 查看一下自己饥荒具体安装的位置

在这里插入图片描述

cd ~/dontstarvetogether_dedicated_server/bin/
./dontstarve_dedicated_server_nullrenderer

在这里插入图片描述
出现这样子的情况,饥荒就安装成功了

在这里插入图片描述

ctrl+c 可以退出

可能需要解决的

解决 lib 缺失(如果有lib依赖缺失的问题请一定要运行这一步,添加软关系,其实云端是有这个依赖的

cd ~/dontstarvetogether_dedicated_server/bin/lib32
ln -s /usr/lib/libcurl.so.4 libcurl-gnutls.so.4

4. 创建本地存档

在这里插入图片描述
在这里插入图片描述
直接退出
在这里插入图片描述

5. 创建服务器地图存档

mkdir -p ~/.klei/DoNotStarveTogether/Cluster_1

打开xftp 的 隐藏图标

在这里插入图片描述

用xftp 上传 本地的 地图资源

在这里插入图片描述
上传完效果
在这里插入图片描述

6. 创建 服务器token,更换地图资源中的token

https://accounts.klei.com/account/info

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
这里是我的token,一定要用自己的token

pds-g^KU_SpqLc8Hm^Y5FP+OXvmjd+5WQ0L8A1pFAtALYf1ecPQIzVG2gYR2c=

6.1 更换地图资源的cluster_token.txt

在这里插入图片描述

7. 添加mod 信息

7.1 查看本地mod 的id

在这里插入图片描述

7.2 修改服务器mod

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

ServerModSetup("1207269058") 
ServerModSetup("1216718131") 
ServerModSetup("1392778117") 
ServerModSetup("1508510758") 
ServerModSetup("1530801499") 
ServerModSetup("1595631294")  
ServerModSetup("1699194522")  
ServerModSetup("1751811434")  
ServerModSetup("1818688368") 
ServerModSetup("1894295075") 
ServerModSetup("1909182187")
ServerModSetup("1951468597") 
ServerModSetup("1991746508") 
ServerModSetup("2078243581") 
ServerModSetup("2289662010") 
ServerModSetup("347079953") 
ServerModSetup("2152123483") 
ServerModSetup("2208128427") 
ServerModSetup("2172284661") 
ServerModSetup("362175979") 
ServerModSetup("447092740") 
ServerModSetup("374550642") 
ServerModSetup("537902048") 
ServerModSetup("375850593") 
ServerModSetup("378160973") 
ServerModSetup("501385076") 
ServerModSetup("666155465") 
ServerModSetup("810443397")
ServerModSetup("623749604")
ServerModSetup("727171538") 
ServerModSetup("519266302") 
ServerModSetup("666155465") 
ServerModSetup("875994715")
ServerModSetup("537902048")
ServerModSetup("623749604")

378160973 (Global Positions) 全球定位
1207269058 ( Simple Health Bar DST)简易血条
666155465 (Show Me (Origin)) 展示信息
737932010 (Damage Indicators) 伤害面板
1751811434 (Fast Work) 快速工作

8. 创建命令,运行服务器

cd ~
touch start.sh

8.1 编译

steamcmd_dir 表示的是steam 安装的位置
install_dir 表示的 饥荒服务器安装的位置
cluster_name 表示的是 地图的名字
donstarve_dir 表示的是 地图的位置

#!/bin/bash

steamcmd_dir="$HOME/steamcmd"
install_dir="$HOME/dontstarvetogether_dedicated_server"
cluster_name="Cluster_1"
dontstarve_dir="$HOME/.klei/DoNotStarveTogether"

function fail()
{ 
   
        echo Error: "$@" >&2
              exit 1
            }

            function check_for_file()
            { 
   
                if [ ! -e "$1" ]; then
                            fail "Missing file: $1"
                              fi
                            }

                            cd "$steamcmd_dir" || fail "Missing $steamcmd_dir directory!"

                            check_for_file "steamcmd.sh"
                            check_for_file "$dontstarve_dir/$cluster_name/cluster.ini"
                            check_for_file "$dontstarve_dir/$cluster_name/cluster_token.txt"
                            check_for_file "$dontstarve_dir/$cluster_name/Master/server.ini"
                            check_for_file "$dontstarve_dir/$cluster_name/Caves/server.ini"
                            check_for_file "$install_dir/bin"

                            cd "$install_dir/bin" || fail

                            run_shared=(./dontstarve_dedicated_server_nullrenderer)
                            run_shared+=(-console)
                            run_shared+=(-cluster "$cluster_name")
                            run_shared+=(-monitor_parent_process $$)
                            run_shared+=(-shard)

                            "${run_shared[@]}" Caves | sed 's/^/Caves: /' &
                            "${run_shared[@]}" Master | sed 's/^/Master: /'

8.2 修改权限

chmod u+x ~/start.sh 

8.3 启动服务器

screen -S DST
./start.sh 

在这里插入图片描述

8.4 配置令牌和服务器管理员

先新建 adminlist.txt 文件,再将此前获取到的 UserID 复制到文件中。

touch adminlist.txt

内容如下

KU_SpqLc8Hm
KU_SpqLc83m
KU_3pqLc9Hm

一个管理员一行,两个管理员两行

运行效果如下
在这里插入图片描述

9. 可能出现的问题

bash: ./start.sh: /bin/bash^M: bad interpreter: No such file or directory

原因是 文件的格式是dos,修改为unix 就OK了

查看文件格式 用vim 打开出错的文件 按 ESC键 再按shift+冒号 输入 set ff 回车 可以看见 该文件的格式 fileformat=dos
按shift + 冒号 输入 set ff=unix 回车 发现没反应,那就对了。
可以按 shift + 冒号 set ff 查看 fileformat=unix

10. 升级

饥荒更新,重新下载

~/steamcmd/steamcmd.sh +login anonymous +force_install_dir ~/dontstarvetogether_dedicated_server/ +app_update 343050 validate +quit

mod 更新
回到后台

screen -r DST

ctrl+C

./start.sh 
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/137366.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 【Github教程】史上最全github用法:github入门到精通

    【Github教程】史上最全github用法:github入门到精通

    2021年11月29日
    53
  • JAVA线程通信详解[通俗易懂]

    JAVA线程通信详解[通俗易懂]目录一、概述二、wait/notify机制三、Condition四、生产者/消费者模式五、线程间的通信——管道六、方法Join的使用一、概述    线程与线程之间不是相互独立的个体,它们彼此之间需要相互通信和协作,最典型的例子就是生产者-消费者问题:当队列满时,生产者需要等待队列有空间才能继续往里面放入商品,而在等待的期间内,生产者必须释放对临界资源(即队列…

    2022年6月19日
    25
  • springboot之项目打包

    springboot之项目打包

    2021年7月7日
    107
  • 集合转数组[通俗易懂]

    集合转数组[通俗易懂]LinkedListl=newLinkedList();l.add(“one”);l.add(“two”);l.add(“three”);System.out.println(l);Object[]c=l.toArray();for(inti=

    2022年6月14日
    30
  • 页面刷新的reload()和refresh()方法有什么不同

    页面刷新的reload()和refresh()方法有什么不同window.reload是重新加载当前需要的所有内容,也就包括页面和后台的代码,此过程中实际上是从后台重新进行操作;window.Refresh是刷新,保留之前的缓存内容,重新加载页面,之前存在的东西不会动,没加载上来的东西继续加载,也会去加载后台代码内容的。

    2022年7月18日
    53
  • UCI数据集整理(附论文常用数据集)

    UCI数据集整理(附论文常用数据集)摘要:UCI数据集作为标准测试数据集经常出现在许多机器学习的论文中,为了更方便使用这些数据集有必要对其进行整理,这里整理了论文中经常出现的数据集,并详细介绍如何使用MATLAB将数据集文件整理成自己需要的格式以及如何使用数据集文件。要点如下UCI数据集介绍用程序整理数据集如何使用数据集文件点击跳转至UCI数据集下载页1.前言UCI数据集是一个常用的机器…

    2022年6月28日
    42

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号