[适合初中级Java程序员修炼手册从0搭建整个Web项目](八)

简介: 前言文本已收录至我的GitHub仓库,欢迎Star:github.com/bin39232820…种一棵树最好的时间是十年前,其次是现在

six-finger-web


一个Web后端框架的轮子从处理Http请求【基于Netty的请求级Web服务器】 到mvc【接口封装转发)】,再到ioc【依赖注入】,aop【切面】,再到 rpc【远程过程调用】最后到orm【数据库操作】全部自己撸一个(简易)的轮子。

github

github.com/bin39232820…


为啥要写这个轮子

其实是这样的,小六六自己平时呢?有时候喜欢看看人家的源码比如Spring,但是小六六的水平可能不怎么样,每次看都看得晕头转向,然后就感觉里面的细节太难了,然后我就只能观其总体的思想,然后我就想我如果可以根据各位前辈的一些思考,自己撸一个简单的轮子出来,那我后面去理解作者的思想是不是简单点呢?于是呢 six-finger-web就面世了,它其实就是我的一个学习过程,然后我把它开源出来,希望能帮助那些对于学习源码有困难的同学。还有就是可以锻炼一下自己的编码能力,因为平时我们总是crud用的Java api都是那些,久而久之,很多框架类的api我们根本就不熟练了,所以借此机会,锻炼一下。


特点

  • 内置由 Netty 编写 HTTP 服务器,无需额外依赖 Tomcat 之类的 web 服务(刚好小六六把Netty系列写完,顺便用下)
  • 代码简单易懂(小六六自己写不出框架大佬那种高类聚,低耦合的代码),能力稍微强一点看代码就能懂,弱点的也没关系,小六六有配套的从0搭建教程。
  • 支持MVC相关的注解确保和SpringMVC的用法类似
  • 支持Spring IOC 和Aop相关功能
  • 支持类似于Mybatis相关功能
  • 支持类似于Dubbo的rpc相关功能
  • 对于数据返回,只支持Json格式


絮叨

前面是已经写好的章节,下面我给大家来一一走一遍搭建流程

不知不觉也写到了第八篇了,差不多也有一半了吧!基本上这些东西学完,小六六打算学点大数据技术栈的东西了(其实本来想学前端的,但是吧从工作开始就没怎么写过前端,感觉能力还在初级阶段,除非真的要我去做前端,不然感觉效率估计会低很多,所以就算了吧,后面看工作吧)

今天我们来真正的来看看RPC的具体实现,上一篇的SPI 是基础哈,大家一定要好好的理解一下。有了这个今天的RPC就不难了。还是用的 Java Guide 的rpc gitee.com/SnailClimb/… 基本上是它的代码,我就讲解一下。

今天是第一个版本,就是不整合Spring的,简单的实现远程过程调用


来看看包结构


网络异常,图片无法展示
|


我们来看上图,其实最主要的是rpc-core 因为现在是基础版 所以就几个核心组件

  • config 这个就是一些配置
  • loadbalance  负载均衡的操作
  • proxy 代理,就是我们客户端去调用服务端接口的时候需要生成的代理对象
  • registry 这边用的zk 服务的注册于发现中心
  • remoting  真正的远程调用的代码,这边基础版用的是基于Socket的方式,下一个版本改成基于Netty


具体代码讲解

因为代码比较多,我就截图部分来讲,具体的话文章还是个辅助,如果真心想看懂,建议的话把代码拉下来看,不难的。


rpc-api

写过dubbo的都知道,我们会用一个放api 接口 因为我们的客户端和服务端都是会依赖它的。

网络异常,图片无法展示
|


也非常的简单,就是定义一个接口,大家都懂

rpc-server

然后就是我们的服务提供方了,大家想想,服务的提供方要干嘛呢?先把我们要做的事情想通了,后面就很简单了。

  • 第一个肯定要启动一个网络通信,那么既然是服务端的话,那么我们是不是需要启动一个Server 这个是肯定的
  • 第二个 我们竟然是服务端,那么我们是不是得向注册中心去注册我们的地址呢?对的,我们要注册我们自己

好了,我们来看rpc-server启动类的代码

网络异常,图片无法展示
|


然后我跟大家来跟跟这2个方法的代码

注册服务

ServiceProviderImpl->publishService

网络异常,图片无法展示
|


ServiceProviderImpl->addService

网络异常,图片无法展示
|

这个是用来找到具体实现的服务的


ZkServiceRegistry-> registerService

网络异常,图片无法展示
|


操作zk的话用的是CuratorFramework 这边小六六提一个点就是我们的zk的服务端和我们代码客户端的版本要一致,不然会各种报错,小六六自己搞了好久。哈哈。

再来看看 启动服务端的流程,这个就得懂点网络了,其实我们做业务的时候根本用不上网络,但是你只要写一些中间件基本上都要懂网络,所以网络的代码也是很重要的。

SocketRpcServer->start

网络异常,图片无法展示
|


这个就是常规操作了,搞个线程池,然后去处理来的请求,具体我们来看里面的处理流程吧

SocketRpcRequestHandlerRunnable->run

网络异常,图片无法展示
|


上面的代码也很简单吧

第一步就是拿到流,拿到流之后呢?把它转成请求对象,然后再去处理,再把结果返回给客户端,那么继续看具体的请求流程

RpcRequestHandler->handle

网络异常,图片无法展示
|

也很简单那,就2行代码,我们有了请求参数,通过请求参数我们再去找到我们服务端具体的接口的实现类,然后通过类和参数,通过方法名称和参数类型,拿到具体的方法,通过反射去执行方法,所以框架的话,反射用的是真的多。

网络异常,图片无法展示
|


到此呢?服务端的我们就分析完了,我们来看看客户端的吧


rpc-client

客户端,我们来想想客户端要做些什么呢?

  • 首先肯定是启动网络的客户端嘛
  • 然后通过请求参数,生成一个代理对象,通过代理对象去调用远程服务的方法

网络异常,图片无法展示
|


来看看SocketRpcClient

网络异常,图片无法展示
|


首先 构造方法 就通过SPI生成了 我们服务发现,这个也是客户端需要做的


RpcClientProxy

这个类是生成代理对象的,我们来看看它是怎么实现的

网络异常,图片无法展示
|


第一步,当然是JDK的动态代理了。然后我们最最最核心的来看看它的invoke 方法

网络异常,图片无法展示
|


前面是先构建请求对象,然后再去具体调用服务端的方法,最后拿到返回值,然后校验返回值。

SocketRpcClient-> sendRpcRequest

网络异常,图片无法展示
|


这个就是也要去zk 拿到我们的ip+端口 然后再去做网络请求嘛。以上就是整个客户端的流程了,大致就是这样了


测试

让我们来测试测试

  • api

网络异常,图片无法展示
|


  • server

网络异常,图片无法展示
|

然后我们先启动服务端

网络异常,图片无法展示
|


然后再启动客户端



网络异常,图片无法展示
|


结尾


好了,因为代码太多了,所以我这边是截图,还是希望大家真的想了解的自己拉代码去学习,你拉代码跟着走一下,基本上rpc的整体流程你可以做到心中有数。

相关文章
|
2月前
|
缓存 JSON 监控
如何在项目中保证 Web 组件化的性能
保证 Web 组件化的性能需要从多个方面入手,综合运用各种优化方法和策略。通过持续的优化和改进,能够提高组件化的整体性能,为用户提供更好的体验,同时也有助于提高项目的开发效率和质量。
53 8
|
2月前
|
存储 前端开发 JavaScript
如何在项目中高效地进行 Web 组件化开发
高效地进行 Web 组件化开发需要从多个方面入手,通过明确目标、合理规划、规范开发、加强测试等一系列措施,实现组件的高效管理和利用,从而提高项目的整体开发效率和质量,为用户提供更好的体验。
44 7
|
2月前
|
监控 安全 测试技术
如何在实际项目中应用Python Web开发的安全测试知识?
如何在实际项目中应用Python Web开发的安全测试知识?
42 4
|
2月前
|
中间件 Go API
Go语言中几种流行的Web框架,如Beego、Gin和Echo,分析了它们的特点、性能及适用场景,并讨论了如何根据项目需求、性能要求、团队经验和社区支持等因素选择最合适的框架
本文概述了Go语言中几种流行的Web框架,如Beego、Gin和Echo,分析了它们的特点、性能及适用场景,并讨论了如何根据项目需求、性能要求、团队经验和社区支持等因素选择最合适的框架。
174 1
|
2月前
|
JavaScript 前端开发 开发工具
web项目规范配置(husky、eslint、lint-staged、commit)
通过上述配置,可以确保在Web项目开发过程中自动进行代码质量检查和规范化提交。Husky、ESLint、lint-staged和Commitlint共同作用,使得每次提交代码之前都会自动检查代码风格和语法问题,防止不符合规范的代码进入代码库。这不仅提高了代码质量,还保证了团队协作中的一致性。希望这些配置指南能帮助你建立高效的开发流程。
80 5
|
2月前
|
JavaScript 前端开发 数据安全/隐私保护
Web开发者必看:手把手教你如何轻松播放m3u8流地址,解锁视频播放新技能,让你的项目更上一层楼!
【10月更文挑战第23天】随着互联网技术的发展,m3u8格式因良好的兼容性和高压缩率被广泛用于网络流媒体传输。本文介绍如何在Web端播放m3u8流地址,包括引入视频播放器(如Video.js)、创建播放器容器、初始化播放器及播放m3u8流的具体步骤。此外,还涉及处理加密m3u8流的示例。
604 1
|
3月前
|
JSON 搜索推荐 API
Python的web框架有哪些?小项目比较推荐哪个?
【10月更文挑战第15天】Python的web框架有哪些?小项目比较推荐哪个?
97 1
|
3月前
|
前端开发 JavaScript API
惊呆了!学会AJAX与Fetch API,你的Python Web项目瞬间高大上!
在Web开发领域,AJAX与Fetch API是提升交互体验的关键技术。AJAX(Asynchronous JavaScript and XML)作为异步通信的先驱,通过XMLHttpRequest对象实现了局部页面更新,提升了应用流畅度。Fetch API则以更现代、简洁的方式处理HTTP请求,基于Promises提供了丰富的功能。当与Python Web框架(如Django、Flask)结合时,这两者能显著增强应用的响应速度和用户体验,使项目更加高效、高大上。
65 2
|
4月前
|
前端开发 Python
前后端分离的进化:Python Web项目中的WebSocket实时通信解决方案
在现代Web开发领域,前后端分离已成为一种主流架构模式,它促进了开发效率、提升了应用的可维护性和可扩展性。随着实时数据交互需求的日益增长,WebSocket作为一种在单个长连接上进行全双工通讯的协议,成为了实现前后端实时通信的理想选择。在Python Web项目中,结合Flask框架与Flask-SocketIO库,我们可以轻松实现WebSocket的实时通信功能。
83 2
|
3月前
|
监控 Java Maven
springboot学习二:springboot 初创建 web 项目、修改banner、热部署插件、切换运行环境、springboot参数配置,打包项目并测试成功
这篇文章介绍了如何快速创建Spring Boot项目,包括项目的初始化、结构、打包部署、修改启动Banner、热部署、环境切换和参数配置等基础操作。
203 0