Add new Resolver and Balancer APIs (gRFC L9) (#1408)
- Add package balancer and resolver. - Change ClientConn internals to new APIs and adds a wrapper for v1 balancer.
This commit is contained in:
		
							
								
								
									
										12
									
								
								rpc_util.go
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								rpc_util.go
									
									
									
									
									
								
							| @ -132,7 +132,9 @@ type callInfo struct { | ||||
| 	creds                 credentials.PerRPCCredentials | ||||
| } | ||||
|  | ||||
| var defaultCallInfo = callInfo{failFast: true} | ||||
| func defaultCallInfo() *callInfo { | ||||
| 	return &callInfo{failFast: true} | ||||
| } | ||||
|  | ||||
| // CallOption configures a Call before it starts or extracts information from | ||||
| // a Call after it completes. | ||||
| @ -384,14 +386,15 @@ func recv(p *parser, c Codec, s *transport.Stream, dc Decompressor, m interface{ | ||||
| } | ||||
|  | ||||
| type rpcInfo struct { | ||||
| 	failfast      bool | ||||
| 	bytesSent     bool | ||||
| 	bytesReceived bool | ||||
| } | ||||
|  | ||||
| type rpcInfoContextKey struct{} | ||||
|  | ||||
| func newContextWithRPCInfo(ctx context.Context) context.Context { | ||||
| 	return context.WithValue(ctx, rpcInfoContextKey{}, &rpcInfo{}) | ||||
| func newContextWithRPCInfo(ctx context.Context, failfast bool) context.Context { | ||||
| 	return context.WithValue(ctx, rpcInfoContextKey{}, &rpcInfo{failfast: failfast}) | ||||
| } | ||||
|  | ||||
| func rpcInfoFromContext(ctx context.Context) (s *rpcInfo, ok bool) { | ||||
| @ -401,7 +404,8 @@ func rpcInfoFromContext(ctx context.Context) (s *rpcInfo, ok bool) { | ||||
|  | ||||
| func updateRPCInfoInContext(ctx context.Context, s rpcInfo) { | ||||
| 	if ss, ok := rpcInfoFromContext(ctx); ok { | ||||
| 		*ss = s | ||||
| 		ss.bytesReceived = s.bytesReceived | ||||
| 		ss.bytesSent = s.bytesSent | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 Menghan Li
					Menghan Li