TrinityCore是模拟魔兽世界(World of Warcraft)的开源项目。
我这里学习搭建环境,基于以下:
下面是我自己用的客户端(12340),对应我自己的服务器。下载就可以直接玩喽!
账号注册: 魔兽世界
关于版本选择3.3.5, 是由于我对这个版本的魔兽世界更加了解,觉得这个版本的魔兽是最好玩的。TrinityCore官方估计也是这么认为的,所以3.3.5这个版本维护的较完善,bug少,是推荐版本。
选择linux来搭建,完全是个人兴趣,这里我用的是Ubuntu。主要目的是入门linux游戏服务器开发。官方也支持 MacOS和Windows,感兴趣的老铁们可以自行查阅以下网站。
官方: https://github.com/TrinityCore/TrinityCore.git
官方wiki: TrinityCore - Confluence
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-dev \ libboost-system-dev \ libboost-filesystem-dev \ libboost-program-options-dev \ libboost-iostreams-dev # 或者 如下 # apt-get install libboost-all-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
这里用root
adduser wow su wow
如果用windows子系统,可以设置默认进入用户
windows进入cmd命令行,执行指令进入Apps目录:
cd %HOMEPATH%\AppData\Local\Microsoft\WindowsApps
因为我安装的debian,所以这个目录下有个ubuntu.exe的文件(如果是debian那么就是debian.exe)
ubuntu.exe config --default-user wow
设置完再进入子系统就是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
cd /home/wow/TrinityCore wget https://github.com/TrinityCore/TrinityCore/archive/refs/tags/TDB335.23061.zip #解压 unzip TDB335.23061.zip
客户端版本:3.3.5(13930 或者12340) 自己想办法下载。魔兽老兵都懂如何下载正确版本。
这里只提供我自己用的一个版本(12340)。解压后讲道理是可以用的。
链接:https://pan.baidu.com/s/1OdxqQDseB3IHwyA9kyotqw?pwd=5h1f
这里用root
环境搭建中我们已经安装mariadb-server数据库(当然也可以使用mysql)。
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)]>
source /home/wow/TrinityCore/TrinityCore-TDB335.23061/sql/create/create_mysql.sql show databases; +--------------------+ | Database | +--------------------+ | auth | | characters | | information_schema | | mysql | | performance_schema | | world | +--------------------+
use auth; source /home/wow/TrinityCore/TrinityCore-TDB335.23061/sql/base/auth_database.sql use characters; source /home/wow/TrinityCore/TrinityCore-TDB335.23061/sql/base/characters_database.sql
这里切回wow
su wow cd /home/wow/TrinityCore/TrinityCore-TDB335.23061 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
注:查看并留意下这三个目录里面的文件,后面会用到。
mkdir /home/wow/server3.5.5/data
把worldserver.conf.dist和authserver.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
运行下面命令,提取客户端数据。这个过程有点慢,请耐心等待。
/home/wow/server3.5.5/bin/mapextractor mkdir /home/wow/server3.5.5/data cp -r dbc maps /home/wow/server3.5.5/data
/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
mkdir mmaps /home/wow/server3.5.5/bin/mmaps_generator cp -r mmaps /home/wow/server3.5.5/data
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,port,address,localaddress,gamebuild from realmlist;
打开客户端目录,找到wow.exe,同级目录下创建init_connect.bat,内容如下。
然后,运行脚本。此时,初始化客户端连接配置成功。
#在本地跑ip用127.0.0.1,这个ip对应上面realmlist中的address 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
/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.
/home/wow/server3.5.5/bin/worldserver好激动。但是。。。
如果你按照上述步骤一步一步到了这里。那么运行结果必然是类似这样的。
不要慌。提示已经再清晰不过了。缺TDB_full_world_335.23061_2023_06_01.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启动成功。
这里我创建了一个用户名为wow1,密码也为wow1的账号,并升级为GM等级
创建一个wow的账号先,worldserver命令行输入,如下
# 这里我们创建了一个用户名为wow1,密码也为wow1的账户 TC> account create wow1 wow1 TC> Account created: wow1
可以提升wow1的gmlevel为3,升级为GM账号,worldserver命令行输入,如下
# 紧接着我们把wow1账户升级为gm TC> account set gmlevel wow1 3 -1 TC> Security level of account WOW1 changed to 3.
windows中找到客户端可执行文件wow.exe,双击运行,打开客户端。
然后输入刚才的账号就可以玩游戏啦~!