游戏服务器研究一:bigworld 开源代码的编译与运行

1. 前言

bigworld 已经开源了它的代码,而我对于大世界的 scale 很感兴趣,所以就尝试把代码跑起来研究。但是,整个过程比我原先预想的复杂得多。

虽然能找到一些官方的帮助文档,但这些文档要么过旧,要么过于详尽,并且写的大多是一些自动化的操作,依赖的工具链很多,所以对于手动搭建没啥帮助,反而带来了不少困惑。

而网上,搜索不到其他人写的关于 bigworld 搭建的文章,所以只能结合官方文档一步步试探。整个安装过程,最 easy 的 part 是安装环境&编译,最烦的 part 是把 server 和 client 运行起来。

本(水)文只包含以下粗浅的内容:

1、编译 server & client。

2、运行 server & client,把 fantasydemo 跑起来。

fantasydemo 是官方自带的一个 demo,包含了 server 跟 client,算是一个可以运行的 mmo 游戏吧。

国内的公司像网易,巨人等,都有引进过 bigworld,应该很熟悉 bigworld 整套框架的搭建,所以相关厉害人士完全可以不用看本(水)文。


2. bigworld 源码下载

有几个版本,最新的是 14.4.1,更早的有 2.0.1,1.9.1。

本文是基于 bigworld-14.4.1 搭建的,而文档是参考 bigworld-2.0.1 的,因为 14.4.1 里面几乎没啥文档。

2.1 bigworld-14.4.1

完整版(源码+资源): https://sourceforge.net/p/bigworld/code/HEAD/tree/ 或者 https://drive.google.com/file/d/1hLm_Ox0v-xIen8c4MvwRHQhkutf9bIpK/view?usp=share_link

源码版: https://github.com/v2v3v4/BigWorld-Engine-14.4.1

2.2 bigworld-2.0.1

完整版(源码+资源): https://drive.google.com/file/d/1b1ZGpVFE2hMoDNC-mGQ4ldwgF8PWH3n7/view?usp=share_link

源码版: https://github.com/v2v3v4/BigWorld-Engine-2.0.1

2.3 bigworld-1.9.1

源码版: https://github.com/v2v3v4/BigWorld-Engine-1.9.1


3. wsl2 编译 server

3.1 wsl2 安装 centos7

官方的文档里说,bigworld 支持的操作系统是 redhat,centos,fedora,而我熟悉 centos,所以用 centos7,并且我也熟悉 wsl,所以用 wsl2。反正,用自己熟悉的方式即可。

仓库所在地址: https://github.com/mishamosher/CentOS-WSL

1、下载

一个发行版,比如 centos7: https://github.com/mishamosher/CentOS-WSL/releases/tag/7.9-2211

2、安装

解压后双击 CentOS7.exe

3、运行

双击 CentOS7.exe 启动即可,后续这个 CentOS7 也会出现在 WindowsTerminal 里面,可以直接运行。


3.2 centos7 创建一个用户

1、创建用户

bash 复制代码
useradd -m -d /home/ant -G adm -s /bin/bash ant

2、创建密码

bash 复制代码
passwd ant

3、修改 sudoer

1)如果当前不是 root 用户,su 到 root 用户

2)运行 visudo 命令,进入编辑界面

3)在 root ALL=(ALL) ALL 的下面加一行 ant ALL=(ALL) ALL

4)保存退出


3.3 wsl2 修改 centos7 的默认用户

为什么?如果没修改,每次进入 centos7 都是 root 用户。

1、以管理员身份运行 windows power shell ,cd 到解压出来的 CentOS7.exe 的所在目录,执行命令

CentOS7.exe config --default-user ant

3.4 centos7 安装依赖的软件

1、以 root 用户运行,或用 sudo 运行

bash 复制代码
yum install epel-release
yum install git
yum install vim
yum install make
yum install gcc
yum install gcc-c++
yum install patch
yum install python-pip
yum install wget
yum install unzip
yum install bzip2
yum install MySQL-python
yum install python-setuptools
yum install python-sqlobject
yum install TurboGears
yum install rpm-build

2、说明

1)EPEL (Extra Packages for Enterprise Linux) 是基于 Fedora 的一个项目,为"红帽系"的操作系统提供额外的软件包,适用于 RHEL、CentOS 和 Scientific Linux。


3.5 centos7 安装 scons

下面在编译 mongo_cxx_driver 的时候会用到 scons,需要提前安装,这个有好几种安装方法,但在 CentOS7 没法使用 python 的 pip 安装,只能从源码安装。

1、scons 官网: https://scons.org/pages/download.html

2、下载 scons-2.5.1.tar.gz,地址: https://sourceforge.net/projects/scons/files/scons/2.5.1/

3、解压后,进入 scons-2.5.1 目录,执行 sudo python setup.py install


3.6 手动编译一些需要的库

1、安装 boost

1)进入 programming\bigworld\third_party\mongodb\boost

2)根据 README.BigWorld 编译 boost

2、安装 mongo_cxx_client

1)进入 programming\bigworld\third_party\mongodb\mongo_cxx_driver

2)根据 README.BigWorld 编译 mongo_cxx_driver

3、出错处理

1) 使用 scons 编译&链接 mongo_cxx_driver 会总是报错,虽然已经正确指定了 boost 的 cpppath 和 libpath。一个 trick 就是根据报错,自己手动去拷贝文件到它的编译命令报错的目录。编译时报错就看看 -I 是指定哪些目录的,把 boost 拷贝过去。链接时报错就看看 -L 是指定哪些目录的,把 boost 的 lib 拷贝过去。


3.7 编译 server

1、进入 programming/bigworld,执行 make

2、报错解决

1)比如一开始 platform_info.py 的报错,是因为它没执行权限,则 chmod 755 platform_info.py 即可,后续还会有其他的 bash 文件执行失败,也是 chmod 即可。


4. windows 编译 client

4.1 安装 visual studio 2019 或其他版本(可选)

可以等下面 cmake 生成 sln 的时候再判断是否需要安装 vs。

我本机安装了很多个 vs,有 vs2010,vs2013,vs2015,vs2017,vs2019,vs2022,但下面运行 bigworld_cmake.bat 的时候,只给了两个选项: vs2019 和 vs2022,所以我也不确定具体需要先安装哪个。


4.2 编译 client

1、生成 vs 的 sln 文件

进入 programming\bigworld\build,运行 bigworld_cmake.bat,选择 3,再选择相应的 visual studio (比如我选了 visual studio 2019)。

生成成功会显示 sln 生成到了什么目录,比如我是生成到 programming\build_client_vc16_win32

2、运行 vs 编译

用 vs (比如我是 vs 2019)打开上面生成的 sln 文件,选择 Consumer_Release 进行生成,(这里就不使用 Debug 版本了)。

编译成功后,文件会生成到 game\bin\client\win32 目录。

3、报错解决

1)提示 "无法找到 v141_xp 的生成工具",则打开 visual studio installer,安装这个组件 "对 C++的 Windows XP 支持"

2)提示找不到 atl 开头的头文件,则 visual studio installer 安装 atl

3)提示找不到 afx 开头的头文件,则 visual studio installer 安装 mfc


5. wsl 安装&运行 server

5.1 安装 mysql 并创建 bigworld 数据库&账号

1、安装 mysql

我是使用 docker compose 的,因为自己很熟悉,所以比较快。唯一的问题就是最近(2024-6-15 号之后) docker 官方 hub pull 不动了,得找国内的 hub,比较折腾。

反正用自己熟悉的方式即可。

2、创建数据库&账号

CREATE DATABASE IF NOT EXISTS bigworld DEFAULT CHARSET utf8mb4 COLLATE utf8mb4_general_ci;


create user 'bigworld'@'localhost' identified by 'bigworld';
grant all privileges on *.* to 'bigworld'@'localhost';
create user 'bigworld'@'%' identified by 'bigworld';
grant all privileges on *.* to 'bigworld'@'%';
flush privileges;

5.2 修改 res 目录的数据库配置

1、打开文件 game\res\bigworld\server\production_defaults.xml,搜索到 mysql,

配置相关信息,比如我配置完是这样的:

...
		<mysql>
			<host> 127.0.0.1 </host> <!-- Type: String -->
			<port> 3306 </port> <!-- Type: Integer -->
			<databaseName> bigworld </databaseName> <!-- Type: String -->
			<username> bigworld </username> <!-- Type: String -->
			<password> bigworld </password> <!-- Type: String -->
			...
		</mysql>
...

2、说明

1)有个特别注意一下,在 wsl2 里面用 docker 跑 mysql,使用 localhost 是连不上 mysql 的,要用 127.0.0.1 。


5.3 安装 bwmachined

1、把编译出来的 bwmachined2 拷贝到正确位置

(以下都用的我机器上的绝对路径,具体视自己的情况而定)

bash 复制代码
cp /home/ant/bigworld/game/bin/server/el7/tools/bwmachined2 /home/ant/bigworld/game/tools/bigworld/server/bin/Hybrid64

2、安装

bash 复制代码
cd /home/ant/bigworld/game/tools/bigworld/server/install
sudo ./bwmachined2.sh install

3、运行或查看状态

bash 复制代码
sudo service bwmachined2 start
sudo service bwmachined2 status

4、平常如果没有开机自己运行,就自己运行

bash 复制代码
sudo service bwmachined2 start

5.4 创建一个目录存放 server 运行文件

(这一步看起来有点多余,但是如果不做,bwmachined2 可能会运行异常)

1、创建目录

bash 复制代码
mkdir -p ~/mf/bigworld/server/bin

2、拷贝文件

bash 复制代码
cp -R game/bin/server/el7/server/* ~/mf/bigworld/bin/server/

5.5 创建 ~/.bwmachined.conf 文件

1、在当前用户的 home 目录 (~/) 下创建一个名为 .bwmachined.conf 的文本文件,要注意,文件名是以 . 号开头,内容如下:

/home/ant/mf/bigworld;/home/ant/bigworld2014/game/res/bigworld:/home/ant/bigworld2014/game/res/fantasydemo

[Components]
cellApp
baseApp
serviceApp
dbApp
cellAppMgr
baseAppMgr
dbAppMgr
loginApp
bots

[Groups]
dev

[TimingMethod]
gettime

#[architecture]
#32

#[InternalInterface]
#eth0

#[MaxPacketDelay]
#100

2、说明

1)在官方的 install 文档里会说使用 bw_configure 脚本来创建这个文件,但会各种报错,根本搞不了,还不如手动创建。

2)此文件有个范本在此 game\tools\bigworld\server\rpm\bwmachined\bwmachined.conf,里面有注释说明,具体可参考。

3)要点

文件的第一行分两部分,第一部分是 bigworld 的 server 可执行文件的目录,第二部分是 res 目录。

第一、二部分之间使用 ; 号隔开。

第二部分的 res 之间使用 : 号 隔开。

第一部分的目录有这样的存放要求,比如我这是这样的:

~/mf/bigworld/bin/server

server 目录就放编译出来的服务器二进制文件,baseapp, cellapp, baseappmgr ... 这些

4)install 文档会有一点误导性,它里面说 .bwmachined.conf 的第一行是 UID;MF_ROOT;MF_RES,实践证明,并不是的,参照上面说的搞即可。


5.6 运行 server

(说明:server 的运行不需要什么参数,它是读取 ~/.bwmachined.conf 文件去加载相应的东西的)

1、进入 server 的目录 game/bin/server/el7/server

2、现写两个脚本负责启动和关闭 server

start-all-server.sh

bash 复制代码
#!/bin/bash

nohup ./baseapp > baseapp.log 2>&1 &
nohup ./baseappmgr > baseappmgr.log 2>&1 &
nohup ./cellapp > cellapp.log 2>&1 &
nohup ./cellappmgr > cellappmgr.log 2>&1 &
nohup ./dbapp > dbapp.log 2>&1 &
nohup ./dbappmgr > dbappmgr.log 2>&1 &
nohup ./loginapp > loginapp.log 2>&1 &
nohup ./serviceapp > serviceapp.log 2>&1 &

stop-all-server.sh

bash 复制代码
#!/bin/bash

pkill baseapp
pkill baseappmgr
pkill dbapp
pkill dbappmgr
pkill cellapp
pkill cellappmgr
pkill loginapp
pkill -9 serviceapp

3、运行 start-all-server.sh 启动服务器


6. windows 运行 client

6.1 修改 fantasydemo 的连接地址

1、client 修改 game\res\fantasydemo\scripts_config.xml,搜索到 <login>,把其中的 host 改为 loginapp 的地址和端口,我的是 wsl 地址是 172.22.36.110,而 loginapp 的默认登录端口是 20013。

所以,我的改完是这样:

...
	<login>
	<!-- This login data is used by the scripts to connect to the server. -->

		<host> 172.22.36.110:20013 </host>
...

6.2 创建一个运行 client 的脚本

1、在 game 目录创建一个名为 run-client.bat 的脚本,脚本内容如下:

@ECHO OFF

start bin\client\win32\bwclient.exe --res %~dp0\res\fantasydemo;%~dp0\res\bigworld

2、说明

1)关键之处在于 --res 参数,要先指定 fantasydemo,再指定 bigworld 。

2)上面 %~dp0 表示当前目录,用的是相对路径,也可以改成绝对路径。比如这样:

@ECHO OFF

start bin\client\win32\bwclient.exe --res D:\code\game-src\bigworld\bigworld2014-git-repo\game\res\fantasydemo;D:\code\game-src\bigworld\bigworld2014-git-repo\game\res\bigworld

6.3 运行 client

1、执行上面的 run-client.bat 就跑起来了

2、选择 "Connect to Standard Server",就看到之前配置的自己的服务器地址了

3、创建游戏账号

4、选择一个区

5、创建区账号

6、进入游戏


正文完。

相关推荐
Zfox_2 分钟前
【MySQL】内置函数+复合查询+内外连接
服务器·数据库·mysql
云云32116 分钟前
云手机:Facebook多账号管理的创新解决方案
服务器·线性代数·安全·智能手机·架构·facebook
上海运维Q先生1 小时前
面试题整理17----K8s中request和limit资源限制是如何实现的
服务器·云原生·kubernetes
码农君莫笑2 小时前
《信管通低代码信息管理系统开发平台》Windows环境安装说明
服务器·数据库·windows·低代码·c#·bootstrap·.netcore
fnd_LN2 小时前
Linux文件目录 --- mkdir命令,创建目录,多级目录,设置目录权限
linux·运维·服务器
InSighT__3 小时前
设计模式与游戏完美开发(2)
java·游戏·设计模式
IPdodo全球网络服务4 小时前
如何通过TikTok引流到私域流量池
运维·服务器·网络
Camllia374 小时前
《CS2》报错dxgi.dll缺失怎么办?《CS2》游戏提示dxgi.dll缺失要怎么解决?
游戏
开疆智能5 小时前
ModbusTCP转Profinet:工业通信的利器
linux·服务器·网络
彩虹糖_haha5 小时前
Linux高并发服务器开发 第六天(rwx 对于目录和文件的区别 gcc编译器 动态库静态库)
linux·运维·服务器