青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
金慶的專欄
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)
相冊
公告照片
搜索
積分與排名
積分 - 660013
排名 - 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" 錯誤(11061)
2.?SVN中邪惡的replace(10986)
3.?VS2005編譯libevent(10434)
4.?混音算法的學習與研究(10239)
5.?C調用lua腳本的效率測試(9020)
評論排行榜
1.?VC6正在被拋棄(35)
2.?VS2005編譯libevent(21)
3.?"multiple definition of" 錯誤(18)
4.?C++引用優于指針(17)
5.?ACE與ASIO之間關于Socket編程的比較(16)
gRPC-go 連接管理
gRPC-go 連接管理
(金慶的專欄 2017.12)
把 example greeter 改一下,處理 SayHello() 請求時,不僅僅返回本次請求者的名字,
還返回上次請求的名字,如:
```
λ go run greeter_client/main.go
2017/12/25 17:59:13 Greeting: Hello 'world' (prev '')
2017/12/25 17:59:15 Greeting: Hello 'world2' (prev 'world')
```
先將客戶端單次請求改為多次請求:
```go
r, err := c.SayHello(context.Background(), &pb.HelloRequest{Name: name})
log.Printf("Greeting: %s", r.Message)
time.Sleep(2 * time.Second)
r, err = c.SayHello(context.Background(), &pb.HelloRequest{Name: name + "2"})
log.Printf("Greeting: %s", r.Message)
...
```
服務器需要為每個連接保存各自的數據。連接創建時初始化數據,連接斷開時清理數據。
這里利用了連接統計的接口,不知道是否是最適當的實現方式?
服務器創建時添加 StatsHandler 選項,輸入一個 stats.Handler 的實現。
```
- s := grpc.NewServer()
+ s := grpc.NewServer(grpc.StatsHandler(&statshandler{}))
```
statshandler 需實現4個方法,只用到2個連接相關的方法,TagConn() 和 HandleConn(),
另外2個 TagRPC() 和 HandleRPC() 用于RPC統計, 實現為空。
```go
type statshandler struct{}
// TagConn 用來給連接打個標簽,以此來標識連接(實在是找不出還有什么辦法來標識連接).
// 這個標簽是個指針,可保證每個連接唯一。
// 將該指針添加到上下文中去,鍵為 connCtxKey{}.
func (h *statshandler) TagConn(ctx context.Context, info *stats.ConnTagInfo) context.Context {
return context.WithValue(ctx, connCtxKey{}, info)
}
// TagRPC 為空.
func (h *statshandler) TagRPC(ctx context.Context, info *stats.RPCTagInfo) context.Context {
return ctx
}
// HandleConn 會在連接開始和結束時被調用,分別會輸入不同的狀態.
func (h *statshandler) HandleConn(ctx context.Context, s stats.ConnStats) {
tag, ok := getConnTagFromContext(ctx)
if !ok {
log.Fatal("can not get conn tag")
}
connsMutex.Lock()
defer connsMutex.Unlock()
switch s.(type) {
case *stats.ConnBegin:
conns[tag] = ""
log.Printf("begin conn, tag = (%p)%#v, now connections = %d\n", tag, tag, len(conns))
case *stats.ConnEnd:
delete(conns, tag)
log.Printf("end conn, tag = (%p)%#v, now connections = %d\n", tag, tag, len(conns))
default:
log.Printf("illegal ConnStats type\n")
}
}
// HandleRPC 為空.
func (h *statshandler) HandleRPC(ctx context.Context, s stats.RPCStats) {
}
```
用一個map來管理所有連接,以連接的標簽(是個指針)為鍵,值為上次請求者的名字。
因為有多線程訪問,所有加個 Mutex 來保護。
連接結束時,將從 conns 中刪除連接相關的數據。
```go
var connsMutex sync.Mutex
var conns map[*stats.ConnTagInfo]string = make(map[*stats.ConnTagInfo]string)
```
getConnTagFromContext() 從上下文中取連接標簽:
```go
type connCtxKey struct{}
func getConnTagFromContext(ctx context.Context) (*stats.ConnTagInfo, bool) {
tag, ok := ctx.Value(connCtxKey{}).(*stats.ConnTagInfo)
return tag, ok
}
```
最后將 SayHello() 改為記錄請求者名字,并返回上次請求者的名字。
```go
func (s *server) SayHello(ctx context.Context, in *pb.HelloRequest) (*pb.HelloReply, error) {
tag, _ := getConnTagFromContext(ctx)
log.Printf("SayHello(), conn tag = (%p)%#v\n", tag, tag)
connsMutex.Lock()
defer connsMutex.Unlock()
prev := conns[tag]
conns[tag] = in.Name
return &pb.HelloReply{Message: fmt.Sprintf("Hello '%s' (prev '%s')", in.Name, prev)}, nil
}
```
測試多個客戶端連接,可以看到每個客戶端有自己的狀態,互不影響。
```
E:\Git\grpc-go\examples\helloworld (master)
λ go run greeter_server/main.go
2017/12/25 18:39:03 start
2017/12/25 18:39:11 begin conn, tag = (0xc042182040)&stats.ConnTagInfo{RemoteAddr:(*net.TCPAddr)(0xc0420818f0), LocalAddr:(*net.TCPAddr)(0xc0420818c0)}, now connections = 1
2017/12/25 18:39:11 SayHello(), conn tag = (0xc042182040)&stats.ConnTagInfo{RemoteAddr:(*net.TCPAddr)(0xc0420818f0), LocalAddr:(*net.TCPAddr)(0xc0420818c0)}
2017/12/25 18:39:13 SayHello(), conn tag = (0xc042182040)&stats.ConnTagInfo{RemoteAddr:(*net.TCPAddr)(0xc0420818f0), LocalAddr:(*net.TCPAddr)(0xc0420818c0)}
2017/12/25 18:39:13 begin conn, tag = (0xc0421ae200)&stats.ConnTagInfo{RemoteAddr:(*net.TCPAddr)(0xc0421de060), LocalAddr:(*net.TCPAddr)(0xc0421de030)}, now connections = 2
2017/12/25 18:39:13 SayHello(), conn tag = (0xc0421ae200)&stats.ConnTagInfo{RemoteAddr:(*net.TCPAddr)(0xc0421de060), LocalAddr:(*net.TCPAddr)(0xc0421de030)}
2017/12/25 18:39:15 SayHello(), conn tag = (0xc042182040)&stats.ConnTagInfo{RemoteAddr:(*net.TCPAddr)(0xc0420818f0), LocalAddr:(*net.TCPAddr)(0xc0420818c0)}
2017/12/25 18:39:15 SayHello(), conn tag = (0xc0421ae200)&stats.ConnTagInfo{RemoteAddr:(*net.TCPAddr)(0xc0421de060), LocalAddr:(*net.TCPAddr)(0xc0421de030)}
2017/12/25 18:39:17 SayHello(), conn tag = (0xc042182040)&stats.ConnTagInfo{RemoteAddr:(*net.TCPAddr)(0xc0420818f0), LocalAddr:(*net.TCPAddr)(0xc0420818c0)}
2017/12/25 18:39:17 SayHello(), conn tag = (0xc0421ae200)&stats.ConnTagInfo{RemoteAddr:(*net.TCPAddr)(0xc0421de060), LocalAddr:(*net.TCPAddr)(0xc0421de030)}
2017/12/25 18:39:19 end conn, tag = (0xc042182040)&stats.ConnTagInfo{RemoteAddr:(*net.TCPAddr)(0xc0420818f0), LocalAddr:(*net.TCPAddr)(0xc0420818c0)}, now connections = 1
2017/12/25 18:39:19 SayHello(), conn tag = (0xc0421ae200)&stats.ConnTagInfo{RemoteAddr:(*net.TCPAddr)(0xc0421de060), LocalAddr:(*net.TCPAddr)(0xc0421de030)}
2017/12/25 18:39:21 end conn, tag = (0xc0421ae200)&stats.ConnTagInfo{RemoteAddr:(*net.TCPAddr)(0xc0421de060), LocalAddr:(*net.TCPAddr)(0xc0421de030)}, now connections = 0
```
posted on 2017-12-25 19:00
金慶
閱讀(1294)
評論(0)
編輯
收藏
引用
所屬分類:
9. 其它
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
相關文章:
TortoiseGit is OK but GitExtensions fails
DeathVoteExpirationTimeout in Orleans
How to delete local branches of GitExtension
Clustering provider in Orleans
Why Orleans' actor is virutal
What comes after microservice?
Rust Deref coercion example
Rust Error Return Check Policy
Rust visibility
Why does Rust check borrow even in single thread
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Powered by:
C++博客
Copyright © 金慶
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
米奇777在线欧美播放
|
欧美日韩亚洲一区二
|
久久午夜电影网
|
欧美一区二区三区喷汁尤物
|
亚洲欧美精品
|
欧美亚洲专区
|
久久最新视频
|
亚洲日本成人在线观看
|
av成人激情
|
欧美一区在线看
|
欧美jjzz
|
亚洲经典三级
|
一区二区三区免费看
|
亚洲综合电影
|
老司机午夜精品
|
欧美日韩三级视频
|
国产一区二区精品
|
日韩视频一区二区三区
|
午夜国产精品视频免费体验区
|
欧美一区二区三区的
|
模特精品裸拍一区
|
一区二区三区 在线观看视频
|
欧美在线免费观看亚洲
|
欧美国产日韩在线观看
|
国产精品日韩专区
|
亚洲国产三级在线
|
欧美一级在线视频
|
欧美激情片在线观看
|
亚洲视频自拍偷拍
|
免费欧美网站
|
国产欧美一区二区三区沐欲
|
亚洲精品久久视频
|
久久久久女教师免费一区
|
亚洲精品视频在线看
|
欧美伊人久久久久久久久影院
|
久久久不卡网国产精品一区
|
老司机午夜精品视频
|
欧美日韩一区二区在线
|
国产日韩欧美综合
|
亚洲第一福利视频
|
一区二区三区高清在线观看
|
久久福利精品
|
亚洲日本一区二区
|
亚洲欧美综合国产精品一区
|
久久亚洲欧美
|
国产精品国产三级国产普通话三级
|
久久精品综合
|
欧美性色视频在线
|
一区二区三区免费网站
|
亚洲国产美女精品久久久久∴
|
欧美一级久久
|
欧美亚洲在线视频
|
亚洲日本一区二区三区
|
久久精品99国产精品酒店日本
|
国产精品二区在线
|
99这里只有久久精品视频
|
欧美国产在线观看
|
蜜臀久久99精品久久久久久9
|
精品福利免费观看
|
蜜桃久久av
|
麻豆九一精品爱看视频在线观看免费
|
国产一区二区三区久久
|
久久福利影视
|
国内精品久久久久久久影视麻豆
|
一区二区三区四区五区精品
|
亚洲精品久久久蜜桃
|
欧美另类一区
|
国产精品99久久不卡二区
|
亚洲免费大片
|
国产精品狼人久久影院观看方式
|
亚洲欧美日韩精品久久奇米色影视
|
一区二区免费看
|
国产精品天美传媒入口
|
久久国产日韩
|
久久夜色精品国产
|
日韩视频一区二区在线观看
|
亚洲伦理在线观看
|
国产精品免费久久久久久
|
欧美在线观看一区
|
久久九九电影
|
一本不卡影院
|
亚洲一区二区在
|
韩国欧美一区
|
亚洲激情视频在线
|
国产精品日日做人人爱
|
老司机67194精品线观看
|
欧美成人免费视频
|
小嫩嫩精品导航
|
麻豆成人在线观看
|
亚洲图片欧美一区
|
久久精品在线播放
|
亚洲视频在线观看免费
|
亚洲欧美日韩中文在线制服
|
亚洲高清资源
|
亚洲综合视频一区
|
亚洲精品久久久久久久久久久
|
久久综合网hezyo
|
中日韩高清电影网
|
久久久亚洲人
|
亚洲欧美日产图
|
老司机成人网
|
欧美一区二区三区在线观看
|
欧美.com
|
久久久久久久久一区二区
|
欧美激情1区2区
|
久久久久久成人
|
国产精品豆花视频
|
亚洲人成网在线播放
|
韩国在线一区
|
亚洲专区一二三
|
亚洲欧洲精品一区二区精品久久久
|
亚洲精品久久久久久久久
|
国产精品久久毛片a
|
欧美黄色大片网站
|
国模大胆一区二区三区
|
欧美一区二区三区免费大片
|
久久久久久久999精品视频
|
亚洲在线国产日韩欧美
|
美女999久久久精品视频
|
久久久久久久久久码影片
|
国产精品久久久久久久久久免费
|
欧美福利视频网站
|
在线观看欧美日本
|
久久精品99国产精品日本
|
久久激情综合网
|
国产精品一区久久久久
|
亚洲午夜精品视频
|
一二三区精品福利视频
|
欧美高清视频在线观看
|
欧美国产欧美亚洲国产日韩mv天天看完整
|
韩国女主播一区
|
欧美一区二视频
|
久久久久久日产精品
|
国产婷婷97碰碰久久人人蜜臀
|
国产精品99久久久久久www
|
亚洲免费播放
|
欧美激情小视频
|
亚洲破处大片
|
亚洲一二三四久久
|
国产精品成人一区
|
亚洲字幕一区二区
|
久久精品国产99精品国产亚洲性色
|
99视频精品全部免费在线
|
一本大道av伊人久久综合
|
欧美日本高清
|
亚洲一区二区欧美
|
久久国内精品自在自线400部
|
国产精品午夜在线
|
欧美一区二区三区成人
|
久久综合狠狠综合久久激情
|
在线欧美一区
|
欧美日韩小视频
|
午夜老司机精品
|
免费成人黄色av
|
亚洲精品一级
|
国产精品久久久999
|
久久久国产91
|
亚洲黄页视频免费观看
|
亚洲一区二区3
|
国产一区二区激情
|
欧美风情在线观看
|
亚洲一品av免费观看
|
久久综合电影
|
一区二区三区精品视频
|
国产农村妇女精品一二区
|
久久久久久久高潮
|
亚洲精品视频一区二区三区
|
欧美伊久线香蕉线新在线
|
亚洲丰满在线
|
国产精品欧美风情
|
欧美91精品
|
午夜精品美女自拍福到在线
|
亚洲精品一区二区在线观看
|
欧美日韩一区二区免费在线观看
|
国产精品久久综合
|
久久嫩草精品久久久精品
|
亚洲免费精品
|
欧美成人中文字幕在线
|
亚洲欧美日韩国产
|
亚洲国产成人久久
|
国产精品一国产精品k频道56
|
久热精品视频在线观看一区
|
亚洲最黄网站
|
亚洲电影免费观看高清完整版在线
|
欧美成人自拍视频
|
亚洲综合精品自拍
|
亚洲欧洲在线看
|
美女国产一区
|
午夜精品一区二区三区在线播放
|
最新国产の精品合集bt伙计
|
国产婷婷色综合av蜜臀av
|
国产精品白丝黑袜喷水久久久
|
男人插女人欧美
|
久久久国产一区二区三区
|
亚洲一区二区三区午夜
|
亚洲精品你懂的
|
浪潮色综合久久天堂
|
欧美综合二区
|
欧美在线视频二区
|
欧美一区亚洲
|