返回顶部
首页 > 资讯 > 精选 >怎么用Springboot和Netty实现rpc
  • 730
分享到

怎么用Springboot和Netty实现rpc

2023-06-29 07:06:54 730人浏览 泡泡鱼
摘要

这篇文章主要介绍“怎么用SpringBoot和Netty实现rpc”,在日常操作中,相信很多人在怎么用springboot和Netty实现rpc问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Spring

这篇文章主要介绍“怎么用SpringBootNetty实现rpc”,在日常操作中,相信很多人在怎么用springboot和Netty实现rpc问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Springboot和Netty实现rpc”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

Springboot、 Netty、动态代理(反射)、反射

项目整体结构如下:

怎么用Springboot和Netty实现rpc

 1.在父项目中引入相关依赖;

        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-WEB</artifactId>            <version>2.3.2.RELEASE</version>        </dependency>        <dependency>            <groupId>io.netty</groupId>            <artifactId>netty-all</artifactId>            <version>4.1.48.Final</version>        </dependency>        <dependency>            <groupId>com.alibaba</groupId>            <artifactId>fastJSON</artifactId>            <version>1.2.58</version>        </dependency>        <dependency>            <groupId>org.slf4j</groupId>            <artifactId>slf4j-log4j12</artifactId>            <version>2.0.0-alpha1</version>        </dependency>

2.服务提供模块整体结构如下:

怎么用Springboot和Netty实现rpc

 这里重点关注一下 RequestModel  ResponseModel 两个消息体类,

@Data@AllArgsConstructorpublic class RequestModel {     private String requestId;    private String serviceName;    private String methodName;    private Class[] paramTypes;    private Object[] paramValues; }
@Data@AllArgsConstructorpublic class ResponseModel {    private String responseId;    private String serviceName;    private String methodName;    private String code;    private String data;}

用于服务端和客户端的数据传输;再者就是关注 ServerChannelInboundHandler 中的 channelRead0() 报文解码处理;

    @Override    protected void channelRead0(ChannelHandlerContext ctx, String msg) {        StringBuilder sb = null;        RequestModel result = null;        try {            // 报文解析处理            sb = new StringBuilder();            result = jsON.parseObject(msg, RequestModel.class);             requestId = result.getRequestId();            String serviceName = result.getServiceName();            String methodName = result.getMethodName();            Class[] paramType = result.getParamTypes();            Object[] paramValue = result.getParamValues();            System.out.println(serviceName + "  " + methodName);            String substring = serviceName.substring(serviceName.lastIndexOf(".") + 1);            String s = substring.substring(0, 1).toLowerCase() + substring.substring(1);            Object serviceObject = applicationContext.getBean(s);            Method method = Class.forName(serviceName).getMethod(methodName, paramType);            Object returnValue = method.invoke(serviceObject, paramValue);            ResponseModel responseModel = new ResponseModel(requestId,serviceName,methodName,"200",JSON.toJSONString(returnValue));            sb.append(JSON.toJSONString(responseModel));            sb.append("\n");            System.out.println(sb.toString());            ctx.writeAndFlush(sb);        } catch (Exception e) {            ResponseModel responseModel = new ResponseModel(requestId,"","","500",e.getMessage());            String errorCode = JSON.toJSONString(responseModel)+"\n";            log.error(errorCode);            ctx.writeAndFlush(errorCode);            log.error("报文解析失败: " + e.getMessage());        }    }

客户端的模块代码如下; 

怎么用Springboot和Netty实现rpc

这里重点关注的是 ClientHandler 类中 channelRead0() 方法的处理

 @Override    protected void channelRead0(ChannelHandlerContext ctx, String msg) {        System.out.println("收到服务端消息: " + msg);         ResponseModel responseModel = JSON.parseObject(msg,ResponseModel.class);        String responseId = responseModel.getResponseId();        Promise promise = LocalPromise.promiseMap.remove(responseId);        if(promise != null){            String code = responseModel.getCode();            if(code.equals("200")){                promise.setSuccess(responseModel.getData());            }else{                promise.setFailure(new RuntimeException(responseModel.getData()));            }        }    }

AppStart 类中获取获取服务的处理;

private <T> T getProxyService(Class<T> serviceClass) {        Object service = Proxy.newProxyInstance(serviceClass.getClassLoader(), new Class[]{serviceClass}, new InvocationHandler() {            @Override            public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {                Channel channel = NettyClient.getChannel(host, port);                RequestModel requestModel = new RequestModel("100001", method.getDeclarinGClass().getName(), method.getName(), method.getParameterTypes(), args);                channel.writeAndFlush(JSON.toJSONString(requestModel) + "\n");                Promise promise = new DefaultPromise(channel.eventLoop());                LocalPromise.promiseMap.put(requestModel.getRequestId(), promise);                 System.out.println(LocalPromise.promiseMap+">>>>>>>>>>>>");                promise.await();                if (promise.isSuccess()) {                    Class<?> returnType = method.getReturnType();                    return JSON.toJavaObject(JSON.parseObject(promise.getNow()+""),returnType);                } else {                    System.out.println(promise.cause());                    return promise.cause();                }            }        });        return (T) service;    }

 测试结果:

怎么用Springboot和Netty实现rpc

怎么用Springboot和Netty实现rpc

到此,关于“怎么用Springboot和Netty实现rpc”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: 怎么用Springboot和Netty实现rpc

本文链接: https://lsjlt.com/news/323626.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 怎么用Springboot和Netty实现rpc
    这篇文章主要介绍“怎么用Springboot和Netty实现rpc”,在日常操作中,相信很多人在怎么用Springboot和Netty实现rpc问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Spring...
    99+
    2023-06-29
  • 基于Springboot+Netty实现rpc的方法附demo
    今天翻看了一下Netty相关的知识点,正好练练手,简单捣鼓了这个demo;这里简单梳理一下; 前提知识点: Springboot、 Netty、动态代理(反射)、反射 项目...
    99+
    2024-04-02
  • 怎么用SpringBoot+Netty实现简单聊天室
    本篇内容主要讲解“怎么用SpringBoot+Netty实现简单聊天室”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用SpringBoot+Netty实现简单聊天室”吧!一、实现1.User...
    99+
    2023-06-29
  • springboot+HttpInvoke如何实现RPC调用
    小编给大家分享一下springboot+HttpInvoke如何实现RPC调用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!开始用springboot2+hession4实现RPC服务时,发现第一个服务可以调用成功,但第二...
    99+
    2023-06-29
  • springboot+HttpInvoke 实现RPC调用的方法
    开始用springboot2+hession4实现RPC服务时,发现第一个服务可以调用成功,但第二个就一直报'<'isanunknowncode。第一个服务还是...
    99+
    2024-04-02
  • Springboot+netty实现Web聊天室
    目录一、项目的创建二、代码编写三、运行效果一、项目的创建 新建Spring项目: 选择JDK版本: 选择Spring Web: 项目名称和位置的设置: 二、代码编写 导入.j...
    99+
    2024-04-02
  • dubbo怎么实现rpc调用
    Dubbo是一个基于Java的高性能RPC框架,可以实现远程服务的调用。以下是使用Dubbo实现RPC调用的步骤:1. 定义服务接口...
    99+
    2023-10-23
    dubbo
  • Netty实现简易版的RPC框架过程详解
    目录正文1:如何运行项目2:从客户端调用开始(springboot-zk-study项目)3:服务端处理请求4:接下来要做什么正文 项目地址:gitee.com/baojh123...
    99+
    2023-02-10
    Netty简易版RPC框架 Netty RPC
  • 如何使用Springboot+netty实现Web聊天室
    这篇文章主要为大家展示了“如何使用Springboot+netty实现Web聊天室”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用Springboot+netty实现Web聊天室”这篇文章...
    99+
    2023-06-21
  • Springboot+Netty+Websocket实现消息推送实例是怎样的
    Springboot+Netty+Websocket实现消息推送实例是怎样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 前言We...
    99+
    2024-04-02
  • Go gRPC怎么实现Simple RPC
    本篇内容介绍了“Go gRPC怎么实现Simple RPC”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!前言gRPC主要...
    99+
    2023-07-02
  • Springboot整合Netty,自定义协议实现
    Springboot整合Netty,自定义协议实现 Springboot整合Netty 新建springboot项目,并在项目以来中导入netty包,用fastjson包处理jsonStr。                ...
    99+
    2023-10-03
    算法 java 开发语言 后端 spring boot
  • springboot整合netty框架实现站内信
    目录代码用到的组件介绍websocket连接过程代码用到的组件介绍 ChannelInitializer 见名知意,就是channel 初始化器,当每个客户端创建连接时这里面的代码都...
    99+
    2022-12-23
    springboot站内信 springboot netty站内消息通知
  • 什么是RPC?聊聊node中怎么实现 RPC 通信
    RPC vs HTTP相同点都是两台计算机之间的网络通信。ajax是浏览器和服务器之间的通行,RPC是服务器与服务器之间的通行需要双方约定一个数据格式不同点寻址服务器不同ajax 是使用 DNS作为寻址服务获取域名所对应的ip地址,浏览器拿...
    99+
    2022-11-22
    Node.js RPC
  • SpringBoot整合Netty实现WebSocket的示例代码
    目录一、pom.xml依赖配置二、代码2.1、NettyServer 类2.2、SocketHandler 类2.3、ChannelHandlerPool 类2.4、Applicat...
    99+
    2024-04-02
  • SpringBoot整合Dubbo框架,实现RPC服务远程调用
    目录一、Dubbo框架简介  1、框架依赖 二、与SpringBoot2.0整合  1、核心依赖2、项目结构说明3、核心配置 三、演示案例  1、服务远...
    99+
    2024-04-02
  • 使用Java怎么实现一个RPC框架
    使用Java怎么实现一个RPC框架?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。一、RPC简介RPC,全称为Remote Procedure Call,即远程过程调用,它是一个...
    99+
    2023-05-30
    java rpc
  • netty的怎么实现及运用到gmq中
    本篇内容主要讲解“netty的怎么实现及运用到gmq中”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“netty的怎么实现及运用到gmq中”吧! 一、背景 书...
    99+
    2024-04-02
  • Java实战之用springboot+netty实现简单的一对一聊天
    目录一、引入pom二、创建netty 服务端三、存储用户channel 的map四、客户端html五、controller 模拟用户登录以及要发送信息给...
    99+
    2024-04-02
  • 利用RabbitMQ实现RPC(pyth
        RPC——远程过程调用,通过网络调用运行在另一台计算机上的程序的函数\方法,是构建分布式程序的一种方式。RabbitMQ是一个消息队列系统,可以在程序之间收发消息。利用RabbitMQ可以实现RPC。本文所有操作都是在CentOS7...
    99+
    2023-01-31
    RabbitMQ RPC pyth
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作