mirror of
https://github.com/go-micro/go-micro.git
synced 2025-01-05 10:20:53 +02:00
93ba8cd0df
* 1.fix plugins go get bug. 2.update all mode. 3.add tidy tools * continue fix pre version go get bug that unknown v3.5.1 |
||
---|---|---|
.. | ||
codec.go | ||
go.mod | ||
go.sum | ||
README.md | ||
rpc_test.go | ||
rpc.go |
MsgPack RPC Codec
Usage
Import the codec and set within the client/server
package main
import (
"github.com/asim/go-micro/plugins/codec/msgpackrpc"
"github.com/asim/go-micro/v3"
"github.com/micro/go-micro/client"
"github.com/micro/go-micro/server"
)
func main() {
client := client.NewClient(
client.Codec("application/msgpack", msgpackrpc.NewCodec),
client.ContentType("application/msgpack"),
)
server := server.NewServer(
server.Codec("application/msgpack", msgpackrpc.NewCodec),
)
service := micro.NewService(
micro.Client(client),
micro.Server(server),
)
// ...
}
Generating Request/Response types
The msgpack codec is much like protobuf. It expects the request/response types to conform to a specific interface. Usually this means defining some IDL and generating the required types.
Learn how to do that at github.com/tinylib/msgp