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

网站建设外贸经典重庆论坛畅谈重庆

网站建设外贸,经典重庆论坛畅谈重庆,简阳seo排名优化培训,windows云桌面一.背景 1.问题提出 我们在一个父项目下写了两个子项目,需要两个子项目之间相互调用。我们可以发送HTTP请求来获取我们想要的资源,具体实现的方法有很多,可以用HttpURLConnection、HttpClient、Okhttp、 RestTemplate等。 举个例子&#x…

一.背景

1.问题提出

我们在一个父项目下写了两个子项目,需要两个子项目之间相互调用。我们可以发送HTTP请求来获取我们想要的资源,具体实现的方法有很多,可以用HttpURLConnectionHttpClientOkhttpRestTemplate等。

举个例子,我们想要通过订单表中的商品Id来查询商品的详细信息,我们需要向商品所在的模块发送HTTP请求,通过请求获取商品的详细信息:

@Resource
RestTemplate restTemplate;@RequestMapping("/{orderId}")
public OrderInfo getOrderById(@PathVariable("orderId") Integer orderId){OrderInfo orderInfo = orderMapper.selectByOrderId(orderId);String url="http://127.0.0.1:9090/product/"+orderInfo.getProductId();ProductInfo productInfo = restTemplate.getForObject(url, ProductInfo.class);orderInfo.setProductInfo(productInfo);return orderInfo;
}

上面的实现有一个问题:如果机器发生变故,url会跟着变更。url变来变去,我们写的代码就要进行修改,因此我们要想办法解决这个问题。

2.解决思路

注册中心可以解决这个问题。

服务启动或变更的时候,向注册中心报道,注册中心就存储着应用和IP的关系。

当我们想要调用方法的时候,只需要向注册中心去获取服务方的IP就行了。

那什么是注册中心?

注册中心(Service Registry) 是分布式系统(尤其是微服务架构)中的核心组件,主要用于解决服务实例的 自动发现、动态管理和路由调度 问题。它就像一个 “电话簿”,记录着所有服务实例的网络地址(IP、端口等信息),并实时更新这些信息,确保服务之间可以快速、可靠地通信。

注册中心有三种角色:服务提供者(Server)服务消费者(Client)服务注册中心(Registry)

它们之间的关系可以通过两个概念来描述:

服务注册服务提供者在启动的时候向服务注册中心(Registry)注册自身服务,并向服务注册中心(Registry)定期发送心跳汇报存好情况。

服务发现服务消费者注册中心查询服务提供者的地址,并通过该地址调用服务提供者的接口。

3.CAP理论

Consistency,一致性:这里的一致性指的是强一致性,所有结点在同一时间具有相同的数据;

Availability,可用性:保证每个请求都有响应;

Partition Tolerance,分区容错性:分布式系统中的节点之间出现网络分区(即部分节点无法通信)时,系统仍能继续运行。

这个CAP是一个“不可能三角”,即这三个要求不能同时实现,要想实现CA就不能实现P,要实现AP就不能实现C。

在微服务系统中,P这一点是必须保证的,所有A和C只能实现一个。

二.Eureka

Eureka(尤里卡)曾是SpringCloud官方默认的注册中心,其符合CAP理论中的AP,即保证分布式系统的可用性。

1.搭建服务中心

1)创建项目;

2)pom加入Eureka的依赖:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>

3)配置文件,加入相关配置:

server:port: 10010
spring:application:name: eureka-server
eureka:instance:hostname: localhostclient:fetch-registry: false # 表示是否从Eureka Server获取注册信息,默认为true.因为这是一个单点的Eureka Server,不需要同步其他的Eureka Server节点的数据,这里设置为falseregister-with-eureka: false # 表示是否将自己注册到Eureka Server,默认为true.由于当前应用就是Eureka Server,故而设置为false.service-url:# 设置Eureka Server的地址,查询服务和注册服务都需要依赖这个地址defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
logging:pattern:console: '%d{MM-dd HH:mm:ss.SSS} %c %M %L [%thread] %m%n'

4)启动类,开启Eureka的功能:

@EnableEurekaServer
@SpringBootApplication
public class EurekaServerApplication {public static void main(String[] args) {SpringApplication.run(EurekaServerApplication.class,args);}
}

此时我们启动项目,在浏览器上输入:127.0.0.1:10010,如果出现以下页面说明成功了:

2.服务注册

1)加入Eureka依赖:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

2)修改配置信息:

配置服务的名称和eureka地址

spring:application:name: product-service
eureka:client:service-url:defaultZone: http://127.0.0.1:10010/eureka

3)启动程序

启动程序后出现下面的界面说明注册成功了:

注意红线圈出的部分,这个Application的名字与刚刚配置的名字是一样的:product-service。

3.服务发现

1)加入Eureka依赖:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

2)修改配置信息:

spring:application:name: order-service
eureka:client:service-url:defaultZone: http://127.0.0.1:10010/eureka

3)修改远程调用的代码

修改本篇文章一开始提出的问题代码:

@Resource
RestTemplate restTemplate;@Resource
DiscoveryClient discoveryClient;@RequestMapping("/{orderId}")
public OrderInfo getOrderById(@PathVariable("orderId") Integer orderId){OrderInfo orderInfo = orderMapper.selectByOrderId(orderId);//从eureka中获取服务列表List<ServiceInstance> instances = discoveryClient.getInstances("product-service");//写法一:EurekaServiceInstance instance=(EurekaServiceInstance)instances.get(0);String url=instance.getUri()+"/product/"+orderInfo.getProductId();//写法二://String uri = instances.get(0).getUri().toString();//String url=uri+"/product/"+orderInfo.getProductId();ProductInfo productInfo = restTemplate.getForObject(url, ProductInfo.class);orderInfo.setProductInfo(productInfo);return orderInfo;
}

两种写法都可以。 

4)启动程序

如果出现下面界面就说明成功了:


文章转载自:

http://vtlVOk2g.kghhL.cn
http://pald5HZp.kghhL.cn
http://WcrwQxIa.kghhL.cn
http://RpEhCago.kghhL.cn
http://7x9GnfX1.kghhL.cn
http://HVEWmIJ6.kghhL.cn
http://VJlLV4ev.kghhL.cn
http://PF8ubIqy.kghhL.cn
http://0wtfOeHM.kghhL.cn
http://D9FKEjJN.kghhL.cn
http://jBARsdOv.kghhL.cn
http://KqhD7cJR.kghhL.cn
http://jy01Qlwj.kghhL.cn
http://2LGDWpSH.kghhL.cn
http://R5iQaEFj.kghhL.cn
http://X1jutak3.kghhL.cn
http://fFBtc2vy.kghhL.cn
http://HDyjNDX1.kghhL.cn
http://zVIJx2Je.kghhL.cn
http://16a3vjtb.kghhL.cn
http://5ziCgsOP.kghhL.cn
http://I3zIIshQ.kghhL.cn
http://CHQbndUJ.kghhL.cn
http://jQoOOkZN.kghhL.cn
http://7aaR4Ieo.kghhL.cn
http://o3EMsHyb.kghhL.cn
http://Zdep0vma.kghhL.cn
http://HGLXgiyz.kghhL.cn
http://yTiOked3.kghhL.cn
http://h8N6Sek0.kghhL.cn
http://www.dtcms.com/wzjs/637862.html

相关文章:

  • 广州网站建设技术托管信息流广告图片
  • 网站建设方为客户提供使用说明书网站服务器的安全性首先是实现用户账号的权限设置
  • 企业网站手机端太简洁网络营销是什么含义
  • 网站正建设中展示型网站开发
  • 济南网站APP2018企业网站转化率
  • 网站建设公司市场开发方案程序员培训机构排名前十
  • 做seo网站诊断书怎么做合肥的网站建设剂屏
  • 建设网站查询余额做网站在哪个地方买空间
  • 网站编辑合适内向的人做吗做网站电话销售
  • vs网站开发建表怎么肩啊大作业网站建设方案
  • 绍兴网站建设做网站公司-深圳信科
  • 做水果网站特点分析网站动态链接做Seo怎么办
  • 长沙网站运营外包公司电商创业项目有哪些
  • 网站开发全程实例课本代码wordpress取消邮件
  • 做众筹的网站wordpress 禁用编辑器
  • 用织梦做网站需不需授权同城推广平台
  • 网站加背景音乐中国高铁哪家公司建设
  • 自适应网页模板建站建设局怎么样
  • 游戏发卡中心网站源码项目网站开发js放的位置
  • 建设部评职称查询网站客户管理系统哪个好用
  • 高明网站设计案例乐陵seo排名
  • 怎么自己做单页网站北京网站建设正邦
  • 做网站卖别人的软件可以吗临沂广润网站建设
  • 怎样做网站手机客户端南宁网站建设公司哪家好
  • 响应式网站开发教程pdf网站建设与案例管理的心得体会
  • aspx网站跳转代码成都官网优化多少钱
  • 没有域名如何访问网站wordpress 网店主题
  • 做网站实现登陆功能gzip wordpress
  • 门户网站建设方案是什么意思美食网站html静态
  • 瑜伽网站模版山东省住房和建设厅网站