sofa-bolt-go 是 bolt 1.0/2.0 serialization protocol 以及 TBRemoting 的 Golang 实现,包含了客户端/服务端/编解码。
sofa-bolt-go 提供三种类型的 API:
- command: 编解码 bolt 1.0/2.0 以及 TaobaoRemoting 协议。
- client: 发送请求并接受响应,同时也支持接受请求并写会响应。
- server: 解析请求并写会响应.
See client_server_example_test.go
See client_server_example_test.go
make build
或者 go get github.com/sofastack/sofa-bolt-go/cmd/bolt
bin/bolt decode 0100000200000000020000c80000000a0000000b0000000131000000013168656c6c6f20776f726c64
bin/bolt decodeheader 00000018736f66615f686561645f7461726765745f736572766963650000001048656c6c6f536572766963653a312e300000001b7270635f74726163655f636f6e746578742e736f666152706349640000000130000000167270635f74726163655f636f6e746578742e73616d700000000566616c73650000001d7270635f74726163655f636f6e746578742e736f6661547261636549640000001e6139666531363839313537313239333033373932323130313233383031330000001f7270635f74726163655f636f6e746578742e736f666143616c6c6572496463000000000000001e7270635f74726163655f636f6e746578742e736f666143616c6c65724970000000000000001e7270635f74726163655f636f6e746578742e736f666150656e417474727300000000000000207270635f74726163655f636f6e746578742e736f666143616c6c65725a6f6e650000000000000014736f66615f686561645f7461726765745f617070000000000000000870726f746f636f6c00000004626f6c7400000007736572766963650000001048656c6c6f536572766963653a312e300000001d7270635f74726163655f636f6e746578742e73797350656e4174747273000000000000001f7270635f74726163655f636f6e746578742e736f666143616c6c65724170700000000000000015736f66615f686561645f6d6574686f645f6e616d650000000873617948656c6c6f
pkg: github.com/sofastack/sofa-bolt-go/sofabolt
BenchmarkClientConcurrent-8 522289 1996 ns/op 0 B/op 0 allocs/op
BenchmarkClient-8 281299 3987 ns/op 0 B/op 0 allocs/op
BenchmarkReadTBRemotingRequest/request-8 431926 2385 ns/op 384 B/op 19 allocs/op
BenchmarkReadTBRemotingRequest/command-8 8268426 145 ns/op 0 B/op 0 allocs/op
BenchmarkWriteRequest-8 29614092 39.3 ns/op 0 B/op 0 allocs/op
BenchmarkWriteResponse-8 17844903 64.0 ns/op 0 B/op 0 allocs/op
BenchmarkServer/1_connection-8 2368573 505 ns/op 0 B/op 0 allocs/op
BenchmarkServer/128_connection-8 1862937 786 ns/op 0 B/op 0 allocs/op
BenchmarkServer/512_connection-8 3341610 343 ns/op 0 B/op 0 allocs/op
BenchmarkServer/1024_connection-8 5492541 212 ns/op 0 B/op 0 allocs/op