-
Notifications
You must be signed in to change notification settings - Fork 251
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
doc: sync User Guide to Generic Call for Streaming (#1179)
Co-authored-by: Marina-Sakai <[email protected]>
- Loading branch information
1 parent
b5e2299
commit 3b753db
Showing
1 changed file
with
34 additions
and
8 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,18 +1,14 @@ | ||
--- | ||
title: "User Guide to Generic Call for Streaming [on trial]" | ||
title: "User Guide to Generic Call for Streaming" | ||
date: 2024-09-19 | ||
weight: 6 | ||
keywords: ["User Guide to Generic Call for Streaming [on trial]"] | ||
keywords: ["User Guide to Generic Call for Streaming"] | ||
description: "" | ||
--- | ||
|
||
## Introduction | ||
|
||
JSON generic call for streaming interfaces is now supported (client-side only). | ||
|
||
**However, due to the ongoing restructuring of the streaming interface to improve the user experience and to avoid making any breaking changes after release, the feature's official release is temporarily on hold. If you have a need for this feature, you can refer to the following to try it out. Please note that once it is officially released, a small adjustment may be required on your end**. | ||
|
||
Please try the feature with kitex test branch test/grpc_json_streaming_generic by `go get github.com/cloudwego/kitex@test/grpc_json_streaming_generic`. | ||
**JSON generic call for streaming interfaces is now supported (client-side only) from Kitex v0.12.0**. | ||
|
||
## Usage | ||
|
||
|
@@ -54,6 +50,10 @@ The four methods included in the example IDL correspond to four scenarios: | |
First of all, please initialize the streaming client. Here is an example of streaming client initialization. | ||
|
||
```go | ||
import ( | ||
dproto "github.com/cloudwego/dynamicgo/proto" | ||
) | ||
|
||
dOpts := dproto.Options{} // you can specify parsing options as you want | ||
p, err := generic.NewPbFileProviderWithDynamicGo(your_idl, ctx, dOpts) | ||
// create json pb generic | ||
|
@@ -102,7 +102,7 @@ The four methods included in the example IDL correspond to four scenarios: | |
Here is an example of streaming client initialization. | ||
|
||
```go | ||
p, err := generic.generic.NewThriftFileProvider(your_idl_path) | ||
p, err := generic.NewThriftFileProvider(your_idl_path) | ||
/* | ||
// if you use dynamicgo | ||
p, err := generic.NewThriftFileProviderWithDynamicGo(idl) | ||
|
@@ -225,3 +225,29 @@ Example: | |
resp, err := cli.GenericCall(ctx, "UnaryEcho", `{"message": "unary request"}`) | ||
strResp, ok := resp.(string) // response is json string | ||
``` | ||
|
||
## FAQ | ||
|
||
### Recv() got err: rpc error: code = 12 desc = Method not found! | ||
|
||
This error occurs when calling with Kitex **protobuf** generic streaming when the downstream is **gRPC-python** (gRPC libraries for other languages may also have this problem). | ||
|
||
The root cause is that Kitex does not parse the package in the protobuf idl, so the package part of `:path` in the gPRC request is missing, and gRPC-python can't find the corresponding method. | ||
|
||
e.g. | ||
|
||
- normal client | ||
|
||
`:path` - /search.gpt_engine.GPTStreamService/GPTGeneration | ||
|
||
- protobuf generic client | ||
|
||
`:path` - /GPTStreamService/GPTGeneration | ||
|
||
#### Solution | ||
|
||
Use the following branch to solve it and wait for the official release of Kitex v1.18.1 to fix this issue. | ||
|
||
```shell | ||
go get -u github.com/cloudwego/[email protected] | ||
``` |