青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
金慶的專欄
C++博客
::
首頁
::
新隨筆
::
聯系
::
聚合
::
管理
::
423 隨筆 :: 0 文章 :: 454 評論 :: 0 Trackbacks
公告
我的隨筆
我的評論
我參與的隨筆
留言簿
(12)
給我留言
查看公開留言
查看私人留言
隨筆分類
(502)
1. C/C++(166)
(rss)
2. 網游開發(108)
(rss)
3. Golang(20)
(rss)
4. Linux/Unix(30)
(rss)
5. 軟工與管理(44)
(rss)
6. Python(23)
(rss)
7. Erlang(18)
(rss)
8. Rust(16)
(rss)
9. 其它(77)
(rss)
隨筆檔案
(423)
2023年1月 (1)
2022年11月 (1)
2022年10月 (2)
2022年9月 (1)
2022年4月 (6)
2022年1月 (2)
2021年12月 (4)
2021年11月 (6)
2021年10月 (2)
2021年9月 (2)
2021年8月 (7)
2021年7月 (2)
2021年5月 (2)
2021年3月 (1)
2021年2月 (2)
2021年1月 (1)
2020年12月 (1)
2020年10月 (1)
2020年9月 (5)
2020年8月 (1)
2020年7月 (1)
2020年6月 (1)
2020年4月 (2)
2020年3月 (3)
2020年2月 (3)
2020年1月 (1)
2019年12月 (1)
2019年9月 (2)
2019年4月 (2)
2019年1月 (1)
2018年12月 (1)
2018年11月 (3)
2018年10月 (1)
2018年9月 (3)
2018年8月 (3)
2018年7月 (2)
2018年6月 (4)
2018年5月 (4)
2018年4月 (4)
2018年3月 (1)
2018年1月 (2)
2017年12月 (2)
2017年11月 (3)
2017年10月 (3)
2017年8月 (7)
2017年7月 (1)
2017年6月 (1)
2017年5月 (3)
2017年4月 (3)
2017年3月 (3)
2017年2月 (2)
2017年1月 (2)
2016年12月 (5)
2016年11月 (2)
2016年10月 (2)
2016年9月 (1)
2016年8月 (6)
2016年7月 (3)
2016年6月 (2)
2016年5月 (4)
2016年4月 (2)
2016年3月 (2)
2016年1月 (3)
2015年12月 (2)
2015年11月 (2)
2015年10月 (1)
2015年8月 (2)
2015年7月 (1)
2015年6月 (1)
2015年5月 (4)
2015年4月 (3)
2015年3月 (4)
2015年2月 (5)
2015年1月 (4)
2014年12月 (3)
2014年11月 (3)
2014年10月 (2)
2014年9月 (3)
2014年8月 (1)
2014年4月 (4)
2014年3月 (1)
2014年2月 (4)
2014年1月 (5)
2013年12月 (5)
2013年11月 (5)
2013年9月 (2)
2013年8月 (2)
2013年7月 (2)
2013年6月 (2)
2013年5月 (1)
2013年1月 (2)
2012年12月 (1)
2012年11月 (1)
2012年9月 (1)
2012年8月 (3)
2012年7月 (2)
2012年6月 (1)
2012年4月 (3)
2012年3月 (2)
2012年2月 (3)
2012年1月 (2)
2011年11月 (2)
2011年10月 (3)
2011年9月 (2)
2011年8月 (2)
2011年7月 (3)
2011年6月 (2)
2011年5月 (3)
2011年1月 (2)
2010年12月 (1)
2010年11月 (2)
2010年10月 (2)
2010年9月 (3)
2010年8月 (2)
2010年7月 (3)
2010年6月 (1)
2010年5月 (3)
2010年4月 (3)
2010年3月 (5)
2010年2月 (4)
2010年1月 (4)
2009年12月 (2)
2009年11月 (3)
2009年10月 (4)
2009年9月 (3)
2009年8月 (2)
2009年7月 (4)
2009年6月 (1)
2009年5月 (3)
2009年4月 (4)
2009年3月 (2)
2009年2月 (5)
2009年1月 (1)
2008年12月 (7)
2008年11月 (4)
2008年10月 (1)
2008年9月 (3)
2008年8月 (4)
2008年7月 (3)
2008年6月 (4)
2008年5月 (6)
2008年4月 (7)
2008年3月 (6)
2008年1月 (5)
2007年12月 (7)
2007年11月 (4)
2007年10月 (5)
2007年9月 (6)
2007年8月 (8)
2007年7月 (5)
相冊
公告照片
搜索
積分與排名
積分 - 659813
排名 - 25
最新評論
1.?re: boost::asio::spawn 將一統C++網絡庫
asio 成為C++首選網絡庫
--linda
2.?re: log4cxx中文輸出錯誤補丁
評論內容較長,點擊標題查看
--金慶
3.?re: mingw編譯OrzNet
能發送一個mingw編譯好的OrzNet庫給我嗎? liuweiqcxy@163.com
謝謝!
--劉威
4.?re: log4cxx中文輸出錯誤補丁
評論內容較長,點擊標題查看
--bigbad
5.?re: log4cxx中文輸出錯誤補丁
評論內容較長,點擊標題查看
--bigbad
閱讀排行榜
1.?"multiple definition of" 錯誤(11060)
2.?SVN中邪惡的replace(10984)
3.?VS2005編譯libevent(10430)
4.?混音算法的學習與研究(10237)
5.?C調用lua腳本的效率測試(9020)
評論排行榜
1.?VC6正在被拋棄(35)
2.?VS2005編譯libevent(21)
3.?"multiple definition of" 錯誤(18)
4.?C++引用優于指針(17)
5.?ACE與ASIO之間關于Socket編程的比較(16)
open-match匹配流程
# open-match匹配流程
(金慶的專欄 2019.1)
https://github.com/GoogleCloudPlatform/open-match
open-match 是一個通用的游戲匹配框架。
由游戲提供自定義的匹配算法(以docker鏡像的方式提供)。
分為多個進程,各進程之間共享一個 redis.
* 前端, 接收玩家加入 redis,成功后通知玩家房間服地址
* 后端,設置一局游戲的匹配規則,設置房間服地址
* MMFOrc,啟動匹配算法(MMF)
* MMF, 自定義匹配算法,讀取 redis 獲取玩家,匹配成功就將結果寫入 redis. 僅匹配一局就退出。
游戲服中連接 open-match 的前端與后端的進程,分別稱為 frontendclient 和 Director。
輸入分2部份,一是玩家信息,二是對局信息。
Director 向后端輸入對局信息,就會收到一個接一個的對局人員列表.
Director 需要為每個對局開房間,然后通知后端房間地址。
后端將房間地址寫入 redis, 然后前端讀取到房間地址,就通知 frontendclient,讓玩家進入房間。
## test/cmd/frontendclient
模擬大廳服或組隊服,連接前端API, 請求匹配玩家/隊伍。成功后將收到房間服(DGS)的地址(Assignment)。
Player 實際上是一個隊伍,其中ID字段是用空格分隔的多個ID.
雖然參數類型都是 Player, CreatePlayer() 參數為整個隊伍,而 GetUpdates() 參數是單個玩家。
main() 中創建多個玩家,每個玩家調用 GetUpdates() 以獲取結果,go waitForResults() 中處理結果。
waitForResult() 讀取流中的匹配結果,壓入 resultsChan(但好像 resultsChan 僅用于打印)。
所有玩家合并到 g 實例中,然后調用 CreatePlayer() 請求匹配。
cleanup() 調用 DeletePlayer() 來刪除匹配請求,不僅需刪除整個隊伍,也需要刪除單個玩家。
好像最后取結果沒取對地方,應該從 resultChan 中獲取 Assignment, 并用該地址 udpClient().
看了該示例就可以理解 frontend.proto
## examples/backendclient
MatchObject.Properties 是從 testprofile.json 讀取的,應該改名為 Profile 是否更好點?
pbProfile 是 MatchObject,Profile 等同于 MatchObject?
Profile 的定義是 MMF 所需的所有參數。
`pbProfile.Properties = jsonProfile` 重復了2遍。
ListMatches()列出這個Profile的所有匹配。
收到一個匹配后,須用CreateAssignments()將房間服地址, 稱為 Assignment, 發送到所有游戲客戶端。
## cmd/frontendapi
CreatePlayer() 將 Player 對象寫入 redis, 鍵值為 Player.Id, 類型為 HSET。
對 Player 的每個 attribute,添加到 ZSET 中去。
此處 Player 是一組玩家。
GetUpdates() 每隔2s讀取redis, Player數據有變化時就發送。此處 Player 是單個玩家。
如果CreatePlayer()中隊伍只有一個玩家,
則寫入的Player與GetUpdates()中讀取的玩家是同一個redis鍵。
## cmd/backendapi
CreateMatch() 中 profile 類型為 MatchObject, 是一個比賽的限制條件。
profile 先寫入 redis, 鍵為 profile.Id.
`requestKey := xid() + "." + profile.Id`,
并將 requestKey 加入 redis 集合 "profileq"。
然后每2s查詢 redis, 看是否有 requestKey 鍵出現,并返回該值。
ListMatch() 每2s調用一次 CreateMatch().
DeleteMatch() 僅僅刪除 Id 這個鍵。
CreateAssignments() 為多個隊伍設置Assignment, 即房間地址。
遍歷所有Roster中的Player對象,在redis中設置Assignment.
(Assignment 更改后,會觸發前端更新。)
將所有 Player.Id 從 "proposed" 移到 "deindexed",這兩個是 ZSET, 分值為加入時間。
Roster 應該是比賽中的陣營,如紅方,藍方,每個陣營中可有多個隊伍。
DeleteAssignments() 僅僅遍歷所有 Player 對象來刪除 Assignment 字段。
## cmd/mmforc
匹配流程是由 mmforc (matchmaking function orchestrator) 控制的。
mmforc 每秒從 redis 的 profileq 中取出 100 個成員, 其中 profileq 是個set類型,
使用命令為`SPOP profileq 100`.
對每個 profile, 創建一個 k8s 任務:
```
// Kick off the job asynchrnously
go mmfunc(ctx, profile, cfg, defaultMmfImages, clientset, &pool)
```
每隔10s, 還有所有匹配任務都完成后,需要 `checkProposals`, 即創建 evaluator 任務。
profileq 中的元素 profile 為字符串,matchObjectID.profileID。
以 profileID 為鍵,可以從 redis 讀取 profile 的內容, profile 是個 MatchObject 對象。
profile 的內容為 json 串,其中 "jsonkeys.mmfImages" 為 mmf (matchmaking function) 鏡像。
如果profile讀取失敗,或者 mmfImages 為空,則使用默認的鏡像。mmfImages 未來會支持多個鏡像。
通過 MMF_* 環境變量傳入各種參數.
## mmf
示例:examples\functions\golang\manual-simple
從環境變量 "MMF_PROFILE_ID" 解析出 profileID, 并向 redis 查詢(HGETALL) profile,HSET 類型。
從 profile 中取 pools 字段,即匹配條件。
pools 分為多個 pool, 每個 pool 中有多個 filter, 每個 filter 向 redis 取符合的 Player.
profile 用到以下字段:
* "properties.playerPool"
json串,是一些過濾條件,如“mmr: 100-999”
* "properties.roster"
json串, 是多個隊伍大小,如 “red: 4”
示例見:`examples\backendclient\profiles\testprofile.json`
### 簡單匹配過程
simple mmf 的匹配過程如下:
1. 從 redis 查詢 profile,獲取過濾條件和各隊伍大小
1. 每個過濾條件向 redis 查詢,所有結果的交集為可選成員
1. 去除 ignoreList, 即最近 800s 內已匹配成功的成員,即 proposal 和 deindexed ZSET 列表。
1. 如果可選成員個數太小,則 insufficient_players 并退出
1. 分配各個隊伍成員
1. 向 redis 記錄結果
### 結果
profile 中添加 roster,即各陣營成員名單,存入 prososalKey.
保存不分隊伍的成員名單。
然后向 "proposalq" 添加 prososalKey
### 細節
poolRosters 以 (pool名, filter attribute) 為鍵,值為 Player ID 列表.
保存從 redis 查詢的符合條件的 Player ID.
overlaps 以 pool 名為鍵,保存符合該pool中所有filter的 Player ID 列表,去除 ignore list.
rosters 是 profile 中的 "properties.rosters" 字段。不知何用?
遍歷 rosters, 為每個陣營的每個player找到對應pool的PlayerID, 保存到 mo.Rosters.
其中 profileRosters 好像沒用。
posted on 2019-01-31 10:21
金慶
閱讀(1108)
評論(0)
編輯
收藏
引用
所屬分類:
2. 網游開發
、
3. Golang
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
相關文章:
How are dtLinks created in NavMesh
UE4 Blueprint Multiple Event BeginPlay
第9代游戲主機
Canvas Scaler 的3種模式
幀同步是否允許客戶端指定命令幀號
rpc應答太快造成請求超時
測試 tolua 例子 TestErrorStack
lua變量缺少local造成unity死鎖
C# tolua 之間互傳 byte[]
Unity使用異步grpc
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Powered by:
C++博客
Copyright © 金慶
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
久久se精品一区精品二区
|
亚洲高清自拍
|
在线视频欧美日韩
|
欧美大胆成人
|
亚洲欧美国产日韩中文字幕
|
欧美三区美女
|
亚洲欧美日本伦理
|
日韩天堂在线视频
|
欧美日韩在线三级
|
亚洲一级片在线看
|
欧美91大片
|
免费成人高清在线视频
|
1024成人
|
亚洲激情偷拍
|
欧美网站大全在线观看
|
亚洲国产专区校园欧美
|
欧美 日韩 国产一区二区在线视频
|
亚洲美女视频在线免费观看
|
亚洲国产精品va在看黑人
|
久久视频这里只有精品
|
亚洲视频999
|
国产综合婷婷
|
亚洲高清在线观看
|
国产精品国产三级欧美二区
|
亚洲一区三区视频在线观看
|
国产精品99久久久久久宅男
|
国产日产高清欧美一区二区三区
|
久久精品99国产精品
|
久久久xxx
|
亚洲国产精品久久
|
亚洲最新在线视频
|
韩国一区二区在线观看
|
欧美激情一区二区三区
|
久久免费视频网
|
亚洲狼人精品一区二区三区
|
亚洲视频日本
|
国内精品亚洲
|
99香蕉国产精品偷在线观看
|
国产美女精品视频免费观看
|
欧美高清在线一区二区
|
国产精品免费观看视频
|
免费观看成人
|
国产精品国产成人国产三级
|
久久久免费精品视频
|
欧美日韩国产色视频
|
亚洲午夜激情网站
|
久久久久一区二区三区四区
|
一本高清dvd不卡在线观看
|
亚洲一区免费看
|
亚洲精品乱码久久久久久蜜桃麻豆
|
av成人免费观看
|
激情久久婷婷
|
亚洲香蕉在线观看
|
亚洲国产精彩中文乱码av在线播放
|
亚洲精品一区二区三
|
激情亚洲一区二区三区四区
|
夜夜夜精品看看
|
国产精品一区二区你懂得
|
亚洲国产成人久久综合一区
|
国产日韩欧美一区二区三区在线观看
|
欧美在线一区二区三区
|
久久久精品久久久久
|
亚洲欧美日韩区
|
欧美韩日一区二区三区
|
久久久久天天天天
|
国产精品亚洲综合
|
一区二区三区国产在线
|
国产在线乱码一区二区三区
|
亚洲深夜福利视频
|
18成人免费观看视频
|
欧美一区二区
|
亚洲视频axxx
|
欧美日在线观看
|
亚洲美女中文字幕
|
国产精品欧美日韩久久
|
99re66热这里只有精品4
|
日韩午夜中文字幕
|
欧美成人中文
|
欧美成人乱码一区二区三区
|
猛男gaygay欧美视频
|
米奇777超碰欧美日韩亚洲
|
国产人久久人人人人爽
|
亚洲一区免费视频
|
欧美日韩福利在线观看
|
亚洲午夜精品一区二区三区他趣
|
欧美专区亚洲专区
|
亚洲高清在线视频
|
欧美色道久久88综合亚洲精品
|
亚洲午夜免费福利视频
|
久久久青草婷婷精品综合日韩
|
在线电影欧美日韩一区二区私密
|
欧美大片91
|
亚洲一区二区三区午夜
|
免费在线日韩av
|
亚洲视频一区在线观看
|
国色天香一区二区
|
欧美精品三级
|
久久国产精品99精品国产
|
亚洲激情av
|
欧美在线亚洲综合一区
|
亚洲精品社区
|
国产亚洲网站
|
欧美午夜无遮挡
|
欧美 日韩 国产在线
|
亚洲一区三区电影在线观看
|
嫩草国产精品入口
|
先锋影音久久
|
日韩一级免费
|
亚洲国产成人在线播放
|
国产精品久久久久7777婷婷
|
久久婷婷人人澡人人喊人人爽
|
一区二区三区精品
|
亚洲国语精品自产拍在线观看
|
欧美一区成人
|
亚洲综合色在线
|
亚洲精品一区二区三区av
|
国产综合色精品一区二区三区
|
欧美日韩中国免费专区在线看
|
久久久欧美一区二区
|
亚洲专区一二三
|
亚洲理论在线
|
亚洲三级电影在线观看
|
欧美+日本+国产+在线a∨观看
|
午夜日韩电影
|
亚洲欧美日韩国产另类专区
|
91久久在线播放
|
亚洲国产mv
|
一区在线视频
|
在线播放日韩欧美
|
精东粉嫩av免费一区二区三区
|
国产日韩一区二区
|
国产日韩欧美a
|
国产午夜久久久久
|
国产欧美一区二区色老头
|
国产精品美女久久福利网站
|
欧美日韩免费精品
|
欧美日韩成人在线视频
|
欧美精品色网
|
欧美日韩系列
|
国产精品女主播在线观看
|
国产精品欧美日韩一区
|
国产精品女主播一区二区三区
|
国产精品久久久久久久久久ktv
|
欧美日本高清
|
国产精品久久久久一区二区三区共
|
欧美精品一区二区三区在线播放
|
欧美大片免费观看
|
欧美日韩国产首页
|
国产精品区一区二区三
|
国产精品一卡
|
1024精品一区二区三区
|
欧美精品二区
|
欧美丝袜第一区
|
国产日产高清欧美一区二区三区
|
国产亚洲一区在线播放
|
亚洲第一福利视频
|
亚洲卡通欧美制服中文
|
亚洲视频欧美在线
|
久久er99精品
|
欧美不卡高清
|
99精品黄色片免费大全
|
亚洲一区二区三区视频播放
|
欧美一区二区视频在线观看
|
久久精品国产久精国产爱
|
免费成人av资源网
|
国产精品sss
|
一区二区三区在线高清
|
亚洲精品麻豆
|
欧美在线观看www
|
欧美电影资源
|
亚洲一区二区动漫
|
另类天堂视频在线观看
|
欧美视频一区二区三区…
|
国产伦精品一区二区三区免费
|
激情综合网激情
|
亚洲曰本av电影
|
欧美v国产在线一区二区三区
|
亚洲免费成人
|
久久久久久久综合日本
|
欧美日韩 国产精品
|
国产一区二区三区成人欧美日韩在线观看
|
欧美久久久久久蜜桃
|
国产精品美腿一区在线看
|
亚洲福利久久
|
欧美在线|欧美
|
亚洲欧洲视频在线
|
久久精品人人
|
欧美视频精品在线
|
亚洲激情av
|
久久久综合激的五月天
|
在线一区二区日韩
|
老司机免费视频久久
|
国产精品豆花视频
|
日韩视频一区
|
亚洲第一成人在线
|
久久精品最新地址
|
国产精品专区h在线观看
|
在线一区二区视频
|
亚洲国产精品尤物yw在线观看
|
欧美伊人影院
|