Trinitycore学习之在Linux环境上搭建服务器并测试运行

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: Trinitycore学习之在Linux环境上搭建服务器并测试运行

1:准备环境,这里用ubuntu 22.04进行测试,安装环境后为了方便,换源。

注意:这里用的虚拟机,在虚拟机上生成地图信息,地图信息占用内存比较大,我暂时设置磁盘50G进行测试,后面研究细节。

ubuntu@ubuntu:~/res$ lsb_release -a
No LSB modules are available.
Distributor ID: Ubuntu
Description:  Ubuntu 22.04.3 LTS
Release:  22.04
Codename: jammy

2:参考文档了解:

https://trinitycore.info/en/install/requirements/linux

https://trinitycore.info/en/install/requirements/windows

3:开始安装环境-安装必备依赖

sudo apt-get update
sudo apt-get install git clang cmake make gcc g++ libmysqlclient-dev libssl-dev libbz2-dev libreadline-dev libncurses-dev libboost-all-dev mysql-server-5.7 p7zip
# 这里mysql-server-5.7 版本没有  我这里安装好mysql-server-8.0
sudo update-alternatives --install /usr/bin/cc cc /usr/bin/clang 100
sudo update-alternatives --install /usr/bin/c++ c++ /usr/bin/clang 100

4:开始安装

mkdir game
cd game
git clone -b 3.3.5 https://github.com/TrinityCore/TrinityCore.git
mkdir build
cd build
cmake ../ -DCMAKE_INSTALL_PREFIX=/home/ubuntu/game -DCONF_DIR=/home/ubuntu/game/bin
make -j2
make install
#这里完了之后  会在/home/ubuntu/game/bin 目录中生成相关可执行文件,以及配置文件也在这
ubuntu@ubuntu:~/game/bin$ pwd
/home/ubuntu/game/bin
ubuntu@ubuntu:~/game/bin$ ll
total 274160
drwxrwxr-x 2 ubuntu ubuntu      4096 Sep  9 16:38 ./
drwxrwxr-x 5 ubuntu ubuntu      4096 Sep  9 17:22 ../
-rwxr-xr-x 1 ubuntu ubuntu  16259744 Sep  9 16:28 authserver*
-rw-r--r-- 1 ubuntu ubuntu     13897 Sep  9 16:10 authserver.conf.dist
-rwxr-xr-x 1 ubuntu ubuntu   2810696 Sep  9 16:27 mapextractor*
-rwxr-xr-x 1 ubuntu ubuntu  14319552 Sep  9 16:27 mmaps_generator*
-rwxr-xr-x 1 ubuntu ubuntu   7811168 Sep  9 16:26 vmap4assembler*
-rwxr-xr-x 1 ubuntu ubuntu   6700944 Sep  9 16:27 vmap4extractor*
-rwxr-xr-x 1 ubuntu ubuntu 232656040 Sep  9 16:37 worldserver*
-rw-r--r-- 1 ubuntu ubuntu    140889 Sep  9 16:10 worldserver.conf.dist
#这里的文件  除了配置文件   就是生成地图的工具 以及启动游戏可执行文件
#authserver是认证服务,worldserver是世界服务也就是游戏的核心服

5:生成地图

上面已经编译出处理地图数据的可执行文件 mapextractor, vmap4extractor,vmap4assembler, mmaps_generator,执行后生成其他一些目录或者文件,是服务器需要的地图信息。

#1:首先从客户端中 把客户端安装目录下 Data和Interface 目录,拷贝到服务器上 这里拷贝到/home/ubuntu/res目录下 (这里的客户端自行下载 启动点击wow.exe)
#2:处理地图的可执行文件  在/home/ubuntu/game/bin目录中
#3:在地图文件所在目录res目录下执行相关可执行文件,这里要用到Data和Interface 中数据,并且好大,快20G:
../game/bin/mapextractor 
../game/bin/vmap4extractor 
../game/bin/vmap4assembler 
../game/bin/mmaps_generator 
#如果运行没有问题  生成如下相关文件:
#这里的执行比较耗时,一到两个小时,以及这里需要的内存比较大,自己在虚拟机进行测试时,反复测试几次。
ubuntu@ubuntu:~/res$ ll
total 1168
drwx--x--x  2 ubuntu ubuntu 311296 Sep  9 18:02 Buildings/
drwxrwxr-x  2 ubuntu ubuntu   4096 Sep  9 17:56 Cameras/
drwxrwxr-x  3 ubuntu ubuntu   4096 Sep  9 17:53 Data/       #主要地图数据 从客户端拷贝而来
drwxrwxr-x  2 ubuntu ubuntu  12288 Sep  9 17:56 dbc/
drwxrwxr-x  3 ubuntu ubuntu   4096 Sep  9 17:47 Interface/   #从客户端拷贝而来
drwxrwxr-x  2 ubuntu ubuntu 159744 Sep  9 17:58 maps/
drwxrwxr-x  2 ubuntu ubuntu 135168 Sep 10 03:11 mmaps/
drwxrwxr-x  2 ubuntu ubuntu 552960 Sep  9 18:05 vmaps/
#4:登录mysql,导入数据库,
#   首先处理安装后设置mysql密码问题,不是本次核心。
#   简单重设mysql密码: sudo mysqladmin -u root -p password
#   导入对应的数据 在TrinityCore源码目录下/sql/create/ 
#   可以查看数据库 生成的表 后续待了解相关结构
sudo mysql -uroot -p123456
mysql> source /home/ubuntu/game/TrinityCore/sql/create/create_mysql.sql
#5:修改realmlist表中address 信息为本机ip地址。
select * from realmlist;
select * from realmlist\G  #纵向显示
update realmlist set address="192.168.40.130" where id = 1; #修改ip

注意:这里地图数据特别大,大约20G,比较耗费内存,这里我用虚拟机测试时,直接设置比较大的内存进行解决。

同时,df -h查看内存情况,参考https://zhuanlan.zhihu.com/p/359959580 可以实现磁盘内存扩展

6:开始运行

./worldserver   #运行服务器
./authserver    #运行认证服务器
#第一次启动时与相关报错
ubuntu@ubuntu:~/game/bin$ ./worldserver
TrinityCore rev. 79e2f77d4403 2023-09-01 12:15:17 +0200 (3.3.5 branch) (Unix, RelWithDebInfo, Static) (worldserver-daemon)
.....
File "TDB_full_world_335.23061_2023_06_14.sql" is missing, download it from "https://github.com/TrinityCore/TrinityCore/releases" uncompress it and place the file "TDB_full_world_335.23061_2023_06_14.sql" in the directory "/home/ubuntu/game/bin".
Could not populate the World database, see log for details.
#按照提示进行处理 去https://github.com/TrinityCore/TrinityCore/releases 找到335.23061对应版本中
#下载对应de.7z 压缩包,用7zip进行解压后,获取到一个sql文件。
#把解压后的sql脚本拷贝到 worldserver 同级目录
TDB_full_world_335.23061_2023_06_14.sql
ubuntu@ubuntu:~/game/bin$ pwd
/home/ubuntu/game/bin
ubuntu@ubuntu:~/game/bin$ ls
Auth.log         authserver.conf.dist  mapextractor     TDB_full_world_335.23061_2023_06_14.sql  worldserver
authserver       DBErrors.log          mmaps_generator  vmap4assembler                           worldserver.conf
authserver.conf  GM.log                Server.log       vmap4extractor                           worldserver.conf.dist
# 把该目录下的配置文件进行处理
cp authserver.conf.dist authserver.conf
cp worldserver.conf.dist worldserver.conf
#修改配置文件  在配置文件中设置地图信息位置   DataDir = "../../res"
vi worldserver.conf
#最终,分别启动真正服务器和认证服务器

7:测试运行

#启动./worldserver  后,设置一个用户名和密码,在客户端进行测试
TC> account create test1 1234
TC> Account created: test1
#在客户端,逍遥魔兽登录器.bat 脚本中,修改对应的服务端ip地址 这里改为对应的服务器ip 对应上面修改的数据库内部地址
if not exist "WTF" md "WTF"
 echo set realmlist 192.168.40.132>realmlist.WTF
 echo set realmlist 192.168.40.132>data/enGB/realmlist.WTF
 echo set realmlist 192.168.40.132>data/zhcn/realmlist.WTF
 start wow.exe
 goto end
 #启动该bat脚本,输入上面的用户名和密码  测试ok

太多的技术栈来源于零声学院,上班之余,又报了个游戏的课外进修,做此整理。

推荐:https://xxetb.xet.tech/s/2W52YR

目录
相关文章
|
1天前
|
Ubuntu Linux Shell
(已解决)Linux环境—bash: wget: command not found; Docker pull报错Error response from daemon: Get https://registry-1.docker.io/v2/: net/http: request canceled
(已成功解决)Linux环境报错—bash: wget: command not found;常见Linux发行版本,Linux中yum、rpm、apt-get、wget的区别;Docker pull报错Error response from daemon: Get https://registry-1.docker.io/v2/: net/http: request canceled
|
22天前
|
机器学习/深度学习 人工智能 算法
BALROG:基准测试工具,用于评估 LLMs 和 VLMs 在复杂动态环境中的推理能力
BALROG 是一款用于评估大型语言模型(LLMs)和视觉语言模型(VLMs)在复杂动态环境中推理能力的基准测试工具。它通过一系列挑战性的游戏环境,如 NetHack,测试模型的规划、空间推理和探索能力。BALROG 提供了一个开放且细粒度的评估框架,推动了自主代理研究的进展。
31 3
BALROG:基准测试工具,用于评估 LLMs 和 VLMs 在复杂动态环境中的推理能力
|
26天前
|
弹性计算 监控 容灾
阿里云ECS提供强大的云上灾备解决方案,通过高可用基础设施、多样的数据备份方式及异地灾备服务,帮助企业实现业务的持续稳定运行
在数字化时代,企业对信息技术的依赖加深,确保业务连续性至关重要。阿里云ECS提供强大的云上灾备解决方案,通过高可用基础设施、多样的数据备份方式及异地灾备服务,帮助企业实现业务的持续稳定运行。无论是小型企业还是大型企业,都能从中受益,确保在面对各种风险时保持业务稳定。
42 4
|
28天前
|
缓存 Ubuntu Linux
Linux环境下测试服务器的DDR5内存性能
通过使用 `memtester`和 `sysbench`等工具,可以有效地测试Linux环境下服务器的DDR5内存性能。这些工具不仅可以评估内存的读写速度,还可以检测内存中的潜在问题,帮助确保系统的稳定性和性能。通过合理配置和使用这些工具,系统管理员可以深入了解服务器内存的性能状况,为系统优化提供数据支持。
34 4
|
1月前
|
NoSQL Linux PHP
如何在不同操作系统上安装 Redis 服务器,包括 Linux 和 Windows 的具体步骤
本文介绍了如何在不同操作系统上安装 Redis 服务器,包括 Linux 和 Windows 的具体步骤。接着,对比了两种常用的 PHP Redis 客户端扩展:PhpRedis 和 Predis,详细说明了它们的安装方法及优缺点。最后,提供了使用 PhpRedis 和 Predis 在 PHP 中连接 Redis 服务器及进行字符串、列表、集合和哈希等数据类型的基本操作示例。
58 4
|
1月前
|
运维 监控 安全
盘点Linux服务器运维管理面板
随着云计算和大数据技术的迅猛发展,Linux服务器在运维管理中扮演着越来越重要的角色。传统的Linux服务器管理方式已经无法满足现代企业的需求,因此,高效、安全、易用的运维管理面板应运而生。
|
29天前
|
运维 监控 Linux
服务器管理面板大盘点: 8款开源面板助你轻松管理Linux服务器
在数字化时代,服务器作为数据存储和计算的核心设备,其管理效率与安全性直接关系到业务的稳定性和可持续发展。随着技术的不断进步,开源社区涌现出众多服务器管理面板,这些工具以其强大的功能、灵活的配置和友好的用户界面,极大地简化了Linux服务器的管理工作。本文将详细介绍8款开源的服务器管理面板,包括Websoft9、宝塔、cPanel、1Panel等,旨在帮助运维人员更好地选择和使用这些工具,提升服务器管理效率。
|
1月前
|
关系型数据库 MySQL Linux
Linux环境下MySQL数据库自动定时备份实践
数据库备份是确保数据安全的重要措施。在Linux环境下,实现MySQL数据库的自动定时备份可以通过多种方式完成。本文将介绍如何使用`cron`定时任务和`mysqldump`工具来实现MySQL数据库的每日自动备份。
95 3
|
16天前
|
存储 Oracle 安全
服务器数据恢复—LINUX系统删除/格式化的数据恢复流程
Linux操作系统是世界上流行的操作系统之一,被广泛用于服务器、个人电脑、移动设备和嵌入式系统。Linux系统下数据被误删除或者误格式化的问题非常普遍。下面北亚企安数据恢复工程师简单聊一下基于linux的文件系统(EXT2/EXT3/EXT4/Reiserfs/Xfs) 下删除或者格式化的数据恢复流程和可行性。
|
27天前
|
安全 Linux API
Linux服务器安全
人们常误认为服务器因存于数据中心且数据持续使用而无需加密。然而,当驱动器需维修或处理时,加密显得尤为重要,以防止数据泄露。Linux虽有dm-crypt和LUKS等内置加密技术,但在集中管理、根卷加密及合规性等方面仍存不足。企业应选择具备强大验证、简单加密擦除及集中管理等功能的解决方案,以弥补这些缺口。
24 0
下一篇
DataWorks