首页 > 其他分享 >Wow魔兽世界服务器搭建详细教程

Wow魔兽世界服务器搭建详细教程

时间:2023-04-08 16:02:38浏览次数:56  
标签:教程 Wow TrinityCore 服务器 home wow server3.5 客户端

自从《魔兽世界》国服关服后,很多魔兽老玩家心里都是空落落的,魔兽陪伴了我们十多年,此次关服犹如关上了通往艾泽拉斯大陆的大门。

上帝关上了一扇门,我们也可以自己开扇窗,随着国服关闭,越来越多的玩家想要自己开服当服主,今天明杰将和你们分享魔兽世界服务器搭建教程。

想要搭建一个魔兽商业服,需要有魔兽世界服务端、客户端和服务器,若是自己不会技术,可以请个技术架设、调试,简单的调试可以和技术请教学习。

魔兽世界服务端

魔兽世界服务端有多种选择,如下:

60级经典旧世版本

70级燃烧的远征版本

80级巫妖王之怒版本

85级大地的裂变版本

90级熊猫人之谜版本

100级德拉诺之王版本

110级军团再临版本

120级争霸艾泽拉斯版本

可以选择自己喜欢的,也可以选择玩家更喜欢的。

魔兽世界服务器

玩家游戏体验感及游戏流畅度都是由服务器决定的。魔兽世界对服务器的配置要求不是很高,CPU像英特尔E5 、酷睿i9系列16核心都是可以满足要求的。当然,选择服务器除了看CPU,还需要看服务器带宽和防御,带宽决定了一个服能承载多少玩家同时在线游戏,带宽有共享带宽和独享带宽,两者区别可以自行了解下。

做游戏开发不能避免会被同行或是公鸡小组盯上,若是对方通过手段发起公鸡,选择的服务器防御低,服务器连接不上,将会直接影响到服里的玩家游戏体验感,所以选择高防服务器是必要的。

防御也分为两种,一种是单机防御,一种是集群防御,单机防御只为一台服务器提供相应的防御能力。例如你所选择的服务器防御配置是100G单机防御,只要遇到的公鸡不超过100G,服务器还是可以正常运行的。

集群防御就不同,由一组防火墙防护多台服务器。一旦遇到公鸡,公鸡值超过集群防御的最大范围值,崩溃的服务器将不仅仅是一台,而是集群下所有的服务器。所以机房不同,防护能力和售后服务都是不同的,服务器性能如何可以通过测试进行初步判断。

 

Debian系统服务器搭建魔兽世界

准备工作

依赖安装

apt-get update

apt-get install git clang cmake make gcc g++

update-alternatives --install /usr/bin/cc cc /usr/bin/clang 100

update-alternatives --install /usr/bin/c++ c++ /usr/bin/clang 100

#boost依赖,如下

apt-get install -y libboost-all-dev \

libboost-system-dev \

libboost-filesystem-dev \

libboost-program-options-dev \

libboost-iostreams-dev

mariadb-server

apt-get install libmariadbclient-dev

zlib在 zlib1g-dev

apt-get install zlib1g-dev

 

# openssl

apt-get install libssl-dev

# readline

apt-get install libreadline-dev

# mysql

apt-get install -y libmysqlclient-dev

 

创建wow用户

用户名为wow

adduser wow

su wow

 

如果用windows子系统,可以设置默认进入用户

windows进入cmd命令行,执行指令进入Apps目录:

cd %HOMEPATH%\AppData\Local\Microsoft\WindowsApps

因为我安装的debian,所以这个目录下有个debian.exe的文件(如果是ubuntu那么就是ubuntu.exe)

debian.exe config --default-user wow

设置完再进入子系统就是wow用户了

 

约定目录

# 以wow权限执行

su wow

cd ~

既然是网络游戏,一定需要C端和S端,即客户端和服务器端。预先创建对应目录方便后面操作。

# TrinityCore源码目录

mkdir /home/wow/TrinityCore

# 服务器目录,最终包含etc,bin,data三个子目录

mkdir /home/wow/server3.5.5

# 客户端目录,后面用于存放客户端版本,提取客户端数据

mkdir /home/wow/client12340

 

下载工作

S端下载

Release TDB 335.22061 · TrinityCore/TrinityCore · GitHub

cd /home/wow/TrinityCore

wget https://github.com/TrinityCore/TrinityCore/archive/refs/tags/TDB335.22061.zip

#解压

unzip TDB335.22061.zip

 

C端下载

客户端版本:3.3.5(12340)

(下载解压后,需要完成后把文件上传到Linux服务器上)

 

编译服务端

# 切回wow

su wow

cd /home/wow/TrinityCore/TrinityCore-TDB335.22061

# 构建项目

mkdir build

cd build

cmake ../ -DCMAKE_INSTALL_PREFIX=/home/wow/server3.5.5 

# 这个步骤可能时间比较长,可以用nohup或者screen执行

make  -j$(nproc) install

编译完成后home/wow/server3.5.5目录会出现bin、etc和bin目录

bin下面是生成的可执行文件。

data下面后面会放入客户端提取的地图数据。

etc 下面是一些配置文件。

注:查看并留意下这三个目录里面的文件,后面会用到。

 

修改配置文件

worldserver.conf.distauthserver.conf.dist各自复制一份,然后去掉后缀.dist 。

cp /home/wow/server3.5.5/etc/worldserver.conf.dist worldserver.conf

cp /home/wow/server3.5.5/etc/authserver.conf.dist authserver.conf

修改worldserver.conf 中 DataDir = "." 为 DataDir = "../data"。

注意:我这里填的是相对路径"../data",你也可以填写绝对路径/home/wow/server3.5.5/data


提取客户端信息

DBC and Maps files

将下载好的客户端,复制一份到上面约定的客户端目录/home/wow/client12340中,进入目录。

cd /home/wow/client12340

运行下面命令,提取客户端数据

/home/wow/server3.5.5/bin/mapextractor

mkdir /home/wow/server3.5.5/data

cp -r dbc maps /home/wow/server3.5.5/data

Visual Maps (aka vmaps)

cd /home/wow/client12340

/home/wow/server3.5.5/bin/vmap4extractor

mkdir vmaps

/home/wow/server3.5.5/bin/vmap4assembler Buildings vmaps

cp -r vmaps /home/wow/server3.5.5/data

Movement Maps (aka mmaps)

cd /home/wow/client12340

mkdir mmaps

/home/wow/server3.5.5/bin/mmaps_generator

cp -r mmaps /home/wow/server3.5.5/data

将地图数据copy到数据目录

cp -r dbc maps /home/wow/server3.5.5/data

cp -r vmaps /home/wow/server3.5.5/data

cp -r mmaps /home/wow/server3.5.5/data

 

数据库

这里用root

环境搭建中我们已经安装mariadb-server数据库(当然也可以使用mysql),所以现在我们需要运行起来。

运行数据库

systemctl enable mysql

systemctl restart mysql

初始化数据库

mysql_secure_installation

# Enter current password for root (enter for none):

会显示叫你输入密码,因为安装时并没有设置密码,所以直接输入回车enter

# Change the root password? [Y/n]

Y

# 输入两次密码

# Remove anonymous users? [Y/n]

Y

# Disallow root login remotely? [Y/n]

# Y表示让root用户远程登录,N表示可以远程登录

Remove test database and access to it? [Y/n]

Y

Reload privilege tables now? [Y/n]

Y


登录数据库

mysql -u root

登录成功,类似如下

Welcome to the MariaDB monitor. Commands end with ; or \g.

Your MariaDB connection id is 2

Server version: 10.1.29-MariaDB-6 Ubuntu 18.04

Copyright (c) 2000, 2017, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]>

 

 导入数据

1、创建数据库

Source /home/wow/TrinityCore/TrinityCore-TDB335.22061/sql/create/create_mysql.sql

# 显示当前数据库系统中所有数据库列表

show databases

+--------------------+

| Database |

+--------------------+

| auth |

| characters |

| information_schema |

| mysql |

| performance_schema |

| world |

+--------------------+

2、建表

use auth;

Source /home/wow/TrinityCore/TrinityCore-TDB335.22061/sql/base/auth_database.sql

use characters;

Source /home/wow/TrinityCore/TrinityCore-TDB335.22061/sql/base/characters_database.sql

 

地图数据载入

创建数据目录,用来存放地图数据

mkdir /home/wow/server3.5.5/data

 

配置网络

连接数据库,输入以下sql,打开auth库,并查看表realmlist

use auth;

select id,name,address,localaddress,gamebuild from realmlist;

Wow魔兽世界服务器搭建详细教程_客户端


address为现网ip及客户端连接ip。本地跑默认127.0.0.1。部署到服务器,需要更改为服务器的ip。

port为对外端口及客户端连接端口。现网需要开放此端口

localaddress为内网ip

gamebuild 为客户端版本号 ,是12340 还是 13930 取决于你所使用的客户端版本

 

启动服务端

运行 authserver(authserver即认证服务,我们登陆账户都是到这里认证后才会请求worldserver)

/home/wow/server3.5.5/bin/authserver

# or

/home/wow/server3.5.5/bin/authserver -c /home/wow/server3.5.5/etc/authserver.conf

如下为成功启动

Connected to MySQL database at 127.0.0.1

DatabasePool 'auth' opened successfully. 2 total connections running.

Started auth database connection pool.

Loading IP Location Database...

Added realm "Trinity" at 127.0.0.1:8085.


运行 worldserver

/home/wow/server3.5.5/bin/worldserver

如果你按照上述步骤一步一步到了这里,那么运行结果可能提示缺少一个文件

TDB_full_world_335.22061_2022_06_01.sql!!!
File "TDB_full_world_335.22061_2022_06_01.sql" is missing,

download it from "https://github.com/TrinityCore/TrinityCore/releases"

uncompress it and place the file "TDB_full_world_335.22061_2022_06_01.sql"

in the directory "/home/rendu".

这里根据你当前运行的worldserver的提示去下载,

World initialized in 11 minutes 39 seconds

Starting up anti-freeze thread (60 seconds max stuck time)...

TrinityCore rev. fc56410b6e0d 2021-02-19 00:42:06 +0200 (3.3.5 branch) (Unix, RelWithDebInfo, Static) (worldserver-daemon) ready...

TC>

看到如上输出,那么恭喜你,worldserver启动成功。

 

添加账号

创建一个用户名为idc02找明杰,密码也为idc02的账号,使用以下命令格式

account create <user> <pass>

TC>TC> account create idc02 idc02

升级为GM

可以提升idc02的gmlevel为3,升级为GM账号,worldserver命令行输入,如下

TC> account set gmlevel idc02 3 -1

 

登录游戏

打开客户端目录,找到wow.exe,同级目录下创建wow.bat,内容如下:

# 在本地搭建ip填写127.0.0.1,外网填写服务器IP,这个ip对应上面realmlist中的address

echo y | rd /s "Cache"

echo SET realmlist "103.219.39.*" > Data\zhTW\realmlist.wtf

echo SET realmlist "103.219.39.*" > Data\enTW\realmlist.wtf

echo SET realmlist "103.219.39.*" > Data\zhCN\realmlist.wtf

echo SET realmlist "103.219.39.*" > Data\enCN\realmlist.wtf

echo SET realmlist "103.219.39.*" > Data\enUS\realmlist.wtf

echo SET realmlist "103.219.39.*" > realmlist.wtf

start Wow.exe

goto end

然后运行脚本,此时初始化客户端连接配置成功,进入游戏。

 

标签:教程,Wow,TrinityCore,服务器,home,wow,server3.5,客户端
From: https://blog.51cto.com/IDC02COM/6177592

相关文章

  • 基于Ubuntu20.04搭建nfs服务器
    准备一台Ubuntu虚拟机IP:192.168.129.114安装nfs-serversudoapt-getinstallnfs-kernel-server添加NFS共享目录sudovim/etc/exports添加一行*表示允许任何网段IP的系统访问该NFS目录/nfsroot*(rw,sync,no_root_squash)新建/nfsroot目录,并为该目录设置最......
  • Linux系统下安装MySQL8.0图文教程
    Linux系统下安装MySQL8.0图文教程1.环境准备1.1. 操作系统Centos7.3,中标麒麟7.61.2. 防火墙配置(可关闭防火墙,不建议)操作系统开启防火墙(注意:不建议把防火墙关闭,应该设置开放对应的端口,或者开放给哪些IP地址的哪些端口)。(1) 防火墙端口开放设置:https://www.cnblogs.com/liu......
  • WSL使用教程
    1.下载WSL环境配置ubuntu安装包VCS工具安装包2.准备1)在管理员模式下打开PowerShell(强烈建议安装terminal操作方便界面效果好)dism.exe/online/enable-feature/featurename:Microsoft-Windows-Subsystem-Linux/all/norestart#启用虚拟化dism.exe/online/......
  • Xbox Series X 完全关机教程 All In One
    XboxSeriesX完全关机教程AllInOne主机的风扇完全停止工作✅https://www.douyin.com/video/7193633798267915581https://www.biaopan8.com/9985.html(......
  • 人工智能AI需要什么配置的服务器开发搭建架设
    人工智能AI需要什么配置的服务器开发搭建架设我是艾西,最近很火的ChatGPT我相信应该不少小伙伴都有关注这个话题吧,随着网络以及技术上的更新迭代人工智能AI需要什么配置的服务器开发搭建呢?人工智能(AI)技术在各种领域中得到了越来越广泛的应用,但要想获得高质量的AI算法和模型,需要拥有......
  • 人工智能AI服务器配置需求
    人工智能AI服务器配置需求我是艾西,今天聊聊很火的话题人工智能AI。大家从网络上应该了解了不少关于使用人工智能的便捷之处,包括一些科幻电影里面都有展示不少让人想要的功能,那么搭建人工智能AI的系统需要什么配置的服务器呢?艾西也是根据网络上能找到的资料以及相关知识总结而出一......
  • 语言服务器
    笔记软件在2023/4/615:08:06推送该笔记语言服务器与客户端语言服务器语言客户端语言服务器运行在单独的进程有两个好处:只要能通过LSP通信,语言分析工具可以用任何语言实现。语言分析工具一般非常消耗CPU和内存,在单独的进程中运行能避免大性能开销lsp-sample:本篇教程的......
  • 在Lync/Skype服务器中添加新的SIP域
    测试目的公司需要在当前的Skypeforbusiness2015环境中添加一个新的sip域,以匹配新增的用户的主SMTP域和sip域名。本测试旨在测试在不同场景中添加新sip域后的Skype客户端功能,并列出Skypeforbusiness2015环境中的所有必要更改。测试环境ServerNameIPAddressRoleDomainAD01192......
  • 史诗级Ubuntu配置教程
    title:Windows安装Anaconda并且配置国内镜像教程top:falsehide:falsecover:falsetoc:truemathjax:truesummary:在学习OpenCV或者其他关于Python技术的时候,我们通常需要准备不同的Python环境,我选择了Anaconda作为我的Python环境管理器。tags:-Anaconda-Pytho......
  • 软考高项第4版教程-差异点解析来啦(第18章)!
    继续高项信息系统项目管理师第4版教程的差异点解析,今天带来第18章的解析。估计还会有朋友问,上次解析到了第5章,这次怎么直接跳到了第18章呢?中间的章节不解析了吗?其实上次已经预报过了,这次在开头再解释下,咱们这次解析的重点在“差异点”3个字,我先把差异变化比较大的章节解析完成,再回......