Skip to content

自定义rpc框架,支持Java序列化和protobuf序列化协议,多种负载均衡算法

Notifications You must be signed in to change notification settings

rcllong/rpc-spring-boot-starter

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 

Repository files navigation

rpc-spring-boot-starter

利用netty实现的rpc框架

  • 支持Java序列化和protobuf序列化协议
  • 支持多种客户端负载均衡(随机、轮询、加权轮询和平滑加权轮询)算法

使用方法

  1. 下载代码到本地
git clone https://github.com/2YSP/rpc-spring-boot-starter.git
  1. 打包到本地
mvn  clean install -DskipTests=true
  1. 添加maven依赖到你的项目中
  <dependency>
           <groupId>cn.sp.rpc</groupId>
           <artifactId>rpc-spring-boot-starter</artifactId>
           <version>1.0.0-SNAPSHOT</version>
       </dependency>

客户端

使用@InjectService注解注入远程方法

@RestController
@RequestMapping("test")
public class TestController {

   @InjectService
   private UserService userService;

   @GetMapping("/user")
   public ApiResult<User> getUser(@RequestParam("id")Long id){
       return userService.getUser(id);
   }
}

配置项:

属性 含义 可选项
sp.rpc.protocol 消息序列化协议 java,protobuf,kryo
sp.rpc.register-address 注册中心地址 默认localhost:2181
sp.rpc.load-balance 负载均衡算法 random
round
weightRound
smoothWeightRound

服务端

提供远程方法并注入IOC

import cn.sp.rpc.annotation.Service;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

@Service
public class UserServiceImpl implements UserService{

   private static  Logger logger = LoggerFactory.getLogger(UserService.class);


   @Override
   public ApiResult<User> getUser(Long id) {
       logger.info("现在是【2】号提供服务");
       User user = new User(1L,"XX",2,"www.aa.com");
       return ApiResult.success(user);
   }
}

注意: 这里的@Service注解不是Spring的。

配置项:

属性 含义 可选项
sp.rpc.protocol 消息序列化协议 java,protobuf,kryo
sp.rpc.register-address 注册中心地址 默认localhost:2181
sp.rpc.server-port 服务端通信端口号 默认9999
sp.rpc.weight 权重 默认1

用法 demo https://github.com/2YSP/rpc-example

About

自定义rpc框架,支持Java序列化和protobuf序列化协议,多种负载均衡算法

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 100.0%