微服務(wù)eureka和nacos案例詳解
服務(wù)遠(yuǎn)程調(diào)用
/**
* 創(chuàng)建RestTemplate并注入Spring容器
* @return
*/
@Bean
public RestTemplate restTemplate(){
return new RestTemplate();
}@Autowired
private RestTemplate restTemplate;
public Order queryOrderById(Long orderId) {
// 1.查詢訂單
Order order = orderMapper.findById(orderId);
// 2.利用RestTemplate發(fā)起HTTP請(qǐng)求,查詢用戶
// 2.1.url路徑
String url="http://localhost:8081/user/"+order.getUserId();
// 2.2.發(fā)送HTTP請(qǐng)求,實(shí)現(xiàn)遠(yuǎn)程調(diào)用
User user = restTemplate.getForObject(url, User.class);
// 3.封裝user到order對(duì)象
order.setUser(user);
// 4.返回
return order;
}搭建eureka服務(wù)
第一步:注入依賴
<dependency>
<!--eureka服務(wù)端-->
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifact
</dependency>第二步:使用@EnableEurekaServer
@EnableEurekaServer
@SpringBootApplication
public class EurekaApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaApplication.class,args);
}
}第三步:application.yml文件
server:
port: 10086 # 服務(wù)端口
spring:
application:
name: eurekaserver # eureka的服務(wù)名稱
eureka:
client:
service-url: # eureka的地址信息
defaultZone: http://127.0.0.1:10086/eureka解釋說(shuō)明: eureka-server自己也是個(gè)微服務(wù),也需要服務(wù)名稱,而且還需要配置eureka的地址(疑問(wèn):我自己就是eureka,為什么還要配置地址信息)剛才說(shuō)了eureka-server自己就是微服務(wù),所以eureka-server在啟動(dòng)的時(shí)候自己也注冊(cè)到eureka上(這是為了將來(lái)eureka集群之間通信去用的,比方說(shuō)我啟動(dòng)2個(gè)或3個(gè)eureka,將來(lái)3個(gè)eureka之間會(huì)互相做注冊(cè),那么這樣他們就可以做數(shù)據(jù)交流)上面defaultZone配置的是eureka集群的地址,有多個(gè)的話用逗號(hào)隔開(kāi),因?yàn)檫@里是單機(jī),所以配置的只有自己(重點(diǎn)來(lái)了:這里的服務(wù)名稱和地址信息都是做服務(wù)的注冊(cè))

服務(wù)注冊(cè)
第一步:項(xiàng)目user-service引入依賴
<!--eureka客戶端依賴-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>第二步:配置application.yml文件
spring:
application:
name: userservice # eureka的服務(wù)名稱
eureka:
client:
service-url: # eureka的地址信息
defaultZone: http://127.0.0.1:10086/eureka
idea創(chuàng)建多個(gè)實(shí)例,可以在UserApplication右擊出現(xiàn)copy Configuration彈出窗口,環(huán)境配置端口點(diǎn)擊應(yīng)用就行了


服務(wù)發(fā)現(xiàn)(服務(wù)注冊(cè)基礎(chǔ)上添加額外2個(gè)步驟)
第一步:在RestTemplate上添加@LoadBalanced注解
/**
* 創(chuàng)建RestTemplate并注入Spring容器
* @return
*/
@LoadBalanced
@Bean
public RestTemplate restTemplate(){
return new RestTemplate();
}第二步:使用服務(wù)名稱來(lái)代替原來(lái)的ip和端口
@Autowired
private OrderMapper orderMapper;
@Autowired
private RestTemplate restTemplate;
public Order queryOrderById(Long orderId) {
// 1.查詢訂單
Order order = orderMapper.findById(orderId);
// 2.利用RestTemplate發(fā)起HTTP請(qǐng)求,查詢用戶
// 2.1.url路徑
// String url="http://localhost:8081/user/"+order.getUserId();
String url="http://userservice/user/"+order.getUserId();
// 2.2.發(fā)送HTTP請(qǐng)求,實(shí)現(xiàn)遠(yuǎn)程調(diào)用
User user = restTemplate.getForObject(url, User.class);
// 3.封裝user到order對(duì)象
order.setUser(user);
// 4.返回
return order;
}負(fù)載均衡

一:代碼方式:在order-service中的OrderApplication類中,定義一個(gè)新的IRule(全局生效)
@Bean
public IRule randomRule(){
return new RandomRule();
}二:配置文件方式(局部生效)
userservice:
ribbon:
NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule # 負(fù)載均衡規(guī)則饑餓加載
Ribbon默認(rèn)采用懶加載,即第一次訪問(wèn)時(shí)才會(huì)去創(chuàng)建LoadBalanceClient,請(qǐng)求時(shí)間會(huì)很長(zhǎng),而饑餓加載則會(huì)在項(xiàng)目啟動(dòng)時(shí)創(chuàng)建,降低第一次訪問(wèn)的耗時(shí),通過(guò)下面配置饑餓加載
ribbon:
eager-load:
enabled: true # 開(kāi)啟饑餓加載
clients: # 指定饑餓加載的服務(wù)名稱 這是一個(gè)集合
- userserviceNacos啟動(dòng)命令
-m參數(shù)含義是模式model standalone含義是單機(jī)啟動(dòng)
startup.cmd -m standalone
服務(wù)注冊(cè)到Nacos
第一步:在cloud-demo父工程中添加spring-cloud-alibaba的管理依賴
<!--nacos的管理依賴-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>2.2.5.RELEASE</version>
<type>pom</type>
<scope>import</scope>
</dependency>第二步:注釋掉order-service和user-service中pom.xml文件原有的eureka依賴
第三步:添加nacos的客戶端依賴
<!--nacos客戶端依賴包-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>第四步:修改user-service和order-service中的application.yml文件,注釋eureka地址,添加nacos地址
spring:
cloud:
nacos:
server-addr: localhost:8848 # nacos 服務(wù)端地址第五步:?jiǎn)?dòng)OrderApplication、UserApplication1、UserApplication2并測(cè)試

nacos服務(wù)分級(jí)存儲(chǔ)模型
服務(wù)跨集群調(diào)用問(wèn)題
服務(wù)調(diào)用盡可能選擇本地集群的服務(wù),跨集群調(diào)用延遲較高,本地集群不可訪問(wèn)時(shí),再去訪問(wèn)其它集群
服務(wù)集群屬性
修改application.yml,添加以下內(nèi)容
spring:
cloud:
nacos:
server-addr: localhost:8848 # nacos 服務(wù)端地址
discovery:
cluster-name: HZ # 配置集群名稱,也就是機(jī)房位置 HZ杭州 SH上海
一旦停掉本地集群的服務(wù),就會(huì)發(fā)生跨集群調(diào)用,出現(xiàn)警告信息,方便運(yùn)維人員知道
A cross-cluster call occurs,name = userservice, clusterName = HZ, instance = [Instance{instanceId='192.168.31.69#8083#SH#DEFAULT_GROUP@@userservice', ip='192.168.31.69', port=8083, weight=1.0, healthy=true, enabled=true, ephemeral=true, clusterName='SH', serviceName='DEFAULT_GROUP@@userservice', metadata={preserved.register.source=SPRING_CLOUD}}]
根據(jù)權(quán)重負(fù)載均衡

編輯修改權(quán)重
環(huán)境隔離
新建命名空間

新增成功會(huì)生成一個(gè)UUID,需要去idea配置application.yml
spring:
cloud:
nacos:
server-addr: localhost:8848 # nacos 服務(wù)端地址
discovery:
cluster-name: HZ # 配置集群名稱,也就是機(jī)房位置 HZ杭州 SH上海
namespace: a0c14ea6-b75e-4a73-beb5-94e5f496a744 # dev 開(kāi)發(fā)環(huán)境

到此這篇關(guān)于微服務(wù)eureka和nacos的文章就介紹到這了,更多相關(guān)微服務(wù)eureka內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MyBatis Plus 入門(mén)使用詳細(xì)教程
這篇文章主要介紹了MyBatis Plus 入門(mén)使用詳細(xì)教程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08
java字符串轉(zhuǎn)JSON簡(jiǎn)單代碼示例
這篇文章主要給大家介紹了關(guān)于java字符串轉(zhuǎn)JSON的相關(guān)資料,JSON?是一種輕量級(jí)的數(shù)據(jù)交換格式,常用于Web應(yīng)用程序中的數(shù)據(jù)傳輸,文中通過(guò)代碼示例介紹的非常詳細(xì),需要的朋友可以參考下2023-09-09
Object.wait()與Object.notify()的用法詳細(xì)解析
以下是對(duì)java中Object.wait()與Object.notify()的用法進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下2013-09-09
詳解Java如何實(shí)現(xiàn)有效的并發(fā)處理
隨著互聯(lián)網(wǎng)的蓬勃發(fā)展,現(xiàn)代軟件系統(tǒng)對(duì)于并發(fā)性能的要求越來(lái)越高,如何學(xué)習(xí)和掌握并發(fā)編程技術(shù)成為了Java開(kāi)發(fā)人員必備的技能之一,本文主要介紹了Java并發(fā)編程的相關(guān)概念、原理和實(shí)踐技巧,感興趣的可以了解下2023-11-11
gradle構(gòu)建工具和java不兼容錯(cuò)誤的解決方案
這篇文章主要介紹了如何解決AS中Gradle和Java版本不兼容的問(wèn)題,主要解決方案包括升級(jí)Gradle版本或降級(jí)Java版本,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2025-02-02

