pingcap / kvproto

Protocol buffer files for TiKV

Repository from Github https://github.compingcap/kvprotoRepository from Github https://github.compingcap/kvproto

Consider using Buf to manage Protobuf and its artifact

spencercjh opened this issue · comments

I've been following the pingcap community on Twitter for a long time, but only briefly know some active developers. I am not familiar with developing databases but gRPC services and using Protobuf.

I find there is huge space for improvement in the way to manage Protobuf from TiSpark.

Use buf to manage protobuf codes instead of raw git clone operations and protoc code generation scripts.

With BSR, Go's Protobuf dependency reference becomes very simple with one line like this(it's an internal example in our team):

image

With another language like Java, working with Java BSR plugin, you can generate Java codes from Protobuf without protoc directly and publish the artifact to a repository like Maven Center or GitHub Package then depend on it with Maven or Gradle.

image

image

I am not a lobbyist for Buf. I'm writing this Issue due to my curiosity about the pingcap team and my enthusiasm for your community. And I am a newbee to open source, I want to participate in some very COOL open source communities.

Our team has been using gRPC for years, following the work of the community about gRPC and Protobuf like Envoy,AIP and Buf. Because of dependencies from other technical teams, we used to look at how we could better maintain and use Protobuf and its artifact using Bazel. Buf is a lighter-weight solution that fits the Go language perfectly compared to Bazel.

If you are interested in learning about it and find it meaningful and useful, I am willing to contribute.

Due to the community ecology and target orientation, Buf has the best support for Go languages and JS/TS, and other languages will be weaker.

I believe the more communities like pingcap use Buf, the better Buf will become, and the more people/organizations using gRPC and Protobuf in China will grow. We will be able to gain a better development experience.