棋牌游戏服务器架构: 详细设计(三) 数据库设计
主要有3类Database: ServerInfoDB,UserInfoDB和GameDB。 ServerInfoDB主要存储的是游戏列表的信息,UserInfoDB存储玩家的全局信息,而GameDB就是积分以及积分变化情况。下面分别加以描述。
1. ServerInfoDB
ServerInfoDB主要存储游戏列表信息。主要有以下几个表:
1. GameTypeInfo,其主要字段为:
TypeID:类型标识 ID
TypeName:类型名字,例如棋牌类,休闲类
Enable:控制游戏大厅是否显示该类型,默认为 1,即为默认显示
2. GameKindInfo,其主要字段为:
KindID: 游戏的唯一标识
TypeID: 外键(GameTypeInfo的主键),该游戏所属类型
KindName: 游戏名称, 比如德州扑克,斗地主等。
ProcessName: 客户端进程名称
MaxVersion: 客户端进程的最低版本,若是登录时发现客户端版本低于这个值,要求其更新。
Enable: 控制游戏大厅是否显示该游戏,默认为1。
3. GameStationInfo 站点信息表:
StationID: 站点标识
StationName: 站点名称
Enable: 这个站点是玩家可以选择的,这个标识控制是否显示给玩家,默认为1
2 UserInfoDB
这个数据库主要存储玩家的全局信息,有两个表: UserAccounts和ClubList:
1. UserAccounts的主要字段:
UserID:玩家的唯一标识,注册的时候自动生成,不能修改
Accounts:帐户名字,具有唯一性,不能重复,能修改
LogonPass:玩家帐户的密码,采用通用加密算法 MD5 加密记录
Gender:性别
LogonNullity:帐户禁止标志,影响玩家登录广场和登录游戏房间
ServiceNullity:服务禁止标志,保留供网站系统使用或者将来系统扩展使用
UserRight:玩家权限标志,每一位代表一种权限, 比如旁观权限,大厅公聊权限,私聊权限等。
ManageRight:管理权限标志,第一位代表一种管理权限,比如踢出玩家,发布消息等。
FaceID:玩家头像索引号码
ClubID:外键(ClubList的主键),玩家社团 ID 号码
MemberOrder:会员等级标识
Experience:玩家经验数值,表示玩家游戏的总局数,可以通过修改每个游戏的经验数值增加方案得到策略的改变
AllLogonTimes:玩家成功登陆的总次数
RegisterDate:玩家的注册日期
LastLogonDate:玩家最后登陆的日期
RegisterIP:玩家帐户的注册所在的 IP 地址
LastLogonIP:玩家最后使用此帐户登陆的 IP 地址
Question:密码找回提示问题
Answer:密码找回回答问题
QQ:玩家注册QQ号码
ConnectPerson:联系人姓名
PhoneNO:电话号码
Address:家庭住址
Email:电子邮箱
2. ClubList是用来存储社团列表的,主要字段包括:
ClubID:社团的唯一标识号码,注册的时候自动生成,不能修改
ClubName:社团名字
ClubQQ:与社团对应的QQ群号码
ClubAdmin:社团管理员(外键)
ClubNotice:社团公告,预留字段
3 GameDB
这个DB主要存储玩家的游戏相关信息,例如游戏积分,胜局,和局,逃局,登陆时间等信息。
1. GameScore
UserID:玩家标识号码
Score:玩家的积分数值
WinCount:游戏胜利局数
LostCount:游戏输局局数
DrawCount: 游戏和局局数
FleeCount: 游戏逃跑局数
UserRight:玩家在此游戏中的普通权限数值,在登陆房间的时候与玩家房间权限进行或操作
ManageRight:玩家在此游戏中的管理权限数值,在登陆房间的时候与玩家房间权限进行或操作
PlayTimeCount:玩家在此类游戏中的游戏时间
AllLogonTimes:玩家进入此类游戏的总次数
RegisterDate:玩家首次进入此类游戏的时间
LastLogonDate:玩家最后一次进入此类游戏的时间
RegisterIP:玩家首次进入此类游戏的 IP 地址
LastLogonIP:玩家最后一次进入此类游戏的IP 地址
2. GameLogonLog:
ID:Log的索引ID,自增长。
UserID:外键,玩家 ID 号码
Score:玩家进入房间时刻的积分数值
WinCount:玩家进入房间时刻的游戏胜利局数
LostCount:玩家进入房间时刻的游戏输局局数
DrawCount:玩家进入房间时刻的游戏和局局数
FleeCount:玩家进入房间时刻的游戏逃跑局数
KindID:玩家进入的房间的类型标识号码
ServerID:玩家进入房间的房间标识号码
ClientIP:玩家进入房间的连接IP地址
LogonTime:玩家进入房间的时间
3. GameScorelog:
ID:LogID,自增长
UserID:外键,玩家 ID 号码
LeftTime:玩家离开房间的时间
Score:玩家在游戏房间游戏所产生的积分改变的数值
WinCount:玩家在游戏房间游戏所产生的胜利局数改变的数值
LostCount:玩家在游戏房间游戏所产生的输局局数改变的数值
DrawCount:玩家在游戏房间游戏所产生的和局局数改变的数值
FleeCount:玩家在游戏房间游戏所产生的逃跑局数改变的数值
Experience:玩家在游戏房间游戏所产生的经验数值改变的数值
PlayTimeCount:玩家在游戏房间游戏所产生的游戏时间的数值
OnLineTimeCount:玩家在游戏房间游戏所产生的在线时间的数值
KindID:玩家进入的房间的类型标识号码
ServerID:玩家进入房间的房间标识号码
ClientIP:玩家进入房间的连接IP地址
- 顶
棋牌游戏服务器架构: 详细设计(三) 数据库设计相关推荐
- 棋牌游戏服务器架构: 详细设计(三) 数据库设计
主要有3类Database: ServerInfoDB,UserInfoDB和GameDB. ServerInfoDB主要存储的是游戏列表的信息,UserInfoDB存储玩家的全局信息,而GameDB ...
- 棋牌游戏服务器架构: 详细设计(3) 数据库设计
2019独角兽企业重金招聘Python工程师标准>>> 主要有3类Database: ServerInfoDB,UserInfoDB和GameDB. ServerInfoDB主要存储 ...
- 棋牌游戏服务器架构: 详细设计(二) 应用层设计
这里的应用层,指的是CenterServer.LogonServer.LogServer.RoomServer等几个服务器,另外还包括游戏模块的设计.不过游戏模块和前4个服务器的设计很不相同.这里先说 ...
- 棋牌游戏服务器架构: 详细设计(一) 内核设计
内核的几个组件被设计成Service,也就是说这几个模块都要实现如下接口: 图1 IService接口 Start方法用来启动服务. Stop 方法用来关闭服务. IsService 方法用于查询当 ...
- 棋牌游戏服务器架构: 总体设计
首先要说明的是, 这个棋牌游戏的服务器架构参考了网狐棋牌的架构.网狐棋牌最令人印象深刻的是其稳定性和高网络负载.它的一份压力测试报告上指出:一台双核r的INTEL Xeon 2.8CPU加上2G内存和 ...
- 网络棋牌游戏服务器架构
一.物理架构说明 游戏系统组件包括: 服务器系统(中心服务器的控制系统,服务器登陆控制的系统,游戏登陆服务器,游戏房间控制的系统,游戏组件系统),游戏客户端(游戏大厅,游戏组件). 数据库系统:用于保 ...
- 棋牌游戏服务器架构: 部署
先看一下,下面这张可能的部署图吧. 图1 系统布署图 在这个图中,可以看到,客户端的形式多种多样,可能是pc上的一个可执行文件,也可能是通过浏览器打开的一个网页,甚至于手机客户端.它们都通过inte ...
- 如何设计大型游戏服务器架构?
一.游戏服务器特征 游戏服务器,是一个会长期运行程序,并且它还要服务于多个不定时,不定点的网络请求.所以这类服务的特点是要特别关注稳定性和性能.这类程序如果需要多个协作来提高承载能力,则还要关注部署和 ...
- 高性能游戏服务器架构设计,一种高性能大型多人在线角色扮演游戏服务器架构设计.doc...
一种高性能大型多人在线角色扮演游戏服务器架构设计 一种高性能大型多人在线角色扮演游戏服务器架构设计摘要:大型多人在线角色扮演游戏(Massively Multiplayer Online Role P ...
最新文章
- MYSQL主从数据库搭建
- linux内核cfs浅析
- C#调用dll提示试图加载格式不正确的程序解决方法
- Python踩坑:类与类对象类型参数传递与使用
- 从程序员的角度分析微信小程序
- 11相机不流畅_小米11最新售价确定,标准版价格亲民,网友:幸福来得真突然...
- 知识即战斗力!数学家华罗庚投入特殊抗战,一夜译破日军密码
- 微软力挺 Go,宣布参与 Athens 项目和 GopherSource
- 局域网从另一台电脑copy文件(Linux系统下)
- linux监控文件是否传输,利用SecureCRT在linux与Windows之间传输文件
- 马哥学习----李洋个人笔记----安全和加密
- 计算机创新课堂教案,1 1.1计算机概述1.2计算机系统课堂教学教案
- 旭日x3派,手势识别之Momo Quanghuang学习记录
- 制造业执行系统MES 在汽车零配件行业展露锋芒
- 计算机如何安装无线网络适配器,小编教你电脑无线网卡驱动怎么安装
- 07.合成复用原则(Composite/Aggregate Reuse Principle,CARP)
- 星环科技如何站稳脚跟?
- ecw2c为我唱一首堆栈溢出的歌曲:音乐尾声优化
- 笔记-深入理解计算机系统
- 我所遇到最牛的sshd远程连接
热门文章
- 分区数据导出功能(页面调整)
- 用户操作-登录流程分析
- SpringMVC异常处理之异常处理代码编写
- springboot No Java compiler available for configuration options compilerClassName
- 什么决定了电商双11大促的成败
- SpringCloud 定义Eureka服务端、Eureka服务信息、Eureka发现管理、Eureka安全配置、Eureka-HA机制、 Eureka服务打包部署
- 在线做计算机考研题,2018年计算机考研真题及参考答案
- PyTorch深度学习实践03
- ubuntu配置GDB
- RabbitMQ消息可靠性分析和应用