当前位置: 首页 > news >正文

沈阳市建设公司网站字体中国设计网

沈阳市建设公司网站,字体中国设计网,上海建设工程招投标网站,黑龙江省城市建设工程学校官方网站1. Dubbo概述 Dubbo 是一款高性能、轻量级的开源Java RPC框架,由阿里巴巴公司开发并在2011年开源。它主要用于解决分布式系统中服务之间的通信问题,支持多种协议,如Dubbo、HTTP、Hessian等,具有服务注册、服务发现、负载均衡、故…

1. Dubbo概述

Dubbo 是一款高性能、轻量级的开源Java RPC框架,由阿里巴巴公司开发并在2011年开源。它主要用于解决分布式系统中服务之间的通信问题,支持多种协议,如Dubbo、HTTP、Hessian等,具有服务注册、服务发现、负载均衡、故障转移等特性。

2. Zookeeper概述(Dubbo推荐使用Zookeeper作为注册中心)

ZooKeeper 是一个开源的分布式协调服务,主要用于分布式应用中的分布式协调。它是由 Apache 软件基金会开发的一个项目,旨在解决分布式应用中的一致性问题。
 

3. 安装Zookeeper

创建一个文件夹放置zookeeper压缩文件

使用tar命令进行压缩zookeeper文件

tar -zxvf apache-zookeeper-3.5.6-bin.tar.gz

创建一个目录用于存放zookeeper的数据 例如:zkdata

zoo_sample.cfg不生效,只有zoo.cfg才生效,需要将zoo_sample.cfg拷贝一份名为zoo.cfg的文件

cp zoo_sample.cfg zoo.cfg

然后进入解压后的zookeeper的配置文件zoo.cfg,在该配置文件中修改dataDir的值为存放zookeeper用于存放数据的目录地址(例如:zkdata的地址)

修改zoo.cfg的dataDir:

4. Zookeeper的基本操作 

返回zookeeper目录

进入bin目录中,zkServer.sh是zookeeper的可执行文件

启动 zookeeper的命令:

./zkServer.sh start

 查看 zookeeper的状态:

./zkServer.sh status

停止 zookeeper的命令:

./zkServer.sh stop

5.Dubbo快速入门示例

首先启动zookeeper 

防火墙未关闭问题

如果发现该提示则表示防火墙未关闭

 关闭防火墙命令

sudo systemctl stop firewalld

(1)dubbo的生产者:

引入依赖

        <dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-dependencies-zookeeper</artifactId><version>2.7.4.1</version><type>pom</type><exclusions><exclusion><groupId>org.slf4j</groupId><artifactId>slf4j-log4j12</artifactId></exclusion></exclusions></dependency><dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-spring-boot-starter</artifactId><version>2.7.4.1</version></dependency>

填写配置

server:port: 8081
dubbo:registry:address: zookeeper://192.168.92.138:2181   #自己的zookeeper服务器的IP:默认端口号application:name: producer1 #注册进去的名字protocol:name: dubbo     #设置类型port: -1      #因为dubbo的服务器端口号是不能唯一的,所以,设置为-1会帮我们自动改变端口号config-center:timeout: 120000  #超时时间  (毫秒)

示例 ServiceImpl

@Service //注意这里是dubbo的Service注解
public class UserServiceImpl implements IUserService {@Overridepublic String helloWorld() {return "Hello World" + LocalDateTime.now();}
}

启动类 

@SpringBootApplication
@ServletComponentScan
@EnableDubbo(scanBasePackages = "com.example.service.service")
public class DubboServiceApplication {public static void main(String[] args){SpringApplication.run(DubboServiceApplication.class,args);}
}

(2)dubbo的消费者:

引入依赖

        <dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-dependencies-zookeeper</artifactId><version>2.7.4.1</version><type>pom</type><exclusions><exclusion><groupId>org.slf4j</groupId><artifactId>slf4j-log4j12</artifactId></exclusion></exclusions></dependency><dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-spring-boot-starter</artifactId><version>2.7.4.1</version></dependency><dependency><groupId>com.example</groupId><artifactId>dubbo-service</artifactId><version>1.0-SNAPSHOT</version></dependency>

填写配置

server:port: 8082dubbo:application:name: consumer1protocol:name: dubboport: -1registry:address: zookeeper://192.168.92.138:2181  #默认端口号为2181config-center:timeout: 12000  #超时时间

示例 controller

@RestController
@RequestMapping("/user")
public class UserController {@Referenceprivate IUserService userService;@GetMapping("/hello")public String getHello(){return userService.helloWorld();}}

启动类

@SpringBootApplication
@ServletComponentScan
@EnableDubbo(scanBasePackages = "com.example.web.controller")
public class DubboWebApplication {public static void main(String[] args){SpringApplication.run(DubboWebApplication.class,args);}
}

 (3)测试

打开浏览器的地址:http://localhost:8082/user/hello

显示效果:

 

6.Dubbo-admin(图形化界面)

(1)首先下载node

(2)下载 Dubbo-admin

下载链接:https://github.com/apache/dubbo-admin

下载dubbo-admin 解压后我们进入…\dubbo-admin-develop\dubbo-admin-server\src\main\resources目录,找到 application.properties配置文件 进行配置修改

(3)修改该配置文件中的 zookeeper 地址:

(将127.0.0.01修改为自己的虚拟机地址)

说明:

admin.registry.address注册中心

admin.config-center 配置中心

admin.metadata-report.address元数据中心 

(4)在 dubbo-admin-develop 目录执行打包命令

mvn clean package

 (5)启动后端

切换目录到:dubbo-Admin-develop\dubbo-admin-distribution\target

打开cmd

执行下面的命令启动 dubbo-admin,dubbo-admin后台由SpringBoot构建。

java -jar .\dubbo-admin-0.1.jar

 (6)启动图形化界面

在dubbo-admin-ui 目录下执行命令

npm run dev

浏览器输入所显示的地址,用户名密码都是root

7.Dubbo高级特性

(1)设置超时和重启

  • timeout:调用超时时间,默认值1000,单位为毫秒。
  • retries:重试次数,默认值2。

(2)多版本

  • version:服务版本,用于区分同一接口的不同版本。

在生产者中的Impl里的@Service和消费者中的controller的@Reffrence的可以通过设置版本,版本必须一致生产者才能为消费者服务。

 

(3)负载均衡

负载均衡策略有四种:

  • random(随机):随机选择一个服务提供者实例。
  • roundRobin(轮询):按顺序轮流选择一个服务提供者实例。
  • leastRequest(最少请求):选择请求最少的服务提供者实例。
  • consistentHash(一致性哈希):基于一致性哈希算法选择服务提供者实例。

在生产者中的Impl里的@Service和消费者中的controller的@Reffrence的可以通过loadbalance属性设置负载均衡策略的模式

 

(4)集群容错

常见的集群容错模式:

  • failover(失败自动切换):当出现失败情况时,重试其他服务器。通常用于读操作,但重试会带来更长延迟。可通过 retries 属性设置重试次数。

  • failfast(快速失败):只发起一次调用,失败立即报错。通常用于非幂等性的写操作,比如新增记录。

  • failback(失败自动恢复):后台记录失败请求,定时重发。通常用于消息通知操作。

  • failsafe(失败安全):出现异常时,直接忽略。通常用于写入审计日志等操作。

 

http://www.yayakq.cn/news/22384/

相关文章:

  • 骏域网站建设专家电话电子商务网站建设与管理实验
  • 网站建设的需求是什么wordpress上传路径
  • 建设电子商务网站必须首先确定的是jsp网站开发引用文献
  • 河北省建设厅网站官网业务系统国家知识产权商标注册查询官网
  • 做淘宝的人就跟做网站一样百度做网站好吗
  • 福州做商城网站公司网络营销自己做网站
  • 项目网站建设方案云南网站开发建设
  • 建设网站系统胶南网站建设哪家好
  • 电商网站新闻怎么做中网-西安网站建设公司
  • win7本地做网站网站发布服务托管器
  • 手游门户网站模块WordPress巨卡无比
  • 网站开发完了备案做网站订单
  • 网站上海备案查询温州 建网站的公司 新
  • 大数据网站建设费用东营聊城网站建设
  • 太原网站建设公司哪家好雄安网站设计制作
  • 成都网站改版竞价推广和信息流推广
  • 最近几年做电影网站怎么样网站建设 东莞
  • 桂林市建设工程质量监督站网站企业有域名怎么做网站
  • 长春阿凡达网站建设移动端网站开发教案
  • 外贸网站建站方案一键建站源码
  • 教育教研网站建设的意义新余商城网站建设
  • 可以看的网站的浏览器有哪些wordpress照片模板
  • 做支付网站个人网站logo生成
  • 网站开发体会范文WordPress安全社区
  • 企业网站管理系统联系我们怎么添加中国电商公司100排名
  • 怎么投诉网站制作公司广西壮族自治区成立于哪一年
  • 网站的前台企业网站的主要类型
  • 学做面包网站如何保存网页上的视频
  • 中文域名网站360优化大师安卓下载
  • 网站在什么环境下做网站标题几个字合适