TypechoJoeTheme

VB

统计

jy02548897

网站页面
类目归类

TrinityCore魔兽世界服务器搭建

jy02548897博主
2022-04-27
/
6 评论
/
75 阅读
/
1059 个字
/
百度已收录
04/27
本文最后更新于2022年04月27日,已超过1341天没有更新。如果文章内容或图片资源失效,请留言反馈,我会及时处理,谢谢!

TrinityCore是魔兽世界(World of Warcraft)的开源的服务端。这里针对魔兽的3.3.5.12340版本(开源代码的3.3.5分支)来学习搭建。

这是我自己的私服客户端,下载就可以直接玩喽。可以和朋友们一起玩(私信我,注册获取游戏账号,就可以登录了)

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

选择linux来搭建,完全是个人兴趣,这里我用的是Debian 10。主要目的是入门linux游戏服务器开发。

官方也支持 macOS,Windows ,感兴趣的可以自行查阅。

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

官方链接: TrinityCore

wiki教程: https://trinitycore.atlassian.net/wiki/spaces/tc/overview?mode=global

Linux Requirements - TrinityCore - Confluence
GM Commands - TrinityCore - Confluence
魔兽世界官方客户端下载 - MaNGOS魔兽世界单机版
环境搭建
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 mariadb-server libmariadbclient-dev default-libmysqlclient-dev

apt-get install libboost-all-dev libssl-dev

apt-get install libbz2-dev libreadline-dev libncurses-dev

apt-get install p7zip-full p7zip-rar
创建用户
用户名为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权限

网络游戏,需要C端和S端,即客户端和服务器端,

以wow权限执行

su - wow

TrinityCore 目录

mkdir /home/wow/TrinityCore

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

mkdir /home/wow/server3.5.5

客户端目录

mkdir /home/wow/client3.3.5_12340
S端下载:
git clone -b 3.3.5 git://github.com/TrinityCore/TrinityCore.git /home/wow/TrinityCore
C端下载:
客户端版本:3.3.5(12340) 自己想办法下载。玩魔兽的老玩家都懂如何下载正确版本。(我这里只能提供我自己用的一个版本。解压讲道理是可以用的。可私信我获取账号密码直接登录)

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

数据库
这里开始建议root权限

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

初始化数据库
mysql_secure_installation

Enter current password for root (enter for none):

输入回车

Change the root password? [Y/n]

Y

输入两次 密码

Remove anonymous users? [Y/n]

Y

Disallow root login remotely? [Y/n]

Y表示让root用户远程登录,N表示可以远程登录,老高推荐董数据库的同学选Y,觉得自己搞不定或者搞不懂的请选N

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

导入数据
第一步,创建数据库,执行以下sqlTrinityCore/sql/create/create_mysql.sql

source /home/wow/TrinityCore/sql/create/create_mysql.sql

show databases;
Database
auth
characters
information_schema
mysql
performance_schema
world

第二步,建表

use auth;
source /home/wow/TrinityCore/sql/base/auth_database.sql
use characters;
source /home/wow/TrinityCore/sql/base/characters_database.sql
编译服务端
这里切回wow权限

su - wow
cd /home/wow/TrinityCore
mkdir build
cd build
cmake ../ -DCMAKE_INSTALL_PREFIX=/home/wow/server3.5.5

下面步骤可能时间比较长,可以用nohup或者screen执行

make -j $(nproc) install

ls server3.5.5

可看到server3.5.5目录下有这3个文件加bin data etc

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

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

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

etc 下面是一些配置文件。

提取客户端地图信息
DBC and Maps files

cd /home/wow/client
/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/client
/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/client
mkdir mmaps
/home/wow/server3.5.5/bin/mmaps_generator
cp -r mmaps /home/wow/server3.5.5/data
到这里数据提取完成,并放到了指定目录。

把worldserver.conf.dist和authserver.conf.dist复制一份,然后去掉后缀.dist 。

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

配置网络
让我们打开数据库auth,查看一下表realmlist,让我们把address字段改为服务器的IP(本地跑,就默认,服务器IP为127.0.0.1)。

配置基本搞定

先运行 authserver
/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
好激动。但是。。。

Database World is empty, auto populating it...

File "TDB_full_world_335.21021_2021_02_15.sql" is missing, download it from "https://github.com/TrinityCore/TrinityCore/releases" uncompress it and place the file "TDB_full_world_335.21021_2021_02_15.sql" in the directory "/home/wow".
Could not populate the World database, see log for details.
如果你按照上述步骤一步一步到了这里。那么运行结果必然是类似上面这样的。不要慌。上面提示已经再清晰不过了。缺TDB_full_world_335.21021_2021_02_15.sql!!!

这里根据你当前运行的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启动成功。

添加账号
worldserver中,创建一个wow的账号先,使用以下命令格式:

account create

这里我们创建了一个用户名为wow1,密码也为wow1的账户

TC> account create wow1 wow1
TC> Account created: wow1

紧接着我们把wow1账户升级为gm

TC> account set gmlevel wow1 3 -1
TC> Security level of account WOW1 changed to 3.
账号创建好了

登录游戏
上面我给的客户端链接是直接连接的我的私服,如果要在本地跑,可如下操作

注意: 下面操作完了就不能连我的私服了

wow客户端下,把下面的代码保存为wow.bat并执行,直接允许。(在本地跑用127.0.0.1)

echo y | rd /s "Cache"
echo SET realmlist "127.0.0.1" > Data\zhTW\realmlist.wtf
echo SET realmlist "127.0.0.1" > Data\enTW\realmlist.wtf
echo SET realmlist "127.0.0.1" > Data\zhCN\realmlist.wtf
echo SET realmlist "127.0.0.1" > Data\enCN\realmlist.wtf
echo SET realmlist "127.0.0.1" > Data\enUS\realmlist.wtf
echo SET realmlist "127.0.0.1" > realmlist.wtf
start Wow.exe
goto end
然后输入刚才的账号就可以玩游戏啦~!

朗读
赞(0)
评论 (6)
  1. akcdesejww 闲逛
    Windows 10 · Google Chrome

    字里行间流露出真挚的情感,让人感同身受,共鸣不已。

    2025-03-02 回复
  2. wmynyzuefx 闲逛
    Windows 10 · Google Chrome

    反驳对手观点时需更注重逻辑严密性。

    2025-03-03 回复
  3. xsltqyigbz 闲逛
    Windows 10 · Google Chrome

    新盘新盘 这个月刚上新盘 新车第一个吃螃蟹!

    2025-10-06 回复
  4. dkfuqdfnlj 闲逛
    Windows 10 · Google Chrome

    2025年10月新盘 做第一批吃螃蟹的人coinsrore.com
    新车新盘 嘎嘎稳 嘎嘎靠谱coinsrore.com
    新车首发,新的一年,只带想赚米的人coinsrore.com
    新盘 上车集合 留下 我要发发 立马进裙coinsrore.com
    做了几十年的项目 我总结了最好的一个盘(纯干货)coinsrore.com
    新车上路,只带前10个人coinsrore.com
    新盘首开 新盘首开 征召客户!!!coinsrore.com
    新项目准备上线,寻找志同道合 的合作伙伴coinsrore.com
    新车即将上线 真正的项目,期待你的参与coinsrore.com
    新盘新项目,不再等待,现在就是最佳上车机会!coinsrore.com
    新盘新盘 这个月刚上新盘 新车第一个吃螃蟹!coinsrore.com

    2025-10-07 回复
  5. 华纳圣淘沙公司开户新手教程

    零基础学会(183-8890-9465薇-STS5099)
    华纳圣淘沙公司开户

    华纳圣淘沙公司开户保姆级教程(183-8890-9465薇-STS5099)

    一步步教你开通华纳圣淘沙公司账户(183-8890-9465薇-STS5099)

    华纳圣淘沙公司开户分步图解

    首次开户必看:(183-8890-9465薇-STS5099)
    华纳圣淘沙全攻略

    华纳圣淘沙公司开户实操手册(183-8890-9465薇-STS5099)
    华纳圣淘沙开户流程视频教程

    手把手教学:(183-8890-9465薇-STS5099)
    华纳圣淘沙公司开户

    华纳圣淘沙公司开户完全指南(183-8890-9465薇-STS5099)

    2025-11-21 回复
  6. 寻找华纳圣淘沙公司开户代理(183-8890-9465薇-STS5099】

    华纳圣淘沙官方合作开户渠道(183-8890-9465薇-STS5099】

    华纳圣淘沙公司开户代理服务(183-8890-9465薇-STS5099】

    华纳圣淘沙公司开户咨询热线(183-8890-9465薇-STS5099】

    联系客服了解华纳圣淘沙开户

    (183-8890-9465薇-STS5099】
    华纳圣淘沙公司开户专属顾问

    (183-8890-9465薇-STS5099】

    2025-11-22 回复

人生倒计时

今日已经过去小时
这周已经过去
本月已经过去
今年已经过去个月

标签云

暂无标签

最新回复

  1. 鍗庣撼鍏徃鍚堜綔寮€鎴锋墍闇€鏉愭枡锛熺數璇濆彿鐮?5587291507 寰俊STS5099闲逛
    2025-11-22
  2. 鍗庣撼鍏徃鍚堜綔寮€鎴锋墍闇€鏉愭枡锛熺數璇濆彿鐮?5587291507 寰俊STS5099闲逛
    2025-11-22
  3. 鍗庣撼鍏徃鍚堜綔寮€鎴锋墍闇€鏉愭枡锛熺數璇濆彿鐮?5587291507 寰俊STS5099闲逛
    2025-11-22
  4. 鍗庣撼鍏徃鍚堜綔寮€鎴锋墍闇€鏉愭枡锛熺數璇濆彿鐮?5587291507 寰俊STS5099闲逛
    2025-11-22
  5. 鍗庣撼鍏徃鍚堜綔寮€鎴锋墍闇€鏉愭枡锛熺數璇濆彿鐮?5587291507 寰俊STS5099闲逛
    2025-11-22