Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
B
brpc
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
brpc
Commits
4a0927af
Commit
4a0927af
authored
Sep 28, 2018
by
gejun
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix many issues around impl. of grpc
parent
798e9a11
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
93 additions
and
97 deletions
+93
-97
client.cpp
example/grpc_c++/client.cpp
+4
-5
server.cpp
example/grpc_c++/server.cpp
+0
-1
http_message.cpp
src/brpc/details/http_message.cpp
+16
-14
http_message.h
src/brpc/details/http_message.h
+8
-8
global.cpp
src/brpc/global.cpp
+0
-12
grpc.cpp
src/brpc/grpc.cpp
+24
-0
grpc.h
src/brpc/grpc.h
+4
-1
http_header.h
src/brpc/http_header.h
+0
-2
options.proto
src/brpc/options.proto
+0
-1
http2_rpc_protocol.cpp
src/brpc/policy/http2_rpc_protocol.cpp
+15
-41
http2_rpc_protocol.h
src/brpc/policy/http2_rpc_protocol.h
+14
-5
http_rpc_protocol.cpp
src/brpc/policy/http_rpc_protocol.cpp
+0
-0
http_rpc_protocol.h
src/brpc/policy/http_rpc_protocol.h
+8
-7
No files found.
example/grpc_c++/client.cpp
View file @
4a0927af
...
@@ -21,7 +21,7 @@
...
@@ -21,7 +21,7 @@
#include <brpc/channel.h>
#include <brpc/channel.h>
#include "helloworld.pb.h"
#include "helloworld.pb.h"
DEFINE_string
(
protocol
,
"
grp
c"
,
"Protocol type. Defined in src/brpc/options.proto"
);
DEFINE_string
(
protocol
,
"
h2
c"
,
"Protocol type. Defined in src/brpc/options.proto"
);
DEFINE_string
(
server
,
"0.0.0.0:50051"
,
"IP Address of server"
);
DEFINE_string
(
server
,
"0.0.0.0:50051"
,
"IP Address of server"
);
DEFINE_string
(
load_balancer
,
""
,
"The algorithm for load balancing"
);
DEFINE_string
(
load_balancer
,
""
,
"The algorithm for load balancing"
);
DEFINE_int32
(
timeout_ms
,
100
,
"RPC timeout in milliseconds"
);
DEFINE_int32
(
timeout_ms
,
100
,
"RPC timeout in milliseconds"
);
...
@@ -59,22 +59,21 @@ int main(int argc, char* argv[]) {
...
@@ -59,22 +59,21 @@ int main(int argc, char* argv[]) {
helloworld
::
HelloReply
response
;
helloworld
::
HelloReply
response
;
brpc
::
Controller
cntl
;
brpc
::
Controller
cntl
;
request
.
set_name
(
"grpc client example"
);
request
.
set_name
(
"grpc_req_from_brpc"
);
cntl
.
http_request
().
set_content_type
(
"application/grpc"
);
if
(
FLAGS_gzip
)
{
if
(
FLAGS_gzip
)
{
cntl
.
set_request_compress_type
(
brpc
::
COMPRESS_TYPE_GZIP
);
cntl
.
set_request_compress_type
(
brpc
::
COMPRESS_TYPE_GZIP
);
}
}
// Because `done'(last parameter) is NULL, this function waits until
// Because `done'(last parameter) is NULL, this function waits until
// the response comes back or error occurs(including timedout).
// the response comes back or error occurs(including timedout).
stub
.
SayHello
(
&
cntl
,
&
request
,
&
response
,
NULL
);
stub
.
SayHello
(
&
cntl
,
&
request
,
&
response
,
NULL
);
//cntl.http_request().uri() = FLAGS_server;
//channel.CallMethod(NULL, &cntl, &request, &response, NULL);
if
(
!
cntl
.
Failed
())
{
if
(
!
cntl
.
Failed
())
{
LOG
(
INFO
)
<<
"Received response from "
<<
cntl
.
remote_side
()
LOG
(
INFO
)
<<
"Received response from "
<<
cntl
.
remote_side
()
<<
" to "
<<
cntl
.
local_side
()
<<
" to "
<<
cntl
.
local_side
()
<<
": "
<<
response
.
message
()
<<
": "
<<
response
.
message
()
<<
" latency="
<<
cntl
.
latency_us
()
<<
"us"
;
<<
" latency="
<<
cntl
.
latency_us
()
<<
"us"
;
}
else
{
}
else
{
LOG
(
WARNING
)
<<
cntl
.
Error
Code
()
<<
": "
<<
cntl
.
Error
Text
();
LOG
(
WARNING
)
<<
cntl
.
ErrorText
();
}
}
usleep
(
FLAGS_interval_ms
*
1000L
);
usleep
(
FLAGS_interval_ms
*
1000L
);
}
}
...
...
example/grpc_c++/server.cpp
View file @
4a0927af
...
@@ -42,7 +42,6 @@ public:
...
@@ -42,7 +42,6 @@ public:
if
(
FLAGS_gzip
)
{
if
(
FLAGS_gzip
)
{
cntl
->
set_response_compress_type
(
brpc
::
COMPRESS_TYPE_GZIP
);
cntl
->
set_response_compress_type
(
brpc
::
COMPRESS_TYPE_GZIP
);
}
}
LOG
(
INFO
)
<<
"req="
<<
req
->
name
();
res
->
set_message
(
"Hello "
+
req
->
name
());
res
->
set_message
(
"Hello "
+
req
->
name
());
// If an error happens, use controller::set_grpc_error_code to set errors
// If an error happens, use controller::set_grpc_error_code to set errors
// e.g., cntl->set_grpc_error_code(brpc::GRPC_RESOURCEEXHAUSTED, "test grpc message");
// e.g., cntl->set_grpc_error_code(brpc::GRPC_RESOURCEEXHAUSTED, "test grpc message");
...
...
src/brpc/details/http_message.cpp
View file @
4a0927af
...
@@ -225,12 +225,14 @@ int HttpMessage::OnBody(const char *at, const size_t length) {
...
@@ -225,12 +225,14 @@ int HttpMessage::OnBody(const char *at, const size_t length) {
delete
_vmsgbuilder
;
delete
_vmsgbuilder
;
_vmsgbuilder
=
NULL
;
_vmsgbuilder
=
NULL
;
}
else
{
}
else
{
if
(
_
body_length
<
(
size_t
)
FLAGS_http_verbose_max_body_length
)
{
if
(
_
vbodylen
<
(
size_t
)
FLAGS_http_verbose_max_body_length
)
{
int
plen
=
std
::
min
(
length
,
(
size_t
)
FLAGS_http_verbose_max_body_length
int
plen
=
std
::
min
(
length
,
(
size_t
)
FLAGS_http_verbose_max_body_length
-
_body_length
);
-
_vbodylen
);
_vmsgbuilder
->
write
(
at
,
plen
);
std
::
string
str
=
butil
::
ToPrintableString
(
at
,
plen
,
std
::
numeric_limits
<
size_t
>::
max
());
_vmsgbuilder
->
write
(
str
.
data
(),
str
.
size
());
}
}
_
body_length
+=
length
;
_
vbodylen
+=
length
;
}
}
}
}
if
(
_stage
!=
HTTP_ON_BODY
)
{
if
(
_stage
!=
HTTP_ON_BODY
)
{
...
@@ -280,8 +282,8 @@ int HttpMessage::OnBody(const char *at, const size_t length) {
...
@@ -280,8 +282,8 @@ int HttpMessage::OnBody(const char *at, const size_t length) {
int
HttpMessage
::
OnMessageComplete
()
{
int
HttpMessage
::
OnMessageComplete
()
{
if
(
_vmsgbuilder
)
{
if
(
_vmsgbuilder
)
{
if
(
_
body_length
>
(
size_t
)
FLAGS_http_verbose_max_body_length
)
{
if
(
_
vbodylen
>
(
size_t
)
FLAGS_http_verbose_max_body_length
)
{
*
_vmsgbuilder
<<
"
\n
<skipped "
<<
_
body_length
*
_vmsgbuilder
<<
"
\n
<skipped "
<<
_
vbodylen
-
(
size_t
)
FLAGS_http_verbose_max_body_length
<<
" bytes>"
;
-
(
size_t
)
FLAGS_http_verbose_max_body_length
<<
" bytes>"
;
}
}
std
::
cerr
<<
_vmsgbuilder
->
buf
()
<<
std
::
endl
;
std
::
cerr
<<
_vmsgbuilder
->
buf
()
<<
std
::
endl
;
...
@@ -396,7 +398,7 @@ HttpMessage::HttpMessage(bool read_body_progressively)
...
@@ -396,7 +398,7 @@ HttpMessage::HttpMessage(bool read_body_progressively)
,
_body_reader
(
NULL
)
,
_body_reader
(
NULL
)
,
_cur_value
(
NULL
)
,
_cur_value
(
NULL
)
,
_vmsgbuilder
(
NULL
)
,
_vmsgbuilder
(
NULL
)
,
_
body_length
(
0
)
{
,
_
vbodylen
(
0
)
{
http_parser_init
(
&
_parser
,
HTTP_BOTH
);
http_parser_init
(
&
_parser
,
HTTP_BOTH
);
_parser
.
data
=
this
;
_parser
.
data
=
this
;
}
}
...
@@ -534,10 +536,10 @@ std::ostream& operator<<(std::ostream& os, const http_parser& parser) {
...
@@ -534,10 +536,10 @@ std::ostream& operator<<(std::ostream& os, const http_parser& parser) {
// | "CONNECT" ; Section 9.9
// | "CONNECT" ; Section 9.9
// | extension-method
// | extension-method
// extension-method = token
// extension-method = token
void
Serialize
HttpRequest
(
butil
::
IOBuf
*
request
,
void
MakeRaw
HttpRequest
(
butil
::
IOBuf
*
request
,
HttpHeader
*
h
,
HttpHeader
*
h
,
const
butil
::
EndPoint
&
remote_side
,
const
butil
::
EndPoint
&
remote_side
,
const
butil
::
IOBuf
*
content
)
{
const
butil
::
IOBuf
*
content
)
{
butil
::
IOBufBuilder
os
;
butil
::
IOBufBuilder
os
;
os
<<
HttpMethod2Str
(
h
->
method
())
<<
' '
;
os
<<
HttpMethod2Str
(
h
->
method
())
<<
' '
;
const
URI
&
uri
=
h
->
uri
();
const
URI
&
uri
=
h
->
uri
();
...
@@ -611,9 +613,9 @@ void SerializeHttpRequest(butil::IOBuf* request,
...
@@ -611,9 +613,9 @@ void SerializeHttpRequest(butil::IOBuf* request,
// CRLF
// CRLF
// [ message-body ] ; Section 7.2
// [ message-body ] ; Section 7.2
// Status-Line = HTTP-Version SP Status-Code SP Reason-Phrase CRLF
// Status-Line = HTTP-Version SP Status-Code SP Reason-Phrase CRLF
void
Serialize
HttpResponse
(
butil
::
IOBuf
*
response
,
void
MakeRaw
HttpResponse
(
butil
::
IOBuf
*
response
,
HttpHeader
*
h
,
HttpHeader
*
h
,
butil
::
IOBuf
*
content
)
{
butil
::
IOBuf
*
content
)
{
butil
::
IOBufBuilder
os
;
butil
::
IOBufBuilder
os
;
os
<<
"HTTP/"
<<
h
->
major_version
()
<<
'.'
os
<<
"HTTP/"
<<
h
->
major_version
()
<<
'.'
<<
h
->
minor_version
()
<<
' '
<<
h
->
status_code
()
<<
h
->
minor_version
()
<<
' '
<<
h
->
status_code
()
...
...
src/brpc/details/http_message.h
View file @
4a0927af
...
@@ -113,7 +113,7 @@ private:
...
@@ -113,7 +113,7 @@ private:
protected
:
protected
:
// Only valid when -http_verbose is on
// Only valid when -http_verbose is on
butil
::
IOBufBuilder
*
_vmsgbuilder
;
butil
::
IOBufBuilder
*
_vmsgbuilder
;
size_t
_
body_length
;
size_t
_
vbodylen
;
};
};
std
::
ostream
&
operator
<<
(
std
::
ostream
&
os
,
const
http_parser
&
parser
);
std
::
ostream
&
operator
<<
(
std
::
ostream
&
os
,
const
http_parser
&
parser
);
...
@@ -122,17 +122,17 @@ std::ostream& operator<<(std::ostream& os, const http_parser& parser);
...
@@ -122,17 +122,17 @@ std::ostream& operator<<(std::ostream& os, const http_parser& parser);
// header: may be modified in some cases
// header: may be modified in some cases
// remote_side: used when "Host" is absent
// remote_side: used when "Host" is absent
// content: could be NULL.
// content: could be NULL.
void
Serialize
HttpRequest
(
butil
::
IOBuf
*
request
,
void
MakeRaw
HttpRequest
(
butil
::
IOBuf
*
request
,
HttpHeader
*
header
,
HttpHeader
*
header
,
const
butil
::
EndPoint
&
remote_side
,
const
butil
::
EndPoint
&
remote_side
,
const
butil
::
IOBuf
*
content
);
const
butil
::
IOBuf
*
content
);
// Serialize a http response.
// Serialize a http response.
// header: may be modified in some cases
// header: may be modified in some cases
// content: cleared after usage. could be NULL.
// content: cleared after usage. could be NULL.
void
Serialize
HttpResponse
(
butil
::
IOBuf
*
response
,
void
MakeRaw
HttpResponse
(
butil
::
IOBuf
*
response
,
HttpHeader
*
header
,
HttpHeader
*
header
,
butil
::
IOBuf
*
content
);
butil
::
IOBuf
*
content
);
}
// namespace brpc
}
// namespace brpc
...
...
src/brpc/global.cpp
View file @
4a0927af
...
@@ -504,18 +504,6 @@ static void GlobalInitializeOrDieImpl() {
...
@@ -504,18 +504,6 @@ static void GlobalInitializeOrDieImpl() {
}
}
#endif
#endif
// grpc protocol is based on http2
Protocol
grpc_protocol
=
{
ParseH2Message
,
SerializeHttpRequest
,
PackH2Request
,
ProcessHttpRequest
,
ProcessHttpResponse
,
VerifyHttpRequest
,
ParseHttpServerAddress
,
GetHttpMethodName
,
CONNECTION_TYPE_SINGLE
,
"grpc"
};
if
(
RegisterProtocol
(
PROTOCOL_GRPC
,
grpc_protocol
)
!=
0
)
{
exit
(
1
);
}
// Only valid at client side
// Only valid at client side
Protocol
ubrpc_compack_protocol
=
{
Protocol
ubrpc_compack_protocol
=
{
ParseNsheadMessage
,
ParseNsheadMessage
,
...
...
src/brpc/grpc.cpp
View file @
4a0927af
...
@@ -24,6 +24,30 @@
...
@@ -24,6 +24,30 @@
namespace
brpc
{
namespace
brpc
{
const
char
*
GrpcStatusToString
(
GrpcStatus
s
)
{
switch
(
s
)
{
case
GRPC_OK
:
return
"GRPC_OK"
;
case
GRPC_CANCELED
:
return
"GRPC_CANCELED"
;
case
GRPC_UNKNOWN
:
return
"GRPC_UNKNOWN"
;
case
GRPC_INVALIDARGUMENT
:
return
"GRPC_INVALIDARGUMENT"
;
case
GRPC_DEADLINEEXCEEDED
:
return
"GRPC_DEADLINEEXCEEDED"
;
case
GRPC_NOTFOUND
:
return
"GRPC_NOTFOUND"
;
case
GRPC_ALREADYEXISTS
:
return
"GRPC_ALREADYEXISTS"
;
case
GRPC_PERMISSIONDENIED
:
return
"GRPC_PERMISSIONDENIED"
;
case
GRPC_RESOURCEEXHAUSTED
:
return
"GRPC_RESOURCEEXHAUSTED"
;
case
GRPC_FAILEDPRECONDITION
:
return
"GRPC_FAILEDPRECONDITION"
;
case
GPRC_ABORTED
:
return
"GPRC_ABORTED"
;
case
GRPC_OUTOFRANGE
:
return
"GRPC_OUTOFRANGE"
;
case
GRPC_UNIMPLEMENTED
:
return
"GRPC_UNIMPLEMENTED"
;
case
GRPC_INTERNAL
:
return
"GRPC_INTERNAL"
;
case
GRPC_UNAVAILABLE
:
return
"GRPC_UNAVAILABLE"
;
case
GRPC_DATALOSS
:
return
"GRPC_DATALOSS"
;
case
GRPC_UNAUTHENTICATED
:
return
"GRPC_UNAUTHENTICATED"
;
case
GRPC_MAX
:
return
"GRPC_MAX"
;
}
return
"Unknown-GrpcStatus"
;
}
GrpcStatus
ErrorCodeToGrpcStatus
(
int
error_code
)
{
GrpcStatus
ErrorCodeToGrpcStatus
(
int
error_code
)
{
switch
(
error_code
)
{
switch
(
error_code
)
{
case
0
:
case
0
:
...
...
src/brpc/grpc.h
View file @
4a0927af
...
@@ -142,8 +142,11 @@ enum GrpcStatus {
...
@@ -142,8 +142,11 @@ enum GrpcStatus {
GRPC_MAX
,
GRPC_MAX
,
};
};
GrpcStatus
ErrorCodeToGrpcStatus
(
int
error_code
);
// Get description of the error.
const
char
*
GrpcStatusToString
(
GrpcStatus
);
// Convert between error code and grpc status with similar semantics
GrpcStatus
ErrorCodeToGrpcStatus
(
int
error_code
);
int
GrpcStatusToErrorCode
(
GrpcStatus
grpc_status
);
int
GrpcStatusToErrorCode
(
GrpcStatus
grpc_status
);
void
PercentEncode
(
const
std
::
string
&
str
,
std
::
string
*
str_out
);
void
PercentEncode
(
const
std
::
string
&
str
,
std
::
string
*
str_out
);
...
...
src/brpc/http_header.h
View file @
4a0927af
...
@@ -154,8 +154,6 @@ friend void policy::ProcessHttpRequest(InputMessageBase *msg);
...
@@ -154,8 +154,6 @@ friend void policy::ProcessHttpRequest(InputMessageBase *msg);
std
::
string
_content_type
;
std
::
string
_content_type
;
std
::
string
_unresolved_path
;
std
::
string
_unresolved_path
;
std
::
pair
<
int
,
int
>
_version
;
std
::
pair
<
int
,
int
>
_version
;
int
_h2_stream_id
;
H2Error
_h2_error
;
};
};
const
HttpHeader
&
DefaultHttpHeader
();
const
HttpHeader
&
DefaultHttpHeader
();
...
...
src/brpc/options.proto
View file @
4a0927af
...
@@ -47,7 +47,6 @@ enum ProtocolType {
...
@@ -47,7 +47,6 @@ enum ProtocolType {
PROTOCOL_CDS_AGENT
=
24
;
// Client side only
PROTOCOL_CDS_AGENT
=
24
;
// Client side only
PROTOCOL_ESP
=
25
;
// Client side only
PROTOCOL_ESP
=
25
;
// Client side only
PROTOCOL_HTTP2
=
26
;
PROTOCOL_HTTP2
=
26
;
PROTOCOL_GRPC
=
27
;
}
}
enum
CompressType
{
enum
CompressType
{
...
...
src/brpc/policy/http2_rpc_protocol.cpp
View file @
4a0927af
...
@@ -1592,8 +1592,7 @@ size_t H2UnsentRequest::EstimatedByteSize() {
...
@@ -1592,8 +1592,7 @@ size_t H2UnsentRequest::EstimatedByteSize() {
return
sz
;
return
sz
;
}
}
void
H2UnsentRequest
::
Describe
(
butil
::
IOBuf
*
desc
)
const
{
void
H2UnsentRequest
::
Print
(
std
::
ostream
&
os
)
const
{
butil
::
IOBufBuilder
os
;
os
<<
"[ H2 REQUEST @"
<<
butil
::
my_ip
()
<<
" ]
\n
"
;
os
<<
"[ H2 REQUEST @"
<<
butil
::
my_ip
()
<<
" ]
\n
"
;
for
(
size_t
i
=
0
;
i
<
_size
;
++
i
)
{
for
(
size_t
i
=
0
;
i
<
_size
;
++
i
)
{
os
<<
"> "
<<
_list
[
i
].
name
<<
" = "
<<
_list
[
i
].
value
<<
'\n'
;
os
<<
"> "
<<
_list
[
i
].
name
<<
" = "
<<
_list
[
i
].
value
<<
'\n'
;
...
@@ -1613,33 +1612,23 @@ void H2UnsentRequest::Describe(butil::IOBuf* desc) const {
...
@@ -1613,33 +1612,23 @@ void H2UnsentRequest::Describe(butil::IOBuf* desc) const {
if
(
!
body
->
empty
())
{
if
(
!
body
->
empty
())
{
os
<<
">
\n
"
;
os
<<
">
\n
"
;
}
}
os
.
move_to
(
*
desc
);
os
<<
butil
::
BinaryPrinter
(
*
body
,
FLAGS_http_verbose_max_body_length
);
if
(
body
->
size
()
>
(
size_t
)
FLAGS_http_verbose_max_body_length
)
{
size_t
nskipped
=
body
->
size
()
-
(
size_t
)
FLAGS_http_verbose_max_body_length
;
body
->
append_to
(
desc
,
FLAGS_http_verbose_max_body_length
);
if
(
nskipped
)
{
char
str
[
48
];
snprintf
(
str
,
sizeof
(
str
),
"
\n
<skipped %"
PRIu64
" bytes>"
,
nskipped
);
desc
->
append
(
str
);
}
}
else
{
desc
->
append
(
*
body
);
}
}
}
H2UnsentResponse
::
H2UnsentResponse
(
Controller
*
c
,
int
stream_id
,
bool
grpc
)
H2UnsentResponse
::
H2UnsentResponse
(
Controller
*
c
,
int
stream_id
,
bool
is_
grpc
)
:
_size
(
0
)
:
_size
(
0
)
,
_stream_id
(
stream_id
)
,
_stream_id
(
stream_id
)
,
_http_response
(
c
->
release_http_response
())
,
_http_response
(
c
->
release_http_response
())
,
_
grpc
(
grpc
)
{
,
_
is_grpc
(
is_
grpc
)
{
_data
.
swap
(
c
->
response_attachment
());
_data
.
swap
(
c
->
response_attachment
());
if
(
grpc
)
{
if
(
is_
grpc
)
{
_grpc_status
=
ErrorCodeToGrpcStatus
(
c
->
ErrorCode
());
_grpc_status
=
ErrorCodeToGrpcStatus
(
c
->
ErrorCode
());
PercentEncode
(
c
->
ErrorText
(),
&
_grpc_message
);
PercentEncode
(
c
->
ErrorText
(),
&
_grpc_message
);
}
}
}
}
H2UnsentResponse
*
H2UnsentResponse
::
New
(
Controller
*
c
,
int
stream_id
,
bool
grpc
)
{
H2UnsentResponse
*
H2UnsentResponse
::
New
(
Controller
*
c
,
int
stream_id
,
bool
is_
grpc
)
{
const
HttpHeader
*
const
h
=
&
c
->
http_response
();
const
HttpHeader
*
const
h
=
&
c
->
http_response
();
const
CommonStrings
*
const
common
=
get_common_strings
();
const
CommonStrings
*
const
common
=
get_common_strings
();
const
bool
need_content_length
=
const
bool
need_content_length
=
...
@@ -1650,7 +1639,7 @@ H2UnsentResponse* H2UnsentResponse::New(Controller* c, int stream_id, bool grpc)
...
@@ -1650,7 +1639,7 @@ H2UnsentResponse* H2UnsentResponse::New(Controller* c, int stream_id, bool grpc)
+
(
size_t
)
need_content_type
;
+
(
size_t
)
need_content_type
;
const
size_t
memsize
=
offsetof
(
H2UnsentResponse
,
_list
)
+
const
size_t
memsize
=
offsetof
(
H2UnsentResponse
,
_list
)
+
sizeof
(
HPacker
::
Header
)
*
maxsize
;
sizeof
(
HPacker
::
Header
)
*
maxsize
;
H2UnsentResponse
*
msg
=
new
(
malloc
(
memsize
))
H2UnsentResponse
(
c
,
stream_id
,
grpc
);
H2UnsentResponse
*
msg
=
new
(
malloc
(
memsize
))
H2UnsentResponse
(
c
,
stream_id
,
is_
grpc
);
// :status
// :status
if
(
h
->
status_code
()
==
200
)
{
if
(
h
->
status_code
()
==
200
)
{
msg
->
push
(
common
->
H2_STATUS
,
common
->
STATUS_200
);
msg
->
push
(
common
->
H2_STATUS
,
common
->
STATUS_200
);
...
@@ -1720,18 +1709,17 @@ H2UnsentResponse::AppendAndDestroySelf(butil::IOBuf* out, Socket* socket) {
...
@@ -1720,18 +1709,17 @@ H2UnsentResponse::AppendAndDestroySelf(butil::IOBuf* out, Socket* socket) {
butil
::
IOBuf
frag
;
butil
::
IOBuf
frag
;
appender
.
move_to
(
frag
);
appender
.
move_to
(
frag
);
butil
::
IOBufAppender
trailer_appender
;
butil
::
IOBuf
trailer_frag
;
butil
::
IOBuf
trailer_frag
;
if
(
_grpc
)
{
if
(
_
is_
grpc
)
{
HPacker
::
Header
status_header
(
"grpc-status"
,
HPacker
::
Header
status_header
(
"grpc-status"
,
butil
::
string_printf
(
"%d"
,
_grpc_status
));
butil
::
string_printf
(
"%d"
,
_grpc_status
));
hpacker
.
Encode
(
&
trailer_
appender
,
status_header
,
options
);
hpacker
.
Encode
(
&
appender
,
status_header
,
options
);
if
(
!
_grpc_message
.
empty
())
{
if
(
!
_grpc_message
.
empty
())
{
HPacker
::
Header
msg_header
(
"grpc-message"
,
_grpc_message
);
HPacker
::
Header
msg_header
(
"grpc-message"
,
_grpc_message
);
hpacker
.
Encode
(
&
trailer_
appender
,
msg_header
,
options
);
hpacker
.
Encode
(
&
appender
,
msg_header
,
options
);
}
}
appender
.
move_to
(
trailer_frag
);
}
}
trailer_appender
.
move_to
(
trailer_frag
);
PackH2Message
(
out
,
frag
,
trailer_frag
,
_data
,
_stream_id
,
ctx
);
PackH2Message
(
out
,
frag
,
trailer_frag
,
_data
,
_stream_id
,
ctx
);
return
butil
::
Status
::
OK
();
return
butil
::
Status
::
OK
();
...
@@ -1752,8 +1740,7 @@ size_t H2UnsentResponse::EstimatedByteSize() {
...
@@ -1752,8 +1740,7 @@ size_t H2UnsentResponse::EstimatedByteSize() {
return
sz
;
return
sz
;
}
}
void
H2UnsentResponse
::
Describe
(
butil
::
IOBuf
*
desc
)
const
{
void
H2UnsentResponse
::
Print
(
std
::
ostream
&
os
)
const
{
butil
::
IOBufBuilder
os
;
os
<<
"[ H2 RESPONSE @"
<<
butil
::
my_ip
()
<<
" ]
\n
"
;
os
<<
"[ H2 RESPONSE @"
<<
butil
::
my_ip
()
<<
" ]
\n
"
;
for
(
size_t
i
=
0
;
i
<
_size
;
++
i
)
{
for
(
size_t
i
=
0
;
i
<
_size
;
++
i
)
{
os
<<
"> "
<<
_list
[
i
].
name
<<
" = "
<<
_list
[
i
].
value
<<
'\n'
;
os
<<
"> "
<<
_list
[
i
].
name
<<
" = "
<<
_list
[
i
].
value
<<
'\n'
;
...
@@ -1767,18 +1754,7 @@ void H2UnsentResponse::Describe(butil::IOBuf* desc) const {
...
@@ -1767,18 +1754,7 @@ void H2UnsentResponse::Describe(butil::IOBuf* desc) const {
if
(
!
_data
.
empty
())
{
if
(
!
_data
.
empty
())
{
os
<<
">
\n
"
;
os
<<
">
\n
"
;
}
}
os
.
move_to
(
*
desc
);
os
<<
butil
::
BinaryPrinter
(
_data
,
FLAGS_http_verbose_max_body_length
);
if
(
_data
.
size
()
>
(
size_t
)
FLAGS_http_verbose_max_body_length
)
{
size_t
nskipped
=
_data
.
size
()
-
(
size_t
)
FLAGS_http_verbose_max_body_length
;
_data
.
append_to
(
desc
,
FLAGS_http_verbose_max_body_length
);
if
(
nskipped
)
{
char
str
[
48
];
snprintf
(
str
,
sizeof
(
str
),
"
\n
<skipped %"
PRIu64
" bytes>"
,
nskipped
);
desc
->
append
(
str
);
}
}
else
{
desc
->
append
(
_data
);
}
}
}
void
PackH2Request
(
butil
::
IOBuf
*
,
void
PackH2Request
(
butil
::
IOBuf
*
,
...
@@ -1806,9 +1782,7 @@ void PackH2Request(butil::IOBuf*,
...
@@ -1806,9 +1782,7 @@ void PackH2Request(butil::IOBuf*,
*
user_message
=
h2_req
;
*
user_message
=
h2_req
;
if
(
FLAGS_http_verbose
)
{
if
(
FLAGS_http_verbose
)
{
butil
::
IOBuf
desc
;
std
::
cerr
<<
*
h2_req
<<
std
::
endl
;
h2_req
->
Describe
(
&
desc
);
std
::
cerr
<<
desc
<<
std
::
endl
;
}
}
}
}
...
...
src/brpc/policy/http2_rpc_protocol.h
View file @
4a0927af
...
@@ -135,7 +135,7 @@ friend void PackH2Request(butil::IOBuf*, SocketMessage**,
...
@@ -135,7 +135,7 @@ friend void PackH2Request(butil::IOBuf*, SocketMessage**,
Controller
*
,
const
butil
::
IOBuf
&
,
const
Authenticator
*
);
Controller
*
,
const
butil
::
IOBuf
&
,
const
Authenticator
*
);
public
:
public
:
static
H2UnsentRequest
*
New
(
Controller
*
c
);
static
H2UnsentRequest
*
New
(
Controller
*
c
);
void
Describe
(
butil
::
IOBuf
*
)
const
;
void
Print
(
std
::
ostream
&
)
const
;
int
AddRefManually
()
int
AddRefManually
()
{
return
_nref
.
fetch_add
(
1
,
butil
::
memory_order_relaxed
);
}
{
return
_nref
.
fetch_add
(
1
,
butil
::
memory_order_relaxed
);
}
...
@@ -194,9 +194,9 @@ private:
...
@@ -194,9 +194,9 @@ private:
class
H2UnsentResponse
:
public
SocketMessage
{
class
H2UnsentResponse
:
public
SocketMessage
{
public
:
public
:
static
H2UnsentResponse
*
New
(
Controller
*
c
,
int
stream_id
,
bool
grpc
);
static
H2UnsentResponse
*
New
(
Controller
*
c
,
int
stream_id
,
bool
is_
grpc
);
void
Destroy
();
void
Destroy
();
void
Describe
(
butil
::
IOBuf
*
)
const
;
void
Print
(
std
::
ostream
&
)
const
;
// @SocketMessage
// @SocketMessage
butil
::
Status
AppendAndDestroySelf
(
butil
::
IOBuf
*
out
,
Socket
*
)
override
;
butil
::
Status
AppendAndDestroySelf
(
butil
::
IOBuf
*
out
,
Socket
*
)
override
;
size_t
EstimatedByteSize
()
override
;
size_t
EstimatedByteSize
()
override
;
...
@@ -208,7 +208,7 @@ private:
...
@@ -208,7 +208,7 @@ private:
void
push
(
const
std
::
string
&
name
,
const
std
::
string
&
value
)
void
push
(
const
std
::
string
&
name
,
const
std
::
string
&
value
)
{
new
(
&
_list
[
_size
++
])
HPacker
::
Header
(
name
,
value
);
}
{
new
(
&
_list
[
_size
++
])
HPacker
::
Header
(
name
,
value
);
}
H2UnsentResponse
(
Controller
*
c
,
int
stream_id
,
bool
grpc
);
H2UnsentResponse
(
Controller
*
c
,
int
stream_id
,
bool
is_
grpc
);
~
H2UnsentResponse
()
{}
~
H2UnsentResponse
()
{}
H2UnsentResponse
(
const
H2UnsentResponse
&
);
H2UnsentResponse
(
const
H2UnsentResponse
&
);
void
operator
=
(
const
H2UnsentResponse
&
);
void
operator
=
(
const
H2UnsentResponse
&
);
...
@@ -218,7 +218,7 @@ private:
...
@@ -218,7 +218,7 @@ private:
uint32_t
_stream_id
;
uint32_t
_stream_id
;
std
::
unique_ptr
<
HttpHeader
>
_http_response
;
std
::
unique_ptr
<
HttpHeader
>
_http_response
;
butil
::
IOBuf
_data
;
butil
::
IOBuf
_data
;
bool
_grpc
;
bool
_
is_
grpc
;
GrpcStatus
_grpc_status
;
GrpcStatus
_grpc_status
;
std
::
string
_grpc_message
;
std
::
string
_grpc_message
;
HPacker
::
Header
_list
[
0
];
HPacker
::
Header
_list
[
0
];
...
@@ -409,6 +409,15 @@ inline bool H2Context::RunOutStreams() const {
...
@@ -409,6 +409,15 @@ inline bool H2Context::RunOutStreams() const {
return
(
_last_client_stream_id
>
0x7FFFFFFF
);
return
(
_last_client_stream_id
>
0x7FFFFFFF
);
}
}
inline
std
::
ostream
&
operator
<<
(
std
::
ostream
&
os
,
const
H2UnsentRequest
&
req
)
{
req
.
Print
(
os
);
return
os
;
}
inline
std
::
ostream
&
operator
<<
(
std
::
ostream
&
os
,
const
H2UnsentResponse
&
res
)
{
res
.
Print
(
os
);
return
os
;
}
}
// namespace policy
}
// namespace policy
}
// namespace brpc
}
// namespace brpc
...
...
src/brpc/policy/http_rpc_protocol.cpp
View file @
4a0927af
This diff is collapsed.
Click to expand it.
src/brpc/policy/http_rpc_protocol.h
View file @
4a0927af
...
@@ -41,7 +41,6 @@ struct CommonStrings {
...
@@ -41,7 +41,6 @@ struct CommonStrings {
std
::
string
ACCEPT_ENCODING
;
std
::
string
ACCEPT_ENCODING
;
std
::
string
CONTENT_ENCODING
;
std
::
string
CONTENT_ENCODING
;
std
::
string
CONTENT_LENGTH
;
std
::
string
CONTENT_LENGTH
;
std
::
string
IDENTITY
;
std
::
string
GZIP
;
std
::
string
GZIP
;
std
::
string
CONNECTION
;
std
::
string
CONNECTION
;
std
::
string
KEEP_ALIVE
;
std
::
string
KEEP_ALIVE
;
...
@@ -69,6 +68,7 @@ struct CommonStrings {
...
@@ -69,6 +68,7 @@ struct CommonStrings {
std
::
string
TRAILERS
;
std
::
string
TRAILERS
;
std
::
string
GRPC_ENCODING
;
std
::
string
GRPC_ENCODING
;
std
::
string
GRPC_ACCEPT_ENCODING
;
std
::
string
GRPC_ACCEPT_ENCODING
;
std
::
string
GRPC_ACCEPT_ENCODING_VALUE
;
std
::
string
GRPC_STATUS
;
std
::
string
GRPC_STATUS
;
std
::
string
GRPC_MESSAGE
;
std
::
string
GRPC_MESSAGE
;
...
@@ -77,8 +77,8 @@ struct CommonStrings {
...
@@ -77,8 +77,8 @@ struct CommonStrings {
// Used in UT.
// Used in UT.
class
HttpContext
:
public
ReadableProgressiveAttachment
class
HttpContext
:
public
ReadableProgressiveAttachment
,
public
InputMessageBase
,
public
InputMessageBase
,
public
HttpMessage
{
,
public
HttpMessage
{
public
:
public
:
HttpContext
(
bool
read_body_progressively
=
false
)
HttpContext
(
bool
read_body_progressively
=
false
)
:
InputMessageBase
()
:
InputMessageBase
()
...
@@ -138,13 +138,14 @@ enum HttpContentType {
...
@@ -138,13 +138,14 @@ enum HttpContentType {
HTTP_CONTENT_OTHERS
=
0
,
HTTP_CONTENT_OTHERS
=
0
,
HTTP_CONTENT_JSON
=
1
,
HTTP_CONTENT_JSON
=
1
,
HTTP_CONTENT_PROTO
=
2
,
HTTP_CONTENT_PROTO
=
2
,
HTTP_CONTENT_GRPC
=
3
};
};
HttpContentType
ParseContentType
(
butil
::
StringPiece
content_type
);
// Parse from the textual content type. One type may have more than one literals.
// Returns a numerical type. *is_grpc_ct is set to true if the content-type is
// set by gRPC.
HttpContentType
ParseContentType
(
butil
::
StringPiece
content_type
,
bool
*
is_grpc_ct
);
}
// namespace policy
}
// namespace policy
}
// namespace brpc
}
// namespace brpc
#endif // BRPC_POLICY_HTTP_RPC_PROTOCOL_H
#endif // BRPC_POLICY_HTTP_RPC_PROTOCOL_H
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment