mirror of https://github.com/longtai-cn/hippo4j
parent
a0c72defcb
commit
6f6ad9e01d
@ -0,0 +1,39 @@
|
||||
package cn.hippo4j.console.netty;
|
||||
|
||||
import cn.hippo4j.common.monitor.Message;
|
||||
import cn.hippo4j.common.monitor.MessageWrapper;
|
||||
import cn.hippo4j.common.toolkit.MessageConvert;
|
||||
import cn.hippo4j.config.monitor.QueryMonitorExecuteChoose;
|
||||
import io.netty.channel.ChannelHandlerContext;
|
||||
import io.netty.channel.SimpleChannelInboundHandler;
|
||||
import lombok.AllArgsConstructor;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
|
||||
|
||||
/**
|
||||
* ServerHandler
|
||||
*
|
||||
* @author lk
|
||||
* @date 2022/06/18
|
||||
*/
|
||||
@Slf4j
|
||||
@AllArgsConstructor
|
||||
public class ServerHandler extends SimpleChannelInboundHandler<MessageWrapper> {
|
||||
|
||||
private QueryMonitorExecuteChoose queryMonitorExecuteChoose;
|
||||
|
||||
private ThreadPoolTaskExecutor monitorThreadPoolTaskExecutor;
|
||||
|
||||
@Override
|
||||
protected void channelRead0(ChannelHandlerContext ctx, MessageWrapper msg) throws Exception {
|
||||
Runnable task = () -> {
|
||||
Message message = MessageConvert.convert(msg);
|
||||
queryMonitorExecuteChoose.chooseAndExecute(message);
|
||||
};
|
||||
try {
|
||||
monitorThreadPoolTaskExecutor.execute(task);
|
||||
} catch (Exception ex) {
|
||||
log.error("Monitoring data insertion database task overflow.", ex);
|
||||
}
|
||||
}
|
||||
}
|
@ -0,0 +1,31 @@
|
||||
package cn.hippo4j.springboot.starter.config;
|
||||
|
||||
import cn.hippo4j.springboot.starter.monitor.netty.NettyConnectSender;
|
||||
import cn.hippo4j.springboot.starter.monitor.send.MessageSender;
|
||||
import cn.hippo4j.springboot.starter.remote.ServerNettyAgent;
|
||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
|
||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
|
||||
import org.springframework.boot.context.properties.EnableConfigurationProperties;
|
||||
import org.springframework.context.annotation.Bean;
|
||||
import org.springframework.context.annotation.Configuration;
|
||||
|
||||
/**
|
||||
* Netty ClientCon figuration
|
||||
*
|
||||
* @author lk
|
||||
* @date 2022/6/18
|
||||
*/
|
||||
@ConditionalOnProperty(prefix = BootstrapProperties.PREFIX, name = "report-type", matchIfMissing = false, havingValue = "netty")
|
||||
public class NettyClientConfiguration {
|
||||
|
||||
@Bean
|
||||
@SuppressWarnings("all")
|
||||
public ServerNettyAgent serverNettyAgent(BootstrapProperties properties) {
|
||||
return new ServerNettyAgent(properties);
|
||||
}
|
||||
|
||||
@Bean
|
||||
public MessageSender nettyConnectSender(ServerNettyAgent serverNettyAgent){
|
||||
return new NettyConnectSender(serverNettyAgent);
|
||||
}
|
||||
}
|
@ -0,0 +1,60 @@
|
||||
package cn.hippo4j.springboot.starter.monitor.netty;
|
||||
|
||||
import cn.hippo4j.common.monitor.Message;
|
||||
import cn.hippo4j.common.monitor.MessageWrapper;
|
||||
import cn.hippo4j.common.toolkit.MessageConvert;
|
||||
import cn.hippo4j.springboot.starter.monitor.send.MessageSender;
|
||||
import cn.hippo4j.springboot.starter.remote.ServerNettyAgent;
|
||||
import io.netty.bootstrap.Bootstrap;
|
||||
import io.netty.channel.ChannelInitializer;
|
||||
import io.netty.channel.ChannelPipeline;
|
||||
import io.netty.channel.EventLoopGroup;
|
||||
import io.netty.channel.socket.SocketChannel;
|
||||
import io.netty.channel.socket.nio.NioSocketChannel;
|
||||
import io.netty.handler.codec.serialization.ClassResolvers;
|
||||
import io.netty.handler.codec.serialization.ObjectDecoder;
|
||||
import io.netty.handler.codec.serialization.ObjectEncoder;
|
||||
import lombok.AllArgsConstructor;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.springframework.stereotype.Component;
|
||||
|
||||
/**
|
||||
* Netty ConnectSender
|
||||
*
|
||||
* @author lk
|
||||
* @date 2022/06/18
|
||||
*/
|
||||
@Slf4j
|
||||
@AllArgsConstructor
|
||||
@Component
|
||||
public class NettyConnectSender implements MessageSender {
|
||||
|
||||
private ServerNettyAgent serverNettyAgent;
|
||||
|
||||
@Override
|
||||
public void send(Message message) {
|
||||
MessageWrapper messageWrapper = MessageConvert.convert(message);
|
||||
EventLoopGroup eventLoopGroup = serverNettyAgent.getEventLoopGroup();
|
||||
try {
|
||||
Bootstrap bootstrap = new Bootstrap();
|
||||
bootstrap.group(eventLoopGroup)
|
||||
.channel(NioSocketChannel.class)
|
||||
.handler(new ChannelInitializer<SocketChannel>(){
|
||||
@Override
|
||||
protected void initChannel(SocketChannel ch) throws Exception {
|
||||
ChannelPipeline pipeline = ch.pipeline();
|
||||
pipeline.addLast(new ObjectEncoder());
|
||||
pipeline.addLast(new ObjectDecoder(Integer.MAX_VALUE,
|
||||
ClassResolvers.cacheDisabled(null)));
|
||||
pipeline.addLast(new SenderHandler(messageWrapper));
|
||||
}
|
||||
});
|
||||
|
||||
bootstrap.connect(serverNettyAgent.getNettyServerAddress(), serverNettyAgent.getNettyServerPort()).sync();
|
||||
} catch (Exception e) {
|
||||
log.error("netty send error ",e);
|
||||
} finally {
|
||||
eventLoopGroup.shutdownGracefully();
|
||||
}
|
||||
}
|
||||
}
|
@ -0,0 +1,30 @@
|
||||
package cn.hippo4j.springboot.starter.monitor.netty;
|
||||
|
||||
import cn.hippo4j.common.monitor.MessageWrapper;
|
||||
import io.netty.channel.ChannelHandlerContext;
|
||||
import io.netty.channel.SimpleChannelInboundHandler;
|
||||
import lombok.AllArgsConstructor;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
|
||||
/**
|
||||
* SenderHandler
|
||||
*
|
||||
* @author lk
|
||||
* @date 2022/06/18
|
||||
*/
|
||||
@Slf4j
|
||||
@AllArgsConstructor
|
||||
public class SenderHandler extends SimpleChannelInboundHandler<MessageWrapper> {
|
||||
|
||||
private MessageWrapper messageWrapper;
|
||||
|
||||
@Override
|
||||
protected void channelRead0(ChannelHandlerContext ctx, MessageWrapper msg) throws Exception {
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void channelActive(ChannelHandlerContext ctx) throws Exception {
|
||||
ctx.channel().writeAndFlush(messageWrapper);
|
||||
}
|
||||
}
|
@ -0,0 +1,36 @@
|
||||
package cn.hippo4j.springboot.starter.remote;
|
||||
|
||||
import cn.hippo4j.springboot.starter.config.BootstrapProperties;
|
||||
import io.netty.channel.EventLoopGroup;
|
||||
import io.netty.channel.nio.NioEventLoopGroup;
|
||||
|
||||
/**
|
||||
* Server Netty Agent
|
||||
*
|
||||
* @author lk
|
||||
* @date 2022/6/18
|
||||
*/
|
||||
public class ServerNettyAgent {
|
||||
|
||||
private final BootstrapProperties dynamicThreadPoolProperties;
|
||||
|
||||
private final ServerListManager serverListManager;
|
||||
|
||||
public ServerNettyAgent(BootstrapProperties properties){
|
||||
this.dynamicThreadPoolProperties = properties;
|
||||
this.serverListManager = new ServerListManager(dynamicThreadPoolProperties);
|
||||
}
|
||||
|
||||
public EventLoopGroup getEventLoopGroup(){
|
||||
EventLoopGroup eventLoopGroup = new NioEventLoopGroup();
|
||||
return eventLoopGroup;
|
||||
}
|
||||
|
||||
public String getNettyServerAddress() {
|
||||
return serverListManager.getCurrentServerAddr().split(":")[1].replace("//","");
|
||||
}
|
||||
|
||||
public Integer getNettyServerPort(){
|
||||
return Integer.parseInt(serverListManager.getNettyServerPort());
|
||||
}
|
||||
}
|
Loading…
Reference in new issue