Day480,java面试官问项目的实现流程

new Class<?>[]{serviceClass},

((proxy, method, args) -> {

//客户端每调用一次就会进入该代码块

//第一次调用

if (nettyClientHandler==null){

startClient0(“127.0.0.1”,7000);

}

//设置要发送给服务器的信息

//providerName协议头,args传入的参数

nettyClientHandler.setParam(providerName+args[0]);

return executors.submit(nettyClientHandler).get();

}

));

}

//初始化客户端

private static void startClient0(String ipaddr,Integer port){

nettyClientHandler = new NettyClientHandler();

NioEventLoopGroup workerGroup = new NioEventLoopGroup();

try {

Bootstrap bootstrap = new Bootstrap();

Bootstrap clientBootstrap = bootstrap.group(workerGroup)

.channel(NioSocketChannel.class)

.option(ChannelOption.TCP_NODELAY,true)

.handler(new ChannelInitializer() {

@Override

protected void initChannel(SocketChannel socketChannel) throws Exception {

ChannelPipeline pipeline = socketChannel.pipeline();

pipeline.addLast(new StringEncoder());

pipeline.addLast(new StringDecoder());

pipeline.addLast(nettyClientHandler);

}

});

clientBootstrap.connect(ipaddr,port).sync();

}catch (InterruptedException e) {

e.printStackTrace();

}

}

}

  • com.achang.netty.dubboRPC.netty.NettyClientHandler

客户端处理器

public class NettyClientHandler extends ChannelInboundHandlerAdapter implements Callable {

private ChannelHandlerContext channelHandlerContext;//上下文

private String result;//调用的返回结果

private String param;//客户端调用方法时的参数

@Override

public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {

cause.printStackTrace();

ctx.close();

}

//收到服务器的数据后就会被调用

@Override

public synchronized void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {

System.out.println(“channelRead”);

result = msg.toString();

notify();//唤醒等待的线程

}

//与服务器连接成功后就会被调用

@Override

public void channelActive(ChannelHandlerContext ctx) throws Exception {

System.out.println(“channelActive”);

channelHandlerContext = ctx;

}

//被代理对象调用,异步发送数据给服务器,然后阻塞,会等待被唤醒

@Override

public synchronized Object call() throws Exception {

System.out.println(“call1”);

channelHandlerContext.writeAndFlush(param);

//进行wait阻塞

wait();

System.out.println(“call2”);

return result;

}

//设置发送的数据

void setParam(String msg){

System.out.println(“setParam”);

this.param = msg;

}

}

  • com.achang.netty.dubboRPC.netty.NettyServer

服务端初始化类

public class NettyServer {

public static void startServer(String hostname,Integer port) throws InterruptedException {

startServer0(hostname,port);

}

private static void startServer0(String hostname,Integer port) throws InterruptedException {

NioEventLoopGroup boosGroup = new NioEventLoopGroup(1);

NioEventLoopGroup workerGroup = new NioEventLoopGroup(8);

try {

ServerBootstrap bootstrap = new ServerBootstrap();

ServerBootstrap serverBootstrap = bootstrap.group(boosGroup, workerGroup)

// .handler(new LoggingHandler())

.channel(NioServerSocketChannel.class)

.childHandler(new ChannelInitializer() {

@Override

protected void initChannel(SocketChannel socketChannel) throws Exception {

ChannelPipeline pipeline = socketChannel.pipeline();

pipeline.addLast(new StringDecoder());

pipeline.addLast(new StringEncoder());

pipeline.addLast(new NettyServerHandler());

}

});

System.out.println(“服务端启动成功…端口:”+port);

ChannelFuture cf = serverBootstrap.bind(hostname, port).sync();

cf.channel().closeFuture().sync();

}finally {

boosGroup.shutdownGracefully();

workerGroup.shutdownGracefully();

}

}

}

  • com.achang.netty.dubboRPC.netty.NettyServerHandler

服务端处理器

public class NettyServerHandler extends ChannelInboundHandlerAdapter {

@Override

public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {

//获取客户端发送来的消息,并调用服务

System.out.println(“msg=”+msg);

//客户端想要调用服务器的api时,想要满足一定协议的要求才能调用

//比如,我们这里要求,每次发送消息时,都必须要求以"HelloService#hello开头"

if (msg.toString().startsWith(“HelloService#hello”)){

String result = new HelloServiceImpl().hello(msg.toString().split(“HelloService#hello”)[1]);

ctx.writeAndFlush(result);

}

}

@Override

public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {

cause.printStackTrace();

ctx.close();

}

}

  • com.achang.netty.dubboRPC.provider.HelloServiceImpl

客户端接口的真正实现Impl

public class HelloServiceImpl implements HelloService {

private static int count = 0;

@Override

小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Java工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Java开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频

如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Java)
img

因此收集整理了一份《2024年最新Java开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
[外链图片转存中…(img-W0UYzdUl-1710871750252)]
[外链图片转存中…(img-g7CgEBBn-1710871750253)]
[外链图片转存中…(img-3OtEgI4l-1710871750253)]

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频

如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Java)
[外链图片转存中…(img-kBXDFB97-1710871750254)]

  • 5
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值