竹笋

首页 » 问答 » 问答 » Alibaba微服务技术,Dubbo2
TUhjnbcbe - 2023/6/14 21:08:00
为什么会得白癞风 http://pf.39.net/bdfyy/zjft/150604/4634163.html

什么叫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="

1
查看完整版本: Alibaba微服务技术,Dubbo2