亚洲中字慕日产2020,大陆极品少妇内射AAAAAA,无码av大香线蕉伊人久久,久久精品国产亚洲av麻豆网站

資訊專欄INFORMATION COLUMN

SpringCloud構(gòu)建微服務(wù)架構(gòu):服務(wù)注冊與發(fā)現(xiàn)

lakeside / 3100人閱讀

摘要:創(chuàng)建服務(wù)注冊中心創(chuàng)建一個(gè)基礎(chǔ)的工程,命名為,并在中引入需要的依賴內(nèi)容通過注解啟動(dòng)一個(gè)服務(wù)注冊中心提供給其他應(yīng)用進(jìn)行對話。

1.Spring Cloud簡介

Spring Cloud是一個(gè)基于Spring Boot實(shí)現(xiàn)的云應(yīng)用開發(fā)工具,它為基于JVM的云應(yīng)用開發(fā)中涉及的配置管理、服務(wù)發(fā)現(xiàn)、斷路器、智能路由、微代理、控制總線、全局鎖、決策競選、分布式會(huì)話和集群狀態(tài)管理等操作提供了一種簡單的開發(fā)方式。

Spring Cloud包含了多個(gè)子項(xiàng)目(針對分布式系統(tǒng)中涉及的多個(gè)不同開源產(chǎn)品),比如:Spring Cloud Config、Spring Cloud Netflix、Spring Cloud0 CloudFoundry、Spring Cloud AWS、Spring Cloud Security、Spring Cloud Commons、Spring Cloud Zookeeper、Spring Cloud CLI等項(xiàng)目。

2.微服務(wù)架構(gòu)

“微服務(wù)架構(gòu)”在這幾年非常的火熱,以至于關(guān)于微服務(wù)架構(gòu)相關(guān)的開源產(chǎn)品被反復(fù)的提及(比如:netflix、dubbo),Spring Cloud也因Spring社區(qū)的強(qiáng)大知名度和影響力也被廣大架構(gòu)師與開發(fā)者備受關(guān)注。

那么什么是“微服務(wù)架構(gòu)”呢?簡單的說,微服務(wù)架構(gòu)就是將一個(gè)完整的應(yīng)用從數(shù)據(jù)存儲開始垂直拆分成多個(gè)不同的服務(wù),每個(gè)服務(wù)都能獨(dú)立部署、獨(dú)立維護(hù)、獨(dú)立擴(kuò)展,服務(wù)與服務(wù)間通過諸如RESTful API的方式互相調(diào)用。

對于“微服務(wù)架構(gòu)”,可以閱讀始祖Martin Fowler的《Microservices》(中文版翻譯點(diǎn)擊查看)

3.Spring Cloud Eureka

Spring Cloud Eureka是Spring Cloud Netflix項(xiàng)目下的服務(wù)治理模塊。而Spring Cloud Netflix項(xiàng)目是Spring Cloud的子項(xiàng)目之一,主要內(nèi)容是對Netflix公司一系列開源產(chǎn)品的包裝,它為Spring Boot應(yīng)用提供了自配置的Netflix OSS整合。通過一些簡單的注解,開發(fā)者就可以快速的在應(yīng)用中配置一下常用模塊并構(gòu)建龐大的分布式系統(tǒng)。它主要提供的模塊包括:服務(wù)發(fā)現(xiàn)(Eureka),斷路器(Hystrix),智能路由(Zuul),客戶端負(fù)載均衡(Ribbon)等。

下面,就來具體看看如何使用Spring Cloud Eureka實(shí)現(xiàn)服務(wù)治理。

3.1 創(chuàng)建“服務(wù)注冊中心”

創(chuàng)建一個(gè)基礎(chǔ)的Spring Boot工程,命名為eureka-server,并在pom.xml中引入需要的依賴內(nèi)容:


    org.springframework.boot
    spring-boot-starter-parent
    1.5.4.RELEASE
    



    
        org.springframework.cloud
        spring-cloud-starter-eureka-server
    



    
        
           org.springframework.cloud
           spring-cloud-dependencies
           Dalston.SR1
           <type>pomtype>
           import
        
    

通過@EnableEurekaServer注解啟動(dòng)一個(gè)服務(wù)注冊中心提供給其他應(yīng)用進(jìn)行對話。這一步非常的簡單,只需要在一個(gè)普通的Spring Boot應(yīng)用中添加這個(gè)注解就能開啟此功能,比如下面的例子:

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

在默認(rèn)設(shè)置下,該服務(wù)注冊中心也會(huì)將自己作為客戶端來嘗試注冊它自己,所以我們需要禁用它的客戶端注冊行為,只需要在application.properties配置文件中增加如下信息:

spring.application.name=eureka-server
server.port=1001

eureka.instance.hostname=localhost
eureka.client.register-with-eureka=false
eureka.client.fetch-registry=false

為了與后續(xù)要進(jìn)行注冊的服務(wù)區(qū)分,這里將服務(wù)注冊中心的端口通過server.port屬性設(shè)置為1001。啟動(dòng)工程后,訪問:http://localhost:1001/,可以看到下面的頁面,其中還沒有發(fā)現(xiàn)任何服務(wù)。

3.2 創(chuàng)建“服務(wù)提供方”

下面我們創(chuàng)建提供服務(wù)的客戶端,并向服務(wù)注冊中心注冊自己。

首先,創(chuàng)建一個(gè)基本的Spring Boot應(yīng)用。命名為eureka-client,在pom.xml中,加入如下配置:

 
    org.springframework.boot
    spring-boot-starter-parent
    1.5.4.RELEASE
     



    
        org.springframework.cloud
        spring-cloud-starter-eureka
    
    
        org.springframework.boot
        spring-boot-starter-web
    



    
        
           org.springframework.cloud
           spring-cloud-dependencies
           Dalston.SR1
           <type>pomtype>
           import
        
    

然后,創(chuàng)建/dc請求處理接口,通過DiscoveryClient對象,在日志中打印出服務(wù)實(shí)例的相關(guān)內(nèi)容。

@RestController
public class DcController {

    @Autowired
    DiscoveryClient discoveryClient;

    @GetMapping("/dc")
    public String dc() {
        String services = "Services: " + discoveryClient.getServices();
        System.out.println(services);
        return services;
    }
}

最后在應(yīng)用主類中通過加上@EnableDiscoveryClient注解,該注解能激活Eureka中的DiscoveryClient實(shí)現(xiàn),這樣才能實(shí)現(xiàn)Controller中對服務(wù)信息的輸出。

@EnableDiscoveryClient
@SpringBootApplication
public class Application {
    public static void main(String[] args) {
        new SpringApplicationBuilder(
            ComputeServiceApplication.class)
            .web(true).run(args);
    }
}

我們在完成了服務(wù)內(nèi)容的實(shí)現(xiàn)之后,再繼續(xù)對application.properties做一些配置工作,具體如下:

通過spring.application.name屬性,我們可以指定微服務(wù)的名稱后續(xù)在調(diào)用的時(shí)候只需要使用該名稱就可以進(jìn)行服務(wù)的訪問。eureka.client.serviceUrl.defaultZone屬性對應(yīng)服務(wù)注冊中心的配置內(nèi)容,指定服務(wù)注冊中心的位置。為了在本機(jī)上測試區(qū)分服務(wù)提供方和服務(wù)注冊中心,使用server.port屬性設(shè)置不同的端口。

啟動(dòng)該工程后,再次訪問:http://localhost:1001。如下圖,就注冊成功了。

我們也可以通過直接訪問eureka-client服務(wù)提供的/dc接口來獲取當(dāng)前的服務(wù)清單,只需要訪問:http://localhost:2001/dc,可以得到一下輸出:

其中,方括號中的eureka-client就是通過Spring Cloud定義的DiscoveryClient接口在eureka的實(shí)現(xiàn)中獲取到的所有服務(wù)清單。

還可以參考spring cloud

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://www.ezyhdfw.cn/yun/7026.html

相關(guān)文章

  • 架構(gòu)服務(wù)

    摘要:接下來繼續(xù)介紹三種架構(gòu)模式,分別是查詢分離模式微服務(wù)模式多級緩存模式。分布式應(yīng)用程序可以基于實(shí)現(xiàn)諸如數(shù)據(jù)發(fā)布訂閱負(fù)載均衡命名服務(wù)分布式協(xié)調(diào)通知集群管理選舉分布式鎖和分布式隊(duì)列等功能。 SpringCloud 分布式配置 SpringCloud 分布式配置 史上最簡單的 SpringCloud 教程 | 第九篇: 服務(wù)鏈路追蹤 (Spring Cloud Sleuth) 史上最簡單的 S...

    xinhaip 評論0 收藏0
  • 架構(gòu)服務(wù) - 收藏集 - 掘金

    摘要:它就是史上最簡單的教程第三篇服務(wù)消費(fèi)者后端掘金上一篇文章,講述了通過去消費(fèi)服務(wù),這篇文章主要講述通過去消費(fèi)服務(wù)。概覽和架構(gòu)設(shè)計(jì)掘金技術(shù)征文后端掘金是基于的一整套實(shí)現(xiàn)微服務(wù)的框架。 Spring Boot 配置文件 – 在坑中實(shí)踐 - 后端 - 掘金作者:泥瓦匠鏈接:Spring Boot 配置文件 – 在坑中實(shí)踐版權(quán)歸作者所有,轉(zhuǎn)載請注明出處本文提綱一、自動(dòng)配置二、自定義屬性三、ran...

    church 評論0 收藏0
  • SpringCloud打造服務(wù)平臺--概覽

    摘要:授權(quán)框架使第三方應(yīng)用程序來獲取對服務(wù)的有限訪問機(jī)會(huì)。無論是通過編排資源所有者和服務(wù)之間的交互批準(zhǔn)的資源所有者,或通過允許第三方應(yīng)用程序來獲取自己的訪問權(quán)限。 SpringCloud打造微服務(wù)平臺--概覽 簡述 SpringCloud是什么 Spring Boot和SpringCloud是什么關(guān)系 Spring Boot是Spring的一套快速WEB開發(fā)的腳手架,可建立獨(dú)立的Sprin...

    siberiawolf 評論0 收藏0

發(fā)表評論

0條評論

最新活動(dòng)
閱讀需要支付1元查看
<