spring cloud 和dubbo区别?
1.服务调用方式 dubbo是RPC springcloud Rest Api
2.注册中心,dubbo 是zookeeper springcloud是eureka,也可以是zookeeper
3.服务网关,dubbo本身没有实现,只能通过其他第三方技术整合,springcloud有 Zuul路由网关,作为路由服务器,进行消费者的请求分发,springcloud支持断路器, 与git完美集成配置文件支持版本控制,事物总线实现配置文件的更新与服务自动 装配等等一系列的微服务架构要素
Eureka和Zookeeper区别?
1.Eureka取CAP的AP,注重可用性,Zookeeper取CAP的CP注重一致性。
2.Zookeeper在选举期间注册服务瘫痪,虽然服务最终会恢复,但选举期间不可用。
3.eureka的自我保护机制,会导致一个结果就是不会再从注册列表移除因长时间没收到心跳而过期的服务。依然能接受新服务的注册和查询请求,但不会被同步到其他节点。不会服务瘫痪。
4.Zookeeper有Leader和Follower角色,Eureka各个节点平等。
5.Zookeeper采用过半数存活原则,Eureka采用自我保护机制解决分区问题。
6.eureka本质是一个工程,Zookeeper只是一个进程。
dubbo
Dubbo 致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。
![]()
节点角色说明:
Provider: 暴露服务的服务提供方。
Consumer: 调用远程服务的服务消费方。
Registry: 服务注册与发现的注册中心。
Monitor: 统计服务的调用次调和调用时间的监控中心。
Container: 服务运行容器。
调用关系说明:
0. 服务容器负责启动,加载,运行服务提供者。
1. 服务提供者在启动时,向注册中心注册自己提供的服务。
2. 服务消费者在启动时,向注册中心订阅自己所需的服务。
3. 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。服务提供者和消费者只在启动时与注册中心交互,注册中心不转发请求
4. 服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。
5. 服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。
1. 短连接: 指通讯双方有数据交互时,就建立一个连接,数据发送完成后,则断开此连接,即每次连接只完成一项业务的发送(百度百科)。
2. 长连接( keep-alive ): 指在一个连接上可以连续发送多个 数据包 ,在连接保持期间,如果没有数据包发送,需要双方发链路检测包(百度百科)。
Zookeeper 在Linux系统的安装
安装步骤:
第一步:安装 jdk
(1)上传jdk安装包到linux服务器上 (资源\配套软件\Jdk\jdk-8u131-linux-x64.tar.gz)
(2)安装包解压缩到指定的目录
tar -xvf jdk-8u131-linux-x64.tar.gz -C /usr/local
(3)、进入到解压缩目录,修改jdk的解压缩文件夹名字
cd /usr/local
mv jdk1.8.0_131/ jdk
(4)、配置环境变量
vi /etc/profile
在文档最后添加配置信息
export JAVA_HOME=/usr/local/jdk
export CLASSPATH=$JAVA_HOME/lib:.
export PATH=$JAVA_HOME/bin:$PATH
(5)、让配置文件立刻生效
source /etc/profile
(6)、测试jdk是否安装成功
java -version
第二步:把 zookeeper 的压缩包(资源\配套软件\Dubbo\zookeeper-3.4.10.tar.gz)上传到 linux 系统。
官方下载地址:https://archive.apache.org/dist/zookeeper/
第三步:解压缩压缩包
tar -zxvf zookeeper-3.4.10.tar.gz第四步:进入 zookeeper-3.4.10 目录,创建 data 文件夹。
第五步:进入conf目录 ,把 zoo_sample.cfg 改名为 zoo.cfg
第六步:打开zoo.cfg , 修改 data 属性:dataDir=/root/zookeeper-3.4.10/data
Zookeeper 服务启动
进入bin目录,启动服务输入命令
./zkServer.sh start输出以下内容表示启动成功
关闭服务输入命令
./zkServer.sh stop
输出以下提示信息
查看状态:
./zkServer.sh status
如果启动状态,提示
如果未启动状态,提示:
管理中心的部署
(1)找到Dubbo管理中心war包(资源\配套软件\Dubbo\dubbo-admin-2.6.1.war), 在linux服务器上安装tomcat, 将此war包上传到linux服务器的tomcat的webapps下。为了访问方便,你可以把版本号去掉。 启动tomcat后自动压。
(2)如果你部署在zookeeper同一台主机并且端口是默认的2181,则无需修改任何配置。如果不是在一台主机上或端口被修改,需要修改WEB-INF下的dubbo.properties ,修改如下配置:
dubbo.registry.address=zookeeper://127.0.0.1:2181
修改后重新启动tomcat
管理端使用
(1)打开浏览器,输入http://192.168.0.107:8080/dubbo-admin,登录用户名和密码均为root 进入首页。 (192.168.0.107)是我部署的linux主机地址。
(2)启动服务提供者工程,即可在服务治理-提供者查看到该服务。
点击其中一条数据后可以查看详情。
(3)启动服务消费者工程,运行页面,观察“消费者”列表
SpringBoot集成Dubbo
导入依赖
<!--dubbo--> <!-- Dubbo Spring Boot Starter --> <dependency> <groupId>org.apache.dubbo</groupId> <artifactId>dubbo-spring-boot-starter</artifactId> <version>2.7.3</version> </dependency> <!--zookeeper--> <!-- https://mvnrepository.com/artifact/com.github.sgroschupf/zkclient --> <dependency> <groupId>com.github.sgroschupf</groupId> <artifactId>zkclient</artifactId> <version>0.1</version> </dependency> <!-- 引入zookeeper --> <dependency> <groupId>org.apache.curator</groupId> <artifactId>curator-framework</artifactId> <version>2.12.0</version> </dependency> <dependency> <groupId>org.apache.curator</groupId> <artifactId>curator-recipes</artifactId> <version>2.12.0</version> </dependency> <dependency> <groupId>org.apache.zookeeper</groupId> <artifactId>zookeeper</artifactId> <version>3.4.14</version> <!--排除这个slf4j-log4j12--> <exclusions> <exclusion> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> </exclusion> </exclusions> </dependency>
在springboot配置文件中配置dubbo相关属性!
#当前应用名字 dubbo.application.name=provider-server #注册中心地址 dubbo.registry.address=zookeeper://127.0.0.1:2181 #扫描指定包下服务 dubbo.scan.base-packages=com.wl.provider.service
测试
package com.wl.controller; import com.wl.service.SayHello; import org.apache.dubbo.config.annotation.Reference; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class Hello { @Reference //远程引用指定的服务,他会按照全类名进行匹配,看谁给注册中心注册了这个全类名,要么pom引入,要么复制同样名字的接口到包下 SayHello sayHello; @RequestMapping("/") public String Hello(){ sayHello.hello(); return "index"; } }