- Create distributed services without writing extra code.
- Provides cluster support and integrate with popular service discovery services like Zookeeper.
- Supports advanced scheduling features like weighted load-balance, scheduling cross IDCs, etc.
- Optimization for high load scenarios, provides high availability in production environment.
- Supports both synchronous and asynchronous calls.
- Support cross-language interactive with Golang, PHP, Lua(Luajit), etc.
The minimum requirements to run the quick start are:
- Add dependencies to pom.
<dependency>
<groupId>com.tbkk.yoyo</groupId>
<artifactId>yoyo-all</artifactId>
<version>1.0.1-SNAPSHOT</version>
</dependency>
-
Create an interface for both service provider and consumer.
com.tbkk.yoyo.rpc.sample.api
package com.tbkk.yoyo.rpc.sample.api; import com.tbkk.yoyo.rpc.sample.api.dto.UserDTO; /** * Demo API */ public interface IRpcTestService { public UserDTO sayHi(String name); }
-
Write an implementation, create and start RPC Server.
com.tbkk.yoyo.rpc.sample.server.service.IRpcTestServiceImpl.java
package com.tbkk.yoyo.rpc.sample.server.service; import com.tbkk.yoyo.rpc.sample.api.IRpcTestService; import com.tbkk.yoyo.rpc.sample.api.dto.UserDTO; import com.tbkk.yoyo.rpc.springsupport.annotation.YoyoRpcService; import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Service; import java.text.MessageFormat; import java.time.LocalDateTime; /** * @author tbkk */ @YoyoRpcService @Service @Slf4j public class IRpcTestServiceImpl implements IRpcTestService { @Override public UserDTO sayHi(String name) { String word = MessageFormat.format("Hi {0}, from {1} as {2}", name, IRpcTestServiceImpl.class.getName(), LocalDateTime.now().toString()); if ("error".equalsIgnoreCase(name)){ throw new RuntimeException("test exception."); } UserDTO userDTO = new UserDTO(name, word); log.info(userDTO.toString()); return userDTO; } }
com.tbkk.yoyo.rpc.sample.server.conf.YoyoRpcSpringProviderFactory.java
@Configuration @Slf4j public class YoyoRpcProviderConfig { @Value("${yoyo-rpc.registry.address}") private String address; @Value("${yoyo-rpc.registry.env}") private String env; @Bean public YoyoRpcSpringProviderFactory yoyoRpcSpringProviderFactory() { RegisterCenter registerCenter = new ZkRegisterCenter(); registerCenter.setRegisterParam(new HashMap<String, String>(){{ put(ZkRegisterCenter.ZK_ADDRESS, address); put(ZkRegisterCenter.ENV, env); }}); YoyoRpcProviderFactory yoyoRpcProviderFactory = new YoyoRpcProviderFactory(registerCenter); log.info(" yoyo-rpc provider config init finish."); return new YoyoRpcSpringProviderFactory(yoyoRpcProviderFactory); } }
yoyo-rpc: registry: address: 127.0.0.1:2181 env: dev
-
Create and start RPC Client.
yoyo-rpc: registry: address: 127.0.0.1:2181 env: dev
com.tbkk.yoyo.rpc.sample.client.conf.YoyoRpcInvokerConfig.java
@Configuration @Slf4j public class YoyoRpcInvokerConfig { @Value("${yoyo-rpc.registry.address}") private String address; @Value("${yoyo-rpc.registry.env}") private String env; @Bean public YoyoRpcSpringInvokerFactory yoyoJobExecutor() { RegisterCenter registerCenter = new ZkRegisterCenter(); registerCenter.setRegisterParam(new HashMap<String, String>(){{ put(ZkRegisterCenter.ZK_ADDRESS, address); put(ZkRegisterCenter.ENV, env); }}); YoyoRpcInvokerFactory yoyoRpcInvokerFactory = new YoyoRpcInvokerFactory(registerCenter); YoyoRpcSpringInvokerFactory invokerFactory = new YoyoRpcSpringInvokerFactory(yoyoRpcInvokerFactory); log.info(" yoyo-rpc invoker config init finish."); return invokerFactory; } }
Execute main function in Client will invoke the remote service and print response.
```java
@RestController
@RequestMapping("/rpc-test")
@Slf4j
@Api("测试命令")
public class IndexController {
@YoyoRpcReference
private IRpcTestService rpcTestService;
@ResponseBody
@ApiOperation(value = "rpc测试")
@RequestMapping(value = "/doTest", method = RequestMethod.POST)
public UserDTO http(String name) {
long startTime = System.currentTimeMillis();
try {
for (int i = 0; i < 999; i++)
{
rpcTestService.sayHi(name);
}
UserDTO userDTO = rpcTestService.sayHi(name);
long spendTime = System.currentTimeMillis() - startTime;
log.info("##: {}, doTest finished Spend Time{} ", name, spendTime);
return userDTO;
} catch (Exception e) {
e.printStackTrace();
return new UserDTO("", e.getMessage());
}
}
}
```
- tbkk(@tbkk) 极简.易用;
Motan is released under the Apache License 2.0.