亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

SpringCloud如何使用Eureka實(shí)現(xiàn)服務(wù)之間的傳遞數(shù)據(jù)

 更新時(shí)間:2021年06月09日 14:37:27   作者:IT界劉德華  
這篇文章主要介紹了SpringCloud使用Eureka實(shí)現(xiàn)服務(wù)之間的傳遞數(shù)據(jù)操作,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

相信大家最關(guān)心的肯定不是什么一大堆的破理論,然后還似懂非懂的,最關(guān)心得莫過于服務(wù)之間的參數(shù)傳遞,數(shù)據(jù)獲取。

Ok,今天就告訴大家三種微服務(wù)之間傳輸數(shù)據(jù)的方式,分別是:

1、最基本的利用Ip端口進(jìn)行請求訪問接口實(shí)現(xiàn)數(shù)據(jù)的傳輸

2、使用Eureka取代Ip(硬編碼)的方式實(shí)現(xiàn)數(shù)據(jù)的傳輸

3、使用Feign更加快捷"分服務(wù)"的方式實(shí)現(xiàn)微服務(wù)之間的數(shù)據(jù)傳輸(對Feign一點(diǎn)不了解的暫時(shí)不用理解,就是SpringCloud的組成的一部分后期會(huì)進(jìn)行詳細(xì)講解,在此處講解只是為自己mark一下)

前提:搭建好Eureka注冊中心,假設(shè)現(xiàn)在有一個(gè)訂單微服務(wù)(服務(wù)消費(fèi)者),一個(gè)用戶微服務(wù)(服務(wù)提供者),然后需要訂單微服務(wù)調(diào)用用戶微服務(wù),獲取用戶的信息,并且兩個(gè)服務(wù)都能正常運(yùn)行,為了方便此處使用SpringJpa的方式獲取數(shù)據(jù)。

一、使用RestTemplate+Ip方式:

1、傳遞數(shù)據(jù)大部分就是以集合和對象的形式進(jìn)行傳遞,所以在這里就用集合和對象的方式為例

在用戶微服務(wù)(服務(wù)提供者)中寫好被調(diào)用的查詢方法

@RestController
@RequestMapping("/user")
public class UserController {
 
    @Resource
    private UserRepository userRepository;
 
    @GetMapping("/getallUser")
    public List<User> getUserPage(){
        return userRepository.findAll();
    }
 
    @GetMapping("/getUser")
    public User getUser(Long userId){
        return userRepository.getOne(userId);
    }
}
@Repository
public interface UserRepository extends JpaRepository<User,Long> {
}
@Entity
@Table(name="TM_USER")
@JsonIgnoreProperties(value={"hibernateLazyInitializer","handler","fieldHandler"})
public class User implements Serializable, Cloneable {
 
    @Id
    @GeneratedValue(strategy= GenerationType.AUTO)
    private Long userId;
 
    /**
     * 登錄名
     */
    @Column(name = "USER_NAME")
    private String userName;
 
    /**
     * 用戶名
     */
    @Column
    private String name;
 
    /**
     * 薪水
     */
    @Column
    private BigDecimal balance;
 
    /**
     * 年齡  get set方法已省略 自行添加
     */
    @Column
    private int age;}

Ok,服務(wù)提供者已經(jīng)寫好,下面開始編寫服務(wù)消費(fèi)者

2、在訂單微服務(wù)(服務(wù)消費(fèi)者)的啟動(dòng)類中添加生成RestTemplate的Bean

@SpringBootApplication
@EnableEurekaClient  //啟用eureka客戶端
public class MicroserviceSimplecConsumerOrderServerApplication {
 
 @Bean
 public RestTemplate restTemplate(){
  return new RestTemplate();
 }
 
 public static void main(String[] args) {
  SpringApplication.run(MicroserviceSimplecConsumerOrderServerApplication.class, args);
 }
}

在訂單微服務(wù)(服務(wù)消費(fèi)者)配置文件yml中添加,其中l(wèi)ocalhost:9021改為用戶微服務(wù)(服務(wù)提供者的Ip和端口)

user:
  urlPath: http://localhost:9021

訂單服務(wù)控制層編寫,此處的User為用戶微服務(wù)的復(fù)制然后去掉@Column、@Table等注釋只是一個(gè)臨時(shí)存儲(chǔ)對象和數(shù)據(jù)庫沒有任何關(guān)聯(lián)

@RestController
@RequestMapping("/order")
public class OrderServerController {
 
    @Autowired
    private RestTemplate restTemplate;
 
    @Value("${user.urlPath}")
    private String urlPath;
    //獲取集合方式
    @GetMapping("/allUser")
    private List<User> getAllUser(){
        ResponseEntity<List<User>> responseEntity = restTemplate.exchange("urlPath"+/user/getallUser?",
                HttpMethod.GET, null, new ParameterizedTypeReference<List<User>>() {});
        return responseEntity.getBody();
    }
    //獲取單個(gè)對象方式
    @GetMapping("/getUser")
    private User getUser(Long userId){
        User user = restTemplate.getForObject("urlPath"+/user/getUser?userId="+userId,User.class);
        return user;
    }
}

二、使用Eureka的方式獲取

很簡單就是直接把訂單微服務(wù)(服務(wù)消費(fèi)者)OrderServerController中的userPath替換為注冊Eureka上面的服務(wù)名即可就是這么簡單。假設(shè)用戶微服務(wù)的服務(wù)名為:microservice-privider-user

spring:
  application:
    name: microservice-privider-user

然后就可以直接進(jìn)行替換處理,即:

@GetMapping("/allUser")  //返回集合
   private List<User> getAllUser(){
        ResponseEntity<List<User>> responseEntity = restTemplate.exchange("microservice-privider-user"+"/user/getallUser", HttpMethod.GET, null, new ParameterizedTypeReference<List<User>>() {});
        return responseEntity.getBody();
    }
//返回對象
    @GetMapping("/getUser")
    private User getUser(Long userId){
        User user = restTemplate.getForObject("microservice-privider-user"+/user/getUser?userId="+userId,User.class);
        return user;
    }

Ok,使用第二種方式已經(jīng)編寫完成

使用服務(wù)名替換了固定的ip,解決了Ip硬編碼不容易維護(hù)的問題

至于第三種Feign的方式會(huì)在以后講解“Feign:聲明性Rest客戶端”的時(shí)候進(jìn)行詳細(xì)講解

gitHub地址:https://github.com/mackjie/microservice-spring-cloud因?yàn)榕渲昧薘abbitMQ,所以請先閱讀ReadMe然后進(jìn)行啟動(dòng)項(xiàng)目,否則會(huì)啟動(dòng)報(bào)錯(cuò)

springcloud學(xué)習(xí)之Eureka Client搭建和服務(wù)間調(diào)用

Eureka Client搭建:

一、引入pom依賴

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

二、啟動(dòng)類推薦添加@EnableEurekaClient注解

就是如果選用的注冊中心是eureka,那么就推薦@EnableEurekaClient,

如果是其他的注冊中心(zookeeper,consul等),那么推薦使用@EnableDiscoveryClient。

三、配置文件添加:

#eureka
spring.application.name=producer
#注冊中心地址
eureka.client.service-url.defaultZone=http://localhost:8761/eureka
#是否把自己注冊
eureka.client.register-with-eureka=true
#是否搜索服務(wù)信息
eureka.client.fetch-registry=true
 
#使用ip地址注冊
eureka.instance.prefer-ip-address=true
#注冊中心列表顯示的狀態(tài)
eureka.instance.instance-id=${spring.cloud.client.ip-address}:${server.port}

服務(wù)調(diào)用:

有兩種方式:

一、ribbon(負(fù)載均衡)+restTemplate

啟動(dòng)類添加:

@Bean
@LoadBalanced//負(fù)載均衡
public RestTemplate initRestTemplate() {
 return new RestTemplate();//
 }
 
 @Bean//負(fù)載均衡的規(guī)則,下面的是其中之一:隨機(jī),還有權(quán)重,輪詢等
 public IRule initIRule() {
  return new RandomRule();
 }

RandomRule表示隨機(jī)策略

RoundRobinRule表示輪詢策略(默認(rèn))

WeightedResponseTimeRule表示加權(quán)策略

BestAvailableRule表示請求數(shù)最少策略

然后在controller中自動(dòng)裝配RestTemplate后使用 restTemplate.getForObject()調(diào)用。

二、feign(推薦)

1、引入pom依賴

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
    <version>2.1.1.RELEASE</version>
</dependency>

2、啟動(dòng)類添加@EnableFeignClients注解

3、創(chuàng)建一個(gè)接口,

package com.sumengnan.test.web;
 
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
 
@FeignClient(name = "eureka",fallback = HtystrixEurekaFallback.class)//調(diào)用失敗后回滾執(zhí)行方法
public interface EurekaServiceApi {
    @GetMapping("test")
    String test();
}

回滾的方法:

package com.sumengnan.test.web;
 
/**
 * eureka熔斷回調(diào)類
 */
public class HtystrixEurekaFallback implements EurekaServiceApi {
    @Override
    public String test() {
        return "連接失敗,請稍后再試!";
    }
}

4、然后在controller中自動(dòng)裝配EurekaServiceApi后使用eurekaServiceApi.test()調(diào)用。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java細(xì)數(shù)IO流底層原理到方法使用

    Java細(xì)數(shù)IO流底層原理到方法使用

    IO主要用于設(shè)備之間的數(shù)據(jù)傳輸,Java將操作數(shù)據(jù)流的功能封裝到了IO包中,這篇文章主要給大家介紹了關(guān)于Java新手學(xué)習(xí)之IO流簡單使用的相關(guān)資料,需要的朋友可以參考下
    2022-05-05
  • MybatisPlus中QueryWrapper常用方法總結(jié)

    MybatisPlus中QueryWrapper常用方法總結(jié)

    MyBatis-Plus是一個(gè)Mybatis增強(qiáng)版工具,在MyBatis上擴(kuò)充了其他功能沒有改變其基本功能,為了簡化開發(fā)提交效率而存在,queryWrapper是mybatis plus中實(shí)現(xiàn)查詢的對象封裝操作類,本文就給大家總結(jié)了MybatisPlus中QueryWrapper的常用方法,需要的朋友可以參考下
    2023-07-07
  • 使用spring-cache一行代碼解決緩存擊穿問題

    使用spring-cache一行代碼解決緩存擊穿問題

    本文主要介紹了使用spring-cache一行代碼解決緩存擊穿問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • 詳解SpringBoot讀取resource目錄下properties文件的常見方式

    詳解SpringBoot讀取resource目錄下properties文件的常見方式

    這篇文章主要介紹了SpringBoot讀取resource目錄下properties文件的常見方式,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-02-02
  • java面向?qū)ο笤O(shè)計(jì)原則之開閉原則示例解析

    java面向?qū)ο笤O(shè)計(jì)原則之開閉原則示例解析

    這篇文章主要介紹了java面向?qū)ο笤O(shè)計(jì)原則之開閉原則的示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2021-10-10
  • Sprint Boot 集成MongoDB的操作方法

    Sprint Boot 集成MongoDB的操作方法

    最近接手一個(gè)Springboot項(xiàng)目,需要在原項(xiàng)目上增加一些需求,用到了mongodb。下面通過本文給大家分享Sprint Boot 集成MongoDB的操作方法,需要的朋友參考下吧
    2017-12-12
  • Java數(shù)組反轉(zhuǎn)方式

    Java數(shù)組反轉(zhuǎn)方式

    這篇文章主要介紹了Java數(shù)組反轉(zhuǎn)方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • Java設(shè)計(jì)模式之單例模式詳解

    Java設(shè)計(jì)模式之單例模式詳解

    這篇文章主要為大家詳細(xì)介紹了Java設(shè)計(jì)模式之單例模式的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • Java中的MapStruct用法詳解

    Java中的MapStruct用法詳解

    這篇文章主要介紹了Java中的MapStruct用法詳解,MapStuct的使用非常簡單,把對應(yīng)的jar包引入即可,本文通過示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-04-04
  • Java本地緩存工具之LoadingCache的使用詳解

    Java本地緩存工具之LoadingCache的使用詳解

    緩存,在我們?nèi)粘i_發(fā)中是必不可少的一種解決性能問題的方法。簡單的說,cache?就是為了提升系統(tǒng)性能而開辟的一塊內(nèi)存空間。本文將為大家介紹一個(gè)Java本地緩存的工具——LoadingCache,感興趣的可以了解一下
    2021-12-12

最新評論