安装Ubuntu 22.04
安装必要的支持
apt-get update
apt-get install git clang cmake make gcc g++ libmysqlclient-dev libssl-dev libbz2-dev libreadline-dev libncurses-dev libboost-all-dev mysql-server p7zip
update-alternatives --install /usr/bin/cc cc /usr/bin/clang 100
sudo update-alternatives --install /usr/bin/c++ c++ /usr/bin/clang 100
TrinityCore源码目录
mkdir /home/wow/TrinityCore
服务器目录,最终包含etc,bin,data三个子目录
mkdir /home/wow/server3.5.5
客户端目录,后面用于存放客户端版本,提取客户端数据
mkdir /home/wow/client12340
cd ~/
git clone -b 3.3.5 https://github.com/TrinityCore/TrinityCore.git
cd TrinityCore
mkdir build
cd build
cmake ../ -DCMAKE_INSTALL_PREFIX=/home/wow/server3.5.5
本机是4核心
make -j 4
make install
cd /home/wow/server3.5.5/etc
cp authserver.conf.dist authserver.conf
cp worldserver.conf.dist worldserver.conf
修改worldserver.conf 中 DataDir = "." 为 DataDir = "/home/wow/TrinityCore/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
Visual Maps (aka vmaps)
cd /home/wow/client12340
/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/client12340
mkdir mmaps
/home/wow/server3.5.5/bin/mmaps_generator
cp -r mmaps /home/wow/server3.5.5/data
导入数据
cat /etc/mysql/debian.cnf
[client]
host = localhost
user = debian-sys-maint
password = M0l3CXrx8GVNvQcS
socket = /var/run/mysqld/mysqld.sock
[mysql_upgrade]
host = localhost
user = debian-sys-maint
password = M0l3CXrx8GVNvQcS
socket = /var/run/mysqld/mysqld.sock
1、创建数据库
source /home/wow/TrinityCore/sql/create/create_mysql.sql
显示当前数据库系统中所有数据库列表
show databases
+--------------------+
| Database |
+--------------------+
| auth |
| characters |
| information_schema |
| mysql |
| performance_schema |
| world |
+--------------------+
2、建表
use auth;
Source /home/wow/TrinityCore/sql/base/auth_database.sql;
use characters;
Source /home/wow/TrinityCore/sql/base/characters_database.sql;
3、修改ip
use auth;
select id,name,address,localaddress,gamebuild from realmlist;
update realmlist set address='192.168.10.33' where id = 1;
启动服务端
运行 authserver(authserver即认证服务,我们登陆账户都是到这里认证后才会请求worldserver)
/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
如果你按照上述步骤一步一步到了这里,那么运行结果可能提示缺少一个文件
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的提示去下载
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启动成功。
添加账号
创建一个用户名为idc02,密码也为idc02的账号,使用以下命令格式
account create
升级为GM
可以提升idc02的gmlevel为3,升级为GM账号,worldserver命令行输入,如下
TC> account set gmlevel idc02 3 -1
登录游戏
打开客户端目录,找到wow.exe,同级目录下创建wow.bat,内容如下:
在本地搭建ip填写127.0.0.1,外网填写服务器IP,这个ip对应上面realmlist中的address
echo y | rd /s "Cache"
echo SET realmlist "103.219.39." > Data\zhTW\realmlist.wtf
echo SET realmlist "103.219.39." > Data\enTW\realmlist.wtf
echo SET realmlist "103.219.39." > Data\zhCN\realmlist.wtf
echo SET realmlist "103.219.39." > Data\enCN\realmlist.wtf
echo SET realmlist "103.219.39." > Data\enUS\realmlist.wtf
echo SET realmlist "103.219.39." > realmlist.wtf
start Wow.exe
goto end
然后运行脚本,此时初始化客户端连接配置成功,进入游戏。