什么叫RPC?
RPC是指远程过程调用,是一种进程间通信方式,他是一种技术的思想,而不是规范。它允许程序调用另一个地址空间(通常是共享网络的另一台机器上)的过程或函数,而不用程序员显式编码这个远程调用的细节。即程序员无论是调用本地的还是远程的函数,本质上编写的调用代码基本相同。a
RPC基本原理,RPC两个核心模块:通讯,序列化。
一次完整的RPC调用流程(同步调用,异步另说)如下:
1)服务消费方(client)调用以本地调用方式调用服务;
2)clientstub接收到调用后负责将方法、参数等组装成能够进行网络传输的消息体;
3)clientstub找到服务地址,并将消息发送到服务端;
4)serverstub收到消息后进行解码;
5)serverstub根据解码结果调用本地的服务;
6)本地服务执行并将结果返回给serverstub;
7)serverstub将返回结果打包成消息并发送至消费方;
8)clientstub接收到消息,并进行解码;
9)服务消费方得到最终结果。
RPC框架的目标就是要2~8这些步骤都封装起来,这些细节对用户来说是透明的,不可见的
netty通信原理
Netty是一个异步事件驱动的网络应用程序框架,用于快速开发可维护的高性能协议服务器和客户端。它极大地简化并简化了TCP和UDP套接字服务器等网络编程。
BIO:(BlockingIO)
NIO(Non-BlockingIO)
Selector一般称为选择器,也可以翻译为多路复用器,
Connect(连接就绪)、Accept(接受就绪)、Read(读就绪)、Write(写就绪)
Netty基本原理:
Dubbo
基本简介
ApacheDubbo(incubating)是一款高性能、轻量级的开源JavaRPC框架,它提供了三大核心能力:面向接口的远程方法调用,智能容错和负载均衡,以及服务自动注册和发现。
框架设计
config配置层:对外配置接口,以ServiceConfig,ReferenceConfig为中心,可以直接初始化配置类,也可以通过spring解析配置生成配置类
proxy服务代理层:服务接口透明代理,生成服务的客户端Stub和服务器端Skeleton,以ServiceProxy为中心,扩展接口为ProxyFactory.
registry注册中心层:封装服务地址的注册与发现,以服务URL为中心,扩展接口为RegistryFactory,Registry,RegistryService
cluster路由层:封装多个提供者的路由及负载均衡,并桥接注册中心,以Invoker为中心,扩展接口为Cluster,Directory,Router,LoadBalance
monitor监控层:RPC调用次数和调用时间监控,以Statistics为中心,扩展接口为MonitorFactory,Monitor,MonitorService
protocol远程调用层:封装RPC调用,以Invocation,Result为中心,扩展接口为Protocol,Invoker,Exporter
exchange信息交换层:封装请求响应模式,同步转异步,以Request,Response为中心,扩展接口为Exchanger,ExchangeChannel,ExchangeClient,ExchangeServer
transport网络传输层:抽象mina和netty为统一接口,以Message为中心,扩展接口为Channel,Transporter,Client,Server,Codec
serialize数据序列化层:可复用的一些工具,扩展接口为Serialization,ObjectInput,ObjectOutput,ThreadPool
启动解析、加载配置信息
服务暴露
服务引用
基本组成
服务提供者(Provider):暴露服务的服务提供方,服务提供者在启动时,向注册中心注册自己提供的服务。
服务消费者(Consumer):调用远程服务的服务消费方,服务消费者在启动时,向注册中心订阅自己所需的服务,服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。
注册中心(Registry):注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者
监控中心(Monitor):服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心
调用关系说明
服务容器负责启动,加载,运行服务提供者。
服务提供者在启动时,向注册中心注册自己提供的服务。
服务消费者在启动时,向注册中心订阅自己所需的服务。
注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。
服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。
服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。
环境搭建
windows-安装zookeeper
下载zookeeper
解压zookeeper解压运行zkServer.cmd,初次运行会报错,没有zoo.cfg配置文件
修改zoo.cfg配置文件将conf下的zoo_sample.cfg复制一份改名为zoo.cfg即可。注意几个重要位置:dataDir=./临时数据存储的目录(可写相对路径)clientPort=zookeeper的端口号修改完成后再次启动zookeeper
使用zkCli.cmd测试ls/:列出zookeeper根下保存的所有节点create–e/atguigu:创建一个atguigu节点,值为get/atguigu:获取/atguigu节点的值
windows-安装dubbo-admin管理控制台
dubbo本身并不是一个服务软件。它其实就是一个jar包能够帮你的java程序连接到zookeeper,并利用zookeeper消费、提供服务。所以你不用在Linux上启动什么dubbo服务。
但是为了让用户更好的管理监控众多的dubbo服务,官方提供了一个可视化的监控程序,不过这个监控即使不装也不影响使用。
下载dubbo-admin
进入目录,修改dubbo-admin配置修改src\main\resources\application.properties指定zookeeper地址
打包dubbo-adminmvncleanpackage-Dmaven.test.skip=true
运行dubbo-adminjava-jardubbo-admin-0.0.1-SNAPSHOT.jar注意:【有可能控制台看着启动了,但是网页打不开,需要在控制台按下ctrl+c即可默认使用root/root登陆
Dubbo配置
配置原则
JVM启动-D参数优先,这样可以使用户在部署和启动时进行参数重写,比如在启动时需改变协议的端口。
XML次之,如果在XML中有配置,则dubbo.properties中的相应配置项无效。
Properties最后,相当于缺省值,只有XML没有配置时,dubbo.properties的相应配置项才会生效,通常用于共享公共配置,比如应用名。
重试次数
失败自动切换,当出现失败,重试其它服务器,但重试会带来更长延迟。可通过retries="2"来设置重试次数(不含第一次)。
重试次数配置如下:
dubbo:serviceretries="2"/或dubbo:referenceretries="2"/或dubbo:referencedubbo:methodname="findFoo"retries="2"//dubbo:reference
超时时间
由于网络或服务端不可靠,会导致调用出现一种不确定的中间状态(超时)。为了避免超时导致客户端资源(线程)挂起耗尽,必须设置超时时间。
Dubbo消费端
全局超时配置
dubbo:consumertimeout=""/指定接口以及特定方法超时配置dubbo:referenceinterface="