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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 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

目录
相关文章
|
2月前
|
运维 Prometheus 监控
如何在测试环境中保持操作系统、浏览器版本和服务器配置的稳定性和一致性?
如何在测试环境中保持操作系统、浏览器版本和服务器配置的稳定性和一致性?
|
16天前
|
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
184 68
(已解决)Linux环境—bash: wget: command not found; Docker pull报错Error response from daemon: Get https://registry-1.docker.io/v2/: net/http: request canceled
|
12天前
|
消息中间件 Java Kafka
【手把手教你Linux环境下快速搭建Kafka集群】内含脚本分发教程,实现一键部署多个Kafka节点
本文介绍了Kafka集群的搭建过程,涵盖从虚拟机安装到集群测试的详细步骤。首先规划了集群架构,包括三台Kafka Broker节点,并说明了分布式环境下的服务进程配置。接着,通过VMware导入模板机并克隆出三台虚拟机(kafka-broker1、kafka-broker2、kafka-broker3),分别设置IP地址和主机名。随后,依次安装JDK、ZooKeeper和Kafka,并配置相应的环境变量与启动脚本,确保各组件能正常运行。最后,通过编写启停脚本简化集群的操作流程,并对集群进行测试,验证其功能完整性。整个过程强调了自动化脚本的应用,提高了部署效率。
【手把手教你Linux环境下快速搭建Kafka集群】内含脚本分发教程,实现一键部署多个Kafka节点
|
9天前
|
Ubuntu Linux Go
golang编译成Linux可运行文件
本文介绍了如何在 Linux 上编译和运行 Golang 程序,涵盖了本地编译和交叉编译的步骤。通过这些步骤,您可以轻松地将 Golang 程序编译成适合 Linux 平台的可执行文件,并在目标服务器上运行。掌握这些技巧,可以提高开发和部署 Golang 应用的效率。
67 14
|
2月前
|
机器学习/深度学习 人工智能 算法
BALROG:基准测试工具,用于评估 LLMs 和 VLMs 在复杂动态环境中的推理能力
BALROG 是一款用于评估大型语言模型(LLMs)和视觉语言模型(VLMs)在复杂动态环境中推理能力的基准测试工具。它通过一系列挑战性的游戏环境,如 NetHack,测试模型的规划、空间推理和探索能力。BALROG 提供了一个开放且细粒度的评估框架,推动了自主代理研究的进展。
46 3
BALROG:基准测试工具,用于评估 LLMs 和 VLMs 在复杂动态环境中的推理能力
|
2月前
|
缓存 Ubuntu Linux
Linux环境下测试服务器的DDR5内存性能
通过使用 `memtester`和 `sysbench`等工具,可以有效地测试Linux环境下服务器的DDR5内存性能。这些工具不仅可以评估内存的读写速度,还可以检测内存中的潜在问题,帮助确保系统的稳定性和性能。通过合理配置和使用这些工具,系统管理员可以深入了解服务器内存的性能状况,为系统优化提供数据支持。
46 4
|
2月前
|
关系型数据库 MySQL Linux
Linux环境下MySQL数据库自动定时备份实践
数据库备份是确保数据安全的重要措施。在Linux环境下,实现MySQL数据库的自动定时备份可以通过多种方式完成。本文将介绍如何使用`cron`定时任务和`mysqldump`工具来实现MySQL数据库的每日自动备份。
140 3
|
19天前
|
监控 JavaScript 测试技术
postman接口测试工具详解
Postman是一个功能强大且易于使用的API测试工具。通过详细的介绍和实际示例,本文展示了Postman在API测试中的各种应用。无论是简单的请求发送,还是复杂的自动化测试和持续集成,Postman都提供了丰富的功能来满足用户的需求。希望本文能帮助您更好地理解和使用Postman,提高API测试的效率和质量。
71 11
|
2月前
|
JSON Java 测试技术
SpringCloud2023实战之接口服务测试工具SpringBootTest
SpringBootTest同时集成了JUnit Jupiter、AssertJ、Hamcrest测试辅助库,使得更容易编写但愿测试代码。
70 3
|
3月前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
84 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)