The triple protocol implemented by Dubbo offers better usability (not binding Protobuf), allowing developers to directly define services using Java interfaces. For users expecting a smooth upgrade, with no multilingual services, or unfamiliar with Protobuf, the Java interface approach is the simplest way to use triple.
The following details the underlying serialization specifics in this protocol model: the framework will wrap the request and response using a built-in protobuf object, which means the object will be serialized twice. The first serialization is done using the method specified by serialization=hessian, and the second is to wrap the byte[] serialized in the first step with the protobuf wrapper before transmission.
When using Java interface method development for triple communication services, the dubbo server will automatically enable support for protobuf and protobuf-json serialization modes.
To use the triple protocol, you must first add the following dependencies:
<dependencies>
	<dependency>
		<groupId>com.google.protobuf</groupId>
		<artifactId>protobuf-java</artifactId>
		<version>3.19.6</version>
	</dependency>
	<!-- Providing support for protobuf-json formatted requests -->
	<dependency>
		<groupId>com.google.protobuf</groupId>
		<artifactId>protobuf-java-util</artifactId>
		<version>3.19.6</version>
	</dependency>
</dependencies>
As long as you use the Java interface method for the triple protocol, protobuf wrapper serialization will be used, simply define the Java interface and enable the triple protocol:
Define Dubbo service via Java interface:
public interface GreetingsService {
    String sayHi(String name);
}
Configure to use the triple protocol (if you need to set the underlying serialization protocol, continue setting serialization, such as hessian, msgpack, etc.):
# application.yml (Spring Boot)
dubbo:
 protocol:
   name: tri
   serialization: hessian
or
# dubbo.properties
dubbo.protocol.name=tri
dubbo.protocol.serialization=hessian
or
<dubbo:protocol name="tri" serialization="hessian"/>