Skip to content
This repository has been archived by the owner on Aug 17, 2020. It is now read-only.

pleuvoir/pikaq

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

51 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

pikaq

HitCount GitHub issues License Maven Central Download

介绍

本项目是对网络通信框架netty、akka的封装,方便使用。

特性

  • 序列化与反序列化器
  • 基础通信模型
  • 自动断连和重连
  • 心跳
  • 自定义通讯协议
  • 自定义业务处理器
  • 异步业务线程

快速开始

引入依赖

<dependency>
  <groupId>io.github.pleuvoir</groupId>
  <artifactId>pikaq</artifactId>
  <version>${latest.version}</version>
</dependency>

基础

命令

项目中定义的通信基本单元为RemoteCommand,业务方可通过继承RemoteBaseCommand实现自己的远程命令,为了方便起见目前加载全路径下实现类,只需要提供实现类即可。如:

public class RpcRequest extends RemoteBaseCommand{

	@Override
	public boolean responsible() {
		return true;
	}

	@Override
	public int requestCode() {
		return 55;
	}

	@Override
	public RemotingCommandType remotingCommandType() {
		return RemotingCommandType.REQUEST_COMMAND;
	}

}
public class RpcResponse extends RemoteBaseCommand {

	@Getter
	@Setter
	private String payload;
	
	@Override
	public boolean responsible() {
		return false;
	}

	@Override
	public int requestCode() {
		return -55;
	}

	@Override
	public RemotingCommandType remotingCommandType() {
		return RemotingCommandType.RESPONSE_COMMAND;
	}

}

注意,消息类型决定了接收到消息后的处理方式。当RemotingCommandTypeREQUEST_COMMAND时,处理器会进行异步处理,如果responsibletrue,那么处理器会将返回的结果冲刷到远程对端节点;当RemotingCommandTypeRESPONSE_COMMAND时,一般而言代表之前的一次请求命令现在响应过来了,如果之前的请求命令有回调会异步执行回调并结束此次流程。

命令处理器

框架通过requestCode匹配到对应的处理器。所有的指令处理都通过实现RemotingRequestProcessor接口进行处理,RemotingServer提供了方法进行注册。

通信模型

async、sync、oneway

消息处理使用Akka作为业务线程池进行异步处理。

示例

public static void main(String[] args) {

	SimpleServer simpleServer = new SimpleServer(ServerConfig.create(8888));

	// 注册业务处理器 requestCode=55
	simpleServer.registerHandler(55, new RemotingRequestProcessor<RpcRequest, RpcResponse>() {

		@Override
		public RpcResponse handler(ChannelHandlerContext ctx, RpcRequest request) {
			RpcResponse rpcResponse = new RpcResponse();
			rpcResponse.setPayload("hello rpc");
			return rpcResponse;
		}
	});

	simpleServer.start();
}
public static void main(String[] args) throws RemotingSendRequestException, RemotingTimeoutException {

	//设置为0则关闭了心跳
	SimpleClient simpleClient = new SimpleClient(ClientConfig.create().heartbeatIntervalSeconds(0).build());

	String addr = "127.0.0.1:8888";
	String addr2 = "127.0.0.1:8888";

	// 批量连接多个不同的地址,连接过程中会进行重试,一般是为了预先连接而使用;如果有一个连接失败则停止
	simpleClient.connectWithRetry(addr, addr2);

	RpcRequest rpcRequest = new RpcRequest();

	// onway
	simpleClient.invokeOneway(addr, rpcRequest);

	// 同步调用
	RemotingCommand response = simpleClient.invokeSync(addr, rpcRequest, 1000);
	System.out.println(response.toJSON());

	// 异步回调
	simpleClient.invokeAsync(addr, rpcRequest, new InvokeCallback() {
		@Override
		public void onRequestException(RemotingFuture remotingFuture) {
			System.err.println("onRequestException .. " + remotingFuture.getBeginTimestamp());
		}

		@Override
		public void onReceiveResponse(RemotingFuture remotingFuture) {
			System.out.println("onReceiveResponse .. " + remotingFuture.getResponseCommand());
		}
	});

	simpleClient.shutdown();
}

About

基于netty和akka的通信层框架

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published