springcloud干貨之服務注冊與發現(Eureka)


springcloud系列文章的第一篇

springcloud服務注冊與發現

   使用Eureka實現服務治理

    作用:實現服務治理(服務注冊與發現)

    簡介:

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

 

項目實戰:

  服務注冊中心 :eureka-server

    作用:服務注冊中心提供服務注冊功能

  服務提供方:eureka-client

    作用:注冊服務到服務注冊中心

   

 

服務注冊中心 :eureka-server

新建一個springboot項目:eureka-server,其pom.xml配置如下:

 1 <properties>
 2         <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
 3         <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
 4         <java.version>1.8</java.version>
 5     </properties>
 6     <dependencies>
 7         <dependency>
 8             <groupId>org.springframework.cloud</groupId>
 9             <artifactId>spring-cloud-starter-eureka-server</artifactId>
10         </dependency>
11     </dependencies>
12     <dependencyManagement>
13         <dependencies>
14             <dependency>
15                 <groupId>org.springframework.cloud</groupId>
16                 <artifactId>spring-cloud-dependencies</artifactId>
17                 <version>Dalston.SR1</version>
18                 <type>pom</type>
19                 <scope>import</scope>
20             </dependency>
21         </dependencies>
22     </dependencyManagement>

 

想要實現一個服務注冊中心的功能非常簡單,只需要在項目的啟動類EurekaServerApplication上使用@EnableEurekaServer注解即可
1 @EnableEurekaServer
2 @SpringBootApplication
3 public class EurekaServerApplication{
4 
5     public static void main(String[] args) {
6         new SpringApplicationBuilder(EurekaServerApplication.class)
7                     .web(true).run(args);
8     }
9 }
默認情況下,該服務注冊中心也會將自己作為客戶端來嘗試注冊它自己,所以我們需要禁用它的客戶端注冊行為,只需要在application.properties配置文件中增加如下信息:
1 spring.application.name=eureka-server
2 server.port=1001
3 eureka.instance.hostname=localhost
4 eureka.client.register-with-eureka=false
5 eureka.client.fetch-registry=false
 
啟動EurekaServerApplication,訪問 http://localhost:9001/可以看到Eureka的頁面,從紅框的位置可以看到沒有任務服務實例注冊到當前的服務注冊中心
 

 

服務提供方 :eureka-client

     每一個實例注冊之后需要向注冊中心發送心跳,當client向server注冊時,它會提供一些元數據,例如主機和端口,URL,主頁等。Eureka server 從每個client實例接收心跳消息。 如果心跳超時,則通常將該實例從注冊server中刪除。

新建一個springboot項目:eureka-client,其pom.xml配置如下:

 1 <properties>
 2         <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
 3         <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
 4         <java.version>1.8</java.version>
 5     </properties>
 6     <dependencies>
 7         <dependency>
 8             <groupId>org.springframework.cloud</groupId>
 9             <artifactId>spring-cloud-starter-eureka</artifactId>
10         </dependency>
11         <dependency>
12             <groupId>org.springframework.boot</groupId>
13             <artifactId>spring-boot-starter-web</artifactId>
14         </dependency>
15     </dependencies>
16     <dependencyManagement>
17         <dependencies>
18             <dependency>
19                 <groupId>org.springframework.cloud</groupId>
20                 <artifactId>spring-cloud-dependencies</artifactId>
21                 <version>Dalston.SR1</version>
22                 <type>pom</type>
23                 <scope>import</scope>
24             </dependency>
25         </dependencies>
26     </dependencyManagement>

想要實現一個服務提供方也很簡單,只要在項目的啟動類EurekaClientApplication上使用@EnableEurekaClient注解即可

 1 @EnableEurekaClient
 2 @SpringBootApplication
 3 public class EurekaClientApplication {
 4 
 5      public static void main(String[] args) {
 6             new SpringApplicationBuilder(
 7                     EurekaClientApplication.class)
 8                 .web(true).run(args);
 9         }
10 }

在application.properties中進行如下配置

spring.application.name=eureka-client
server.port=9002
eureka.client.serviceUrl.defaultZone=http://localhost:9001/eureka/

  通過spring.application.name屬性,我們可以指定微服務的名稱后續在調用的時候只需要使用該名稱就可以進行服務的訪問。

  eureka.client.serviceUrl.defaultZone屬性對應服務注冊中心的配置內容,指定服務注冊中心的位置。

  使用server.port屬性設置不同的端口。

 

啟動EurekaClientApplication類

刷新 http://localhost:9001/,可以看到咱們的服務提供方已經注冊到了服務注冊中心

 

在新建一個DiscoveryController

   使用discoveryClient.getServices()獲取已經注冊的服務名,使用@value將配置文件中的信息賦值到ip

@RestController
public class DiscoveryController {
    
    @Autowired
    private DiscoveryClient discoveryClient;
    @Value("${server.port}")
    private String ip;
    
    @GetMapping("/client")
    public String client() {
        String services = "Services: " + discoveryClient.getServices()+" ip :"+ip;
        
        System.out.println(services);
        return services;
    }
}

訪問:http://localhost:9002/client

 

最后說明一下@EnableEurekaClient 與@EnableDiscoveryClient這兩個注解

 首先這個兩個注解都可以實現服務發現的功能,在spring cloud中discovery service有許多種實現(eureka、consul、zookeeper等等)

   @EnableEurekaClient基於spring-cloud-netflix。服務采用eureka作為注冊中心,使用場景較為單一。

   @EnableDiscoveryClient基於spring-cloud-commons。服務采用其他注冊中心。

 


碼雲:https://gitee.com/cmy1996/springcloud 點我查看
 
GitHub:https://github.com/mingyuHub/springcloud 點我查看

 

參考文獻:

  翟永超:http://blog.didispace.com/spring-cloud-starter-dalston-1/

  方志鵬:http://blog.csdn.net/forezp/article/details/70148833#t0

 


歡迎關注本人公眾號,掃碼發現更多精彩內容       

      本文為原創文章,歡迎轉載,轉載請注明作者


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM