首页 > 分享 > TrinityCore魔兽世界服务器

TrinityCore魔兽世界服务器

TrinityCore是模拟魔兽世界(World of Warcraft)的开源项目。

我这里学习搭建环境,基于以下:

客户端World of Warcraft 3.3.5(12340或13930版本)服务端TrinityCore3.3.5分支

注:租用的服务器到期啦,下面地址已经不能用了!!

下面是我自己用的客户端(12340),对应我自己的云服务器。下载就可以直接玩喽!

账号注册: 沸腾WOW

客户端:https://pan.baidu.com/s/1jVQ4qoJ4qGNDHOBUzicIjg  

提取码:imbo (某度云盘真是ma了f*ck 慢)

前言

关于版本选择3.3.5, 是由于我对这个版本的魔兽世界更加了解,作为一名资深兽人,觉得这个版本的魔兽是最好玩的。TrinityCore官方估计也是这么认为的,所以3.3.5这个版本维护的较完善,bug少,是推荐版本。

选择linux来搭建,完全是个人兴趣,这里我用的是Debian。主要目的是入门linux游戏服务器开发。官方也支持 MacOS和Windows,感兴趣的老铁们可以自行查阅以下网站。

官方: https://github.com/TrinityCore/TrinityCore.git

Releases · TrinityCore/TrinityCore · GitHub

官方wiki:  TrinityCore - Confluence

Installation Guide - TrinityCore - ConfluenceLinux Requirements - TrinityCore - Confluence GM Commands - TrinityCore - Confluence

其他:MaNGOS魔兽世界单机版 (xspio.com)

环境搭建

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

apt-get install -y libboost-dev

libboost-system-dev

libboost-filesystem-dev

libboost-program-options-dev

libboost-iostreams-dev

apt-get install zlib1g-dev

apt-get install libssl-dev

apt-get install libreadline-dev

apt-get install -y libmysqlclient-dev

创建wow用户

这里用root

adduser wow

su wow

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

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

cd %HOMEPATH%AppDataLocalMicrosoftWindowsApps

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

debian.exe config --default-user wow

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

约定目录

这里用wow

su wow

cd ~

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

mkdir /home/wow/TrinityCore

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(13930 或者12340) 自己想办法下载。魔兽老兵都懂如何下载正确版本。

这里只提供我自己用的一个版本(12340)。解压后讲道理是可以用的。

链接:https://pan.baidu.com/s/1jVQ4qoJ4qGNDHOBUzicIjg  提取码:imbo

数据库

这里用root

环境搭建中我们已经安装mariadb-server数据库(当然也可以使用mysql)。具体安装步骤可以参考我的另一篇博文

初始化数据库

mysql_secure_installation

输入回车

Y

Y

Y

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)]>

导入数据

第一步,创建数据库

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

show databases;

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

| Database |

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

| auth |

| characters |

| information_schema |

| mysql |

| performance_schema |

| world |

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

第二步,建表

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

编译服务端

这里切回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 #编译项目

编译成功后

ls /home/wow/server3.5.5 #可看到server3.5.5目录下有这3个文件夹 bin data etc bin下面是生成的可执行文件。data下面后面会放入客户端提取的地图数据。etc 下面是一些配置文件。

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

地图数据载入

创建数据目录

用来存放地图数据

mkdir /home/wow/server3.5.5/data 修改配置文件

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

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

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

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

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

从客户端导出地图数据

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

cd /home/wow/client12340

运行下面命令,提取客户端数据。这个过程有点慢,请耐心等待。

DBC and Maps files

/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)

/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)

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

配置连接

数据库配置

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

use auth;

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

address为现网ip,及客户端连接ip。本地跑默认127.0.0.1就好。如果部署到云,需要更改为对应的ip。port为对外端口,及客户端连接端口。现网需要开放本端口localaddress为内网ipgamebuild 为客户端版本号 ,是12340 还是 13930 取决于你所使用的客户端版本

客户端配置

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

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

echo y | rd /s "Cache"

echo SET realmlist "127.0.0.1" > DatazhTWrealmlist.wtf

echo SET realmlist "127.0.0.1" > DataenTWrealmlist.wtf

echo SET realmlist "127.0.0.1" > DatazhCNrealmlist.wtf

echo SET realmlist "127.0.0.1" > DataenCNrealmlist.wtf

echo SET realmlist "127.0.0.1" > DataenUSrealmlist.wtf

echo SET realmlist "127.0.0.1" > realmlist.wtf

start Wow.exe

启动服务端

先运行 authserver

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

/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的提示去下载,因为trinitycore团队一直在维护更新代码。聪明的你应该很快就能搞定!

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启动成功。

登入世界

添加账号

这里我创建了一个用户名为wow1,密码也为wow1的账号,并升级为GM等级

创建账号

创建一个wow的账号先,worldserver命令行输入,如下

TC> account create wow1 wow1

TC> Account created: wow1

升级为GM

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

TC> account set gmlevel wow1 3 -1

TC> Security level of account WOW1 changed to 3.

登入游戏

windows中找到客户端可执行文件wow.exe,双击运行,打开客户端。

然后输入刚才的账号就可以玩游戏啦~!

相关知识

魔兽世界怀旧服rp服务器是什么
魔兽世界wlk成就龙如何获得,魔兽世界WLk
魔兽世界小宠物(魔兽世界小宠物排行榜)
魔兽世界
《魔兽世界》慈善音乐会宠物大派送
魔兽世界猎人宠物喂食
魔兽世界猎人鸟宠物
魔兽世界云端翔龙骑士团声望攻略
魔兽世界宠物
魔兽世界水元素宠物

网址: TrinityCore魔兽世界服务器 https://m.mcbbbk.com/newsview631584.html

所属分类:萌宠日常
上一篇: nodejs+vue+eleme
下一篇: jiangshuchuan/宠物