TrinityCore多区realms配置-do multiple realms for TrinityCore

打印 上一主题 下一主题

主题 582|帖子 582|积分 1746

TrinityCore是支持多区配置的,即多个realm分区。只必要起一套authserver服务,负责全部区的登录。必要在mysql的auth库中到场其它realm的配置信息,如:
  1. +----+----------+-----------------+--------------+-----------------+------+------+------+----------+----------------------+------------+-----------+
  2. |  1 | Trinity  | 114.115.136.249 | 127.0.0.1    | 255.255.255.0   | 8085 |    0 |    0 |       16 |                    0 |          0 |     12340 |
  3. |  2 | NewRealm | 114.115.136.249 | 127.0.0.1    | 255.255.255.0   | 8086 |    0 |    2 |       16 |                    0 |          0 |     12340 |
  4. +----+----------+-----------------+--------------+-----------------+------+------+------+----------+----------------------+------------+-----------+
复制代码
其它realms区只必要启动worldserver服务,不必要再启动authserver服务。worldserver.conf配置文件里必要mysql指向authserver的ip,如:LoginDatabaseInfo     = "192.168.1.2;3306;trinity;trinity;auth" 。这里的192.168.1.2是authserver服务器的ip地点,也就是mysql的auth库是调用的authserver的内容,而character和world数据库,照旧用各个realms当地的。
TrinityCore安装文档:TrinityCore安装记录_ubuntu 魔兽天下-CSDN博客
mysql打开网络服务文档:如安在python里登录测试mysql数据库-CSDN博客
尝试TrinityCore多区配置

  1. # 进入wow用户
  2. su - wow
  3. # 进入mysql控制台
  4. sudo mysql
复制代码
添加一条新区数据到realmlist

默认只有id 1,后来加了id 2 和6 两条。
  1. mysql> insert into realmlist (name) values("test") ;
  2. Query OK, 1 row affected (0.01 sec)
  3. mysql> select * from realmlist;
  4. +----+----------+-----------------+--------------+-----------------+------+------+------+----------+----------------------+------------+-----------+
  5. | id | name     | address         | localAddress | localSubnetMask | port | icon | flag | timezone | allowedSecurityLevel | population | gamebuild |
  6. +----+----------+-----------------+--------------+-----------------+------+------+------+----------+----------------------+------------+-----------+
  7. |  1 | Trinity  | 114.115.136.249 | 127.0.0.1    | 255.255.255.0   | 8085 |    0 |    0 |        1 |                    0 |          0 |     12340 |
  8. |  2 | NewRealm | 192.168.1.12    | 127.0.0.1    | 255.255.255.0   | 8085 |    0 |    0 |        1 |                    0 |          0 |     12340 |
  9. |  6 | test     | 127.0.0.1       | 127.0.0.1    | 255.255.255.0   | 8085 |    0 |    2 |        0 |                    0 |          0 |     12340 |
  10. +----+----------+-----------------+--------------+-----------------+------+------+------+----------+----------------------+------------+-----------+
  11. 3 rows in set (0.00 sec)
复制代码

修改realm把realm id由3改为2

首先看一下:
mysql> use auth;
mysql> select id,name,address,localaddress,gamebuild from realmlist;
+----+----------+-----------------+--------------+-----------+
| id | name     | address         | localaddress | gamebuild |
+----+----------+-----------------+--------------+-----------+
|  1 | Trinity  | 114.115.136.249 | 192.168.0.12 |     12340 |
|  3 | NewRealm | 192.168.1.12    | 192.168.1.12 |     12345 |
+----+----------+-----------------+--------------+-----------+
2 rows in set (0.00 sec)

把realm名字改成:NewRealm 。固然可以改成自己喜欢的名字。
刚开始拿到的id是3,把RealmID 从3改成2:
  1. mysql> update realmlist set id="2" where id="3";
  2. Query OK, 1 row affected (0.01 sec)
  3. Rows matched: 1  Changed: 1  Warnings: 0
复制代码
worldserver.conf文件中修改

修改realm2区服务器的server/etc/worldserver.conf文件,把原文件中RealmID = 1 改为RealmID = 2
同样在authserver.conf文件中必要写
当时是这样的:
  1. mysql> use auth;
  2. Reading table information for completion of table and column names
  3. You can turn off this feature to get a quicker startup with -A
  4. Database changed
  5. mysql> select * from realmlist;
  6. +----+----------+-----------------+--------------+-----------------+------+------+------+----------+----------------------+------------+-----------+
  7. | id | name     | address         | localAddress | localSubnetMask | port | icon | flag | timezone | allowedSecurityLevel | population | gamebuild |
  8. +----+----------+-----------------+--------------+-----------------+------+------+------+----------+----------------------+------------+-----------+
  9. |  1 | Trinity  | 114.115.136.249 | 192.168.0.12 | 255.255.255.0   | 8085 |    0 |    0 |        1 |                    0 |          0 |     12340 |
  10. |  3 | NewRealm | 192.168.1.12    | 192.168.1.12 | 255.255.255.0   | 8085 |    0 |    0 |        0 |                    0 |          0 |     12345 |
  11. +----+----------+-----------------+--------------+-----------------+------+------+------+----------+----------------------+------------+-----------+
  12. 2 rows in set (0.00 sec)
复制代码

修改时区到16

  1. timezone        displayed name                timezone        displayed name
  2. 1        Development                20        CN4
  3. 2        United States                21        CN5
  4. 3        Oceanic                22        CN6
  5. 4        Latin America                23        CN7
  6. 5        Tournament                24        CN8
  7. 6        Korea                25        Tournament
  8. 7        Tournament                26        Test Server
  9. 8        English                27        Tournament
  10. 9        German                28        QA Server
  11. 10        French                29        CN9
  12. 11        Spanish                30        Test Server 2
  13. 12        Russian                31        CN10
  14. 13        Tournament                32        CTC
  15. 14        Taiwan                33        CNC
  16. 15        Tournament                34        CN1/4
  17. 16        China                35        CN2/6/9
  18. 17        CN1                36        CN3/7
  19. 18        CN2                37        CN5/8
  20. 19        CN3                       
复制代码
把时区修改成16 中国
  1. mysql> UPDATE realmlist SET timezone='16' WHERE id =3 ;
  2. Query OK, 1 row affected (0.03 sec)
  3. Rows matched: 1  Changed: 1  Warnings: 0
  4. mysql> UPDATE realmlist SET timezone='16' WHERE id =1 ;
  5. Query OK, 1 row affected (0.02 sec)
  6. Rows matched: 1  Changed: 1  Warnings: 0
  7. mysql> select * from realmlist;
  8. +----+----------+-----------------+--------------+-----------------+------+------+------+----------+----------------------+------------+-----------+
  9. | id | name     | address         | localAddress | localSubnetMask | port | icon | flag | timezone | allowedSecurityLevel | population | gamebuild |
  10. +----+----------+-----------------+--------------+-----------------+------+------+------+----------+----------------------+------------+-----------+
  11. |  1 | Trinity  | 114.115.136.249 | 192.168.0.12 | 255.255.255.0   | 8085 |    0 |    0 |       16 |                    0 |          0 |     12340 |
  12. |  3 | NewRealm | 192.168.1.12    | 192.168.1.12 | 255.255.255.0   | 8085 |    0 |    0 |       16 |                    0 |          0 |     12345 |
  13. +----+----------+-----------------+--------------+-----------------+------+------+------+----------+----------------------+------------+-----------+
  14. 2 rows in set (0.01 sec)
复制代码
但是现在登录到192.168.0.12,照旧看不到多区。

现在总结一下,必要id 修改一下,比如把id改成2 ,同时worldserver.conf 文件里的 realmID 也设置为2 
同时localAddress 不能用当地ip地点,如192.168.0.12 ,因为这样远端(通过公网)就无法连上服务器了。
解决看不到TrinityCore多区的题目

原来是版本的题目,以前用的版本是12340,后来编译的时间可能拿到的是12345,就是版本不一致导致客户端不停没有瞥见新区
  1. mysql> update realmlist set gamebuild="12340" where id="2";
复制代码
  1. +----+----------+-----------------+--------------+-----------------+------+------+------+----------+----------------------+------------+-----------+
  2. |  1 | Trinity  | 114.115.136.249 | 127.0.0.1 | 255.255.255.0   | 8085 |    0 |    0 |       16 |                    0 |          0 |     12340 |
  3. |  2 | NewRealm | 192.168.1.12    | 127.0.0.1 | 255.255.255.0   | 8085 |    0 |    0 |       16 |                    0 |          0 |     12340 |
  4. +----+----------+-----------------+--------------+-----------------+------+------
复制代码

将RealmID改成1和2,将版本号都改成12340,现在终于能看到两个区了。
现在的题目是,假如账户登录的是1号realm(192.168.0.12),能瞥见两个区,但是只能登录1号区,登录2号区提示auth认证失败,进不去瞥见账户那里。
假如帐号登录的就是2号realm(192.168.1.12),那么登录1号区会失败,2号可以登录。
也就是无法1号和2号两个区同时登录乐成。
核心:解决全网可通mysql auth数据库的题目

现在的核心就是要设置一个公用的mysql的auth库,并保证可以通过网络能连上这个库。
决定利用192.168.0.12为公用auth库,realm1 和realm2都指向这台服务器的mysql数据库。为了可以或许外网访问mysql,增加了一个host为%的语句:
  1. mysql> use mysql
  2. Reading table information for completion of table and column names
  3. You can turn off this feature to get a quicker startup with -A
  4. Database changed
  5. mysql> update auth set host = '%' where user = 'trinity';
  6. ERROR 1146 (42S02): Table 'mysql.auth' doesn't exist
  7. mysql> update user set host = '%' where user = 'trinity';
  8. Query OK, 1 row affected (0.01 sec)
  9. Rows matched: 1  Changed: 1  Warnings: 0
  10. mysql> select host, user from user;
  11. +-----------+------------------+
  12. | host      | user             |
  13. +-----------+------------------+
  14. | %         | trinity          |
  15. | localhost | debian-sys-maint |
  16. | localhost | mysql.infoschema |
  17. | localhost | mysql.session    |
  18. | localhost | mysql.sys        |
  19. | localhost | root             |
  20. +-----------+------------------+
  21. 6 rows in set (0.00 sec)
复制代码
现在调试,从192.168.1.12登过来,显示
Error: (1130, "Host '192.168.1.12' is not allowed to connect to this MySQL server")
发现是给错服务器了.....因为两台服务器,老是弄混.....

给192.168.0.12增加源ip192.168.1.12的登入权限:
  1. CREATE USER 'trinity'@'192.168.1.12' IDENTIFIED BY 'trinity';
  2. GRANT ALL PRIVILEGES ON auth.* TO 'trinity'@'192.168.1.12' WITH GRANT OPTION;
复制代码
可以看到加进去了: 
  1. select host, user from user;
  2. +--------------+------------------+
  3. | host         | user             |
  4. +--------------+------------------+
  5. | 192.168.1.12 | trinity          |
  6. | localhost    | debian-sys-maint |
  7. | localhost    | mysql.infoschema |
  8. | localhost    | mysql.session    |
  9. | localhost    | mysql.sys        |
  10. | localhost    | phpmyadmin       |
  11. | localhost    | root             |
  12. | localhost    | trinity          |
  13. +--------------+------------------+
  14. 9 rows in set (0.00 sec)
复制代码
 再配好worldserver的配置

worldserver从网上过来,假如是当地登录,设为当地192.168.1.12地点即可。
这里用了公网的ip的映射,最终auth realmlist的配置:
  1. mysql> update realmlist set address="114.115.136.249"  where id="2";Query OK, 1 row affected (0.03 sec)Rows matched: 1  Changed: 1  Warnings: 0mysql> update realmlist set port="8086"  where id="2";Query OK, 1 row affected (0.02 sec)Rows matched: 1  Changed: 1  Warnings: 0mysql> update realmlist set timezone="16"  where id="2";Query OK, 1 row affected (0.04 sec)Rows matched: 1  Changed: 1  Warnings: 0mysql> select * ;ERROR 1096 (HY000): No tables usedmysql> select * from auth;ERROR 1146 (42S02): Table 'auth.auth' doesn't existmysql> select * from realmlist;+----+----------+-----------------+--------------+-----------------+------+------+------+----------+----------------------+------------+-----------+| id | name     | address         | localAddress | localSubnetMask | port | icon | flag | timezone | allowedSecurityLevel | population | gamebuild |+----+----------+-----------------+--------------+-----------------+------+------+------+----------+----------------------+------------+-----------+
  2. |  1 | Trinity  | 114.115.136.249 | 127.0.0.1    | 255.255.255.0   | 8085 |    0 |    0 |       16 |                    0 |          0 |     12340 |
  3. |  2 | NewRealm | 114.115.136.249 | 127.0.0.1    | 255.255.255.0   | 8086 |    0 |    2 |       16 |                    0 |          0 |     12340 |
  4. +----+----------+-----------------+--------------+-----------------+------+------+------+----------+----------------------+------------+-----------+
  5. 2 rows in set (0.00 sec)
复制代码
 这样终于多区配置乐成了!两个区 Trinity和NewRealm都可以登录了!

总结

TrinityCore多区拓扑:

 可以看到两个分区是差别网段,192.168.0.12和192.168.1.12且中心有一层NAT。内网的192.168.0.12被NAT为192.168.1.2 。
实在这不是必须的,在同一网段,大概不在同一网段,都可以实现TrinityCore的多区设置。固然有一个条件,就是其它的ream必要可以或许跟auth服务器的mysql通信,因为其它realm都是登入auth所在的mysql数据库并调用的此中的auth库内容。
对于所有的realms,都要设定auth指向192.168.0.12即worldserver.conf文件中设置,即多个realm认证服务用同一个数据库:
  1. # LoginDatabaseInfo     = "127.0.0.1;3306;trinity;trinity;auth"
  2. LoginDatabaseInfo     = "192.168.1.2;3306;trinity;trinity;auth"
复制代码
 这里192.168.0.12数据库被NAT为192.168.1.2:3306 。所以最终指向了192.168.1.2 ,留意必要设置mysql支持网络登录,具体见:https://skywalk.blog.csdn.net/article/details/140786611
固然realm1 照旧利用127.0.0.1地点登录myql,即:
  1. LoginDatabaseInfo     = "127.0.0.1;3306;trinity;trinity;auth"
复制代码

对于realmid,每个realm对必要跟auth数据库中的id值对应,比如这里
192.168.0.12 是realm 1, worldserver.conf中设为RealmID = 1:
192.168.1.12是realm2 ,设为RealmID = 2
假如再增加ream,则id依次增加即可。

worldserver.conf中RealmZone 是realm的分区,设为16即为cn ,默认是RealmZone = 1

末了留意gamebuild必要与客户端版本一致,否则客户端是看不到服务器的。

这样设置好后,TrinityCore多区realms就设定好了。当前还不支持跨服副本(Cross realms are not supported.)

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

北冰洋以北

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表