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

安康市建设银行网站云主机配置网站

安康市建设银行网站,云主机配置网站,禁止粘贴的网站,芜湖企业生成过程视频: 如何使用ChatGPT快速生成代码 (qq.com) 如何使用ChatGPT快速生成SpringBoot集成Dubbo的完整案例 1、Dubbo最新版本有哪些新特性 Dubbo最新版本是2.7.9,于2021年6月发布。以下是该版本的一些新特性: 1)增加Dubbo-go…

生成过程视频: 如何使用ChatGPT快速生成代码 (qq.com)

如何使用ChatGPT快速生成SpringBoot集成Dubbo的完整案例

1、Dubbo最新版本有哪些新特性

Dubbo最新版本是2.7.9,于2021年6月发布。以下是该版本的一些新特性:

1)增加Dubbo-goDubbo-rust两个新的实现,提供更多语言的支持。

2)引入Dubbo Mesh,可以基于IstioKubernetes等服务网格框架,自动实现服务的流量管理、熔断降级等功能。

3)增加Generic JSON协议,支持基于HTTP/JSON的调用。

4)支持Dubbo IDL,可通过定义IDL文件生成服务接口的Java和Go代码,方便服务端和客户端的开发。

5)增加GenericService通用服务接口,可以跨语言调用,且不需要提前定义接口。

6)增加Spring Cloud集成,可以通过Spring CloudService Registry实现服务的注册与发现。

7)提升性能,优化了序列化和反序列化过程,同时优化了服务端和客户端的线程模型。

8) 改进了部分文档和示例。

总的来说,Dubbo 2.7.9 在多语言支持、服务网格、协议支持、IDL、性能优化等方面都有不少新特性。

2、Dubbo执行流程图

                       ┌───────────────┐     │  Dubbo 服务消费者 │     └───────────────┘     │             │             ▼             ┌───────────────┐     │     代理类        │     └───────────────┘     │             │             ▼             ┌───────────────┐     │     过滤器链     │     └───────────────┘     │             │             ▼             ┌───────────────┐     │      集群路由      │     └───────────────┘     │             │             ▼             ┌───────────────┐     │   负载均衡选择器   │     └───────────────┘     │             │             ▼             ┌───────────────┐     │     传输层         │     └───────────────┘     │             │             ▼             ┌───────────────┐     │    协议层         │     └───────────────┘     │             │             ▼             ┌───────────────┐     │  服务提供者    │     └───────────────┘

具体的流程如下:

1)服务提供者启动时,会向Dubbo注册中心注册自己提供的服务以及服务的地址信息。

2)服务消费者启动时,会向Dubbo注册中心订阅需要消费的服务以及服务地址信息。

3)服务消费者通过Dubbo代理类调用Dubbo服务,Dubbo代理类会在本地缓存中查找可用的Dubbo服务提供者。

4)如果本地缓存中没有可用的Dubbo服务提供者,Dubbo代理类会向Dubbo注册中心查询可用的Dubbo服务提供者。

5)Dubbo注册中心返回可用的Dubbo服务提供者地址信息,Dubbo代理类根据负载均衡策略选择一个Dubbo服务提供者。

6)Dubbo代理类将请求发送到Dubbo服务提供者。

7)Dubbo服务提供者接收到请求后,根据请求的服务名、方法名等信息,调用相应的Java方法,得到结果。

8)Dubbo服务提供者将结果返回给Dubbo代理类。

9)Dubbo代理类将结果返回给服务消费者。

需要注意的是,Dubbo还提供了多种配置方式和扩展机制,使得Dubbo的执行流程可以根据具体的业务场景进行灵活定制。例如,Dubbo可以支持多种注册中心、协议、序列化方式等,并且提供了众多的过滤器和扩展点,方便用户进行二次开发和定制。

3、SpringBoot集成Dubbo的完整实例

下面是一个SpringBoot集成Dubbo的完整实例。本例子使用Dubbo 2.7.9版本和SpringBoot 2.5.0版本。

第一步:在pom.xml中添加Dubbo和SpringBoot的依赖。在dependencies中添加以下内容:

<dependencies><!-- Dubbo --><dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-spring-boot-starter</artifactId><version>2.7.9</version></dependency><!-- SpringBoot --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId><version>2.5.0</version></dependency>
</dependencies>

第二步:在application.properties中添加Dubbo的配置。

#Dubbo
dubbo.application.name=example-provider
dubbo.registry.address=zookeeper://127.0.0.1:2181
dubbo.protocol.name=dubbo
dubbo.protocol.port=20880

第三步:创建一个接口,定义我们的Dubbo服务。

public interface ExampleService {String sayHello(String name);
}

第四步:创建一个实现类,实现ExampleService接口。

@Service
public class ExampleServiceImpl implements ExampleService {@Overridepublic String sayHello(String name) {return "Hello " + name;}
}

第五步:在Dubbo配置类中,将ExampleServiceImpl暴露为Dubbo服务。

@Configuration
public class DubboConfig {@Beanpublic ApplicationConfig applicationConfig() {ApplicationConfig applicationConfig = new ApplicationConfig();applicationConfig.setName("example-provider");return applicationConfig;}@Beanpublic RegistryConfig registryConfig() {RegistryConfig registryConfig = new RegistryConfig();registryConfig.setAddress("zookeeper://127.0.0.1:2181");return registryConfig;}@Beanpublic ProtocolConfig protocolConfig() {ProtocolConfig protocolConfig = new ProtocolConfig();protocolConfig.setName("dubbo");protocolConfig.setPort(20880);return protocolConfig;}@Beanpublic ServiceConfig<ExampleService> serviceConfig(ExampleService exampleService) {ServiceConfig<ExampleService> serviceConfig = new ServiceConfig<>();serviceConfig.setInterface(ExampleService.class);serviceConfig.setRef(exampleService);serviceConfig.setVersion("1.0.0");serviceConfig.setTimeout(5000);return serviceConfig;}
}

第六步:创建一个RestController,将Dubbo服务注入进去。

@RestController
public class ExampleController {@Reference(version = "1.0.0")private ExampleService exampleService;@GetMapping("/hello/{name}")public String hello(@PathVariable("name") String name) {return exampleService.sayHello(name);}
}

第七步:启动SpringBoot应用程序,运行Dubbo服务提供者。

第八步:测试Dubbo服务。使用curl或Postman等工具访问http://localhost:8080/hello/yourname ,看到返回的字符串是"Hello yourname"。

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

相关文章:

  • 株洲网站排名优化小程序源码怎么上传
  • 网络营销企业网站免费空间可以上传网站吗
  • app与网站WordPress淘客转链插件
  • 制作企业网站需要多少钱长沙做网站智投未来
  • 企业 网站 制作装修网名大全
  • vs做网站各种控件的使用杭州哪家网站建设好
  • 一 网站开发体会制作网站要找什么公司
  • 物流网站建设可行性报告重庆房地产信息官网
  • 网站建设88国模 wordpress
  • 宽屏公司网站源码php网页搜索记录怎么恢复
  • 网站建设技术的实现陕西建设信息网
  • 东莞免费网站建站模板网站建设网银
  • 网站建设方案报告正规网络游戏平台
  • 400元做网站送网推做餐饮的网站
  • 郑州做网站排名公司微信商城小程序怎么自己开发
  • 免费网站管理系统下载企业网站的短视频中心模板
  • 重庆做模块网站新加坡网站后缀
  • c 网站开发用的人多吗网上打广告
  • 个人网站优秀作品义务加工网
  • pw域名网站微信h5制作软件
  • 烟台网站建设方案书wordpress建博客网站
  • 怎么建网站卖产品网站后台编辑框不显示
  • 关于网站建设的话术网站建设万禾
  • 家具商务网站策划案网站导航html源码
  • 外贸高端网站设计公司外贸电商网站开发价格
  • 网站建设倒计时单页源码个人网站模板html代码免费
  • 永年做网站开发区网站制作公司
  • 郑州仿站模板网站建设北京到广州动卧
  • 开发一个微信小程序多少费用成都百度推广排名优化
  • 建设一个网站要钱吗多推网怎么推广