使用Spring Cloud搭建服務註冊中心

咱們在以前的博客中已經介紹過阿里的分佈式服務框架dubbo【Linux上安裝Zookeeper以及一些注意事項】【一個簡單的案例帶你入門Dubbo分佈式框架】,可是小夥伴們應該也看到了,阿里的dubbo沒法單獨完成工做,咱們還要藉助於Apache上的開源框架zookeeper(不是必須,可是最佳實踐莫過於zookeeper),使用zookeeper做爲服務註冊中心,才能實現一個較好的分佈式應用。與dubbo不一樣的是,Spring Cloud是一個一站式分佈式框架,Spring Cloud爲開發人員提供了快速構建分佈式系統中一些常見模式的工具(例如配置管理,服務發現,斷路器,智能路由,微代理,控制總線)。分佈式系統的協調致使了樣板模式, 使用Spring Cloud開發人員能夠快速地支持實現這些模式的服務和應用程序。他們將在任何分佈式環境中運行良好,包括開發人員本身的筆記本電腦,裸機數據中心,以及Cloud Foundry等託管平臺。那麼今天我但願經過一個簡單的案例帶小夥伴們來了解下Spring Cloud。java


OK,那麼本文我主要想介紹下在Spring Cloud中使用Eureka搭建一個服務註冊中心,而後再向其中註冊服務。因爲Spring Cloud是在Spring Boot的基礎上構建分佈式服務的,因此閱讀本文須要有一點Spring Boot的知識儲備,若是小夥伴們對Spring Boot尚不太熟悉的話,能夠先參考下【https://github.com/lenve/JavaEETest】。
OK,那麼上面所提到的是閱讀本文所須要具有的基礎知識,在此基礎之上咱們來看看怎麼樣利用Spring Cloud中的Eureka來搭建服務註冊中心。git

首先我要說的是Spring Cloud並非一個東西,和Hadoop相似,Spring Cloud也包含了許多個子項目,咱們今天要看的Eureka只是其中的一個子項目,Eureka的功能有點相似於咱們以前寫過的zookeeper,它是一個服務治理組件,包含了服務註冊中心、服務註冊與發現機制。其餘的組件咱們這裏先不作介紹,後面的系列文章都會一一說起到。github

OK,廢話說了一籮筐,上代碼吧。web

 

建立服務註冊中心

建立一個普通的Spring Boot工程

首先咱們須要建立一個普通的Spring Boot工程,命名爲eureka-server,普通到什麼程度呢?就是一個starter都不須要添加,建立成功以後就只引用了一個父starter。spring

添加Eureka依賴

工程建立成功以後,向pom.xml文件中添加eureka-server的依賴,目前eureka的穩定版本是Dalston.SR3,添加完依賴以後,pom.xml文件以下所示:apache

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>org.sang</groupId>
    <artifactId>eureka-server</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

    <name>eureka-server</name>
    <description>Demo project for Spring Boot</description>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.5.6.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>

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

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Dalston.SR3</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

那麼這裏依賴的添加我主要參考了Eureka官網的 http://projects.spring.io/spring-cloud/。瀏覽器

啓動一個服務註冊中心

啓動一個服務註冊中心的方式很簡單,就是在Spring Boot的入口類上添加一個@EnableEurekaServer註解,以下:微信

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

配置服務註冊中心

最後咱們再作一點簡單的配置就能夠了,配置就寫在Spring Boot的配置文件application.properties中,寫法以下:app

server.port=1111
eureka.instance.hostname=localhost
eureka.client.register-with-eureka=false
eureka.client.fetch-registry=false
eureka.client.service-url.defaultZone=http://${eureka.instance.hostname}:${server.port}/eureka/

OK,那麼關於這幾行註釋,我說以下幾點:框架

1.server.port=1111表示設置該服務註冊中心的端口號
2.eureka.instance.hostname=localhost表示設置該服務註冊中心的hostname
3.eureka.client.register-with-eureka=false,因爲咱們目前建立的應用是一個服務註冊中心,而不是普通的應用,默認狀況下,這個應用會向註冊中心(也是它本身)註冊它本身,設置爲false表示禁止這種默認行爲
4.eureka.client.fetch-registry=false,表示不去檢索其餘的服務,由於服務註冊中心自己的職責就是維護服務實例,它也不須要去檢索其餘服務

測試

OK,作完這一切以後,咱們就能夠啓動這一個Spring Boot 服務,服務啓動成功以後,在瀏覽器中輸入:http://localhost:1111就可以看到以下頁面:

 

OK,看到上面這個頁面以後,表示你的服務註冊中心已經搭建好了。

小結

咱們以前專門有一篇博客介紹如何在Linux上安裝zookeeper【Linux上安裝Zookeeper以及一些注意事項】,可是對於Eureka卻不存在這樣的問題,由於Eureka中的服務註冊中心其實是一個Spring Boot工程,而Spring Boot工程咱們知道能夠直接打成一個jar包,而後java -jar命令就能夠運行,無論Windows仍是Linux上,運行方式都是一致的。

註冊服務提供者

OK,那麼如今服務註冊中心有了以後,咱們能夠考慮向這個服務註冊中心註冊一個服務提供者了。

建立一個新的Spring Boot工程

仍是建立一個Spring Boot工程,此次建立比以前建立多一個步驟,在建立的時候選中web的starter,咱們來建立一個web工程,在IntelliJ IDEA中建立的時候選中web,以下:

 

添加Eureka依賴

在建立好的工程中,咱們須要添加Eureka依賴,添加方式以下:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>org.sang</groupId>
    <artifactId>provider</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>
    <name>provider</name>
    <description>Demo project for Spring Boot</description>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.5.6.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-eureka</artifactId>
        </dependency>
    </dependencies>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Dalston.SR3</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

建立應用的入口

這是一個web工程,因此咱們添加一個Controller,在該Controller中提供一個訪問入口,以下:

@RestController
public class HelloController {
    private final Logger logger = Logger.getLogger(getClass());
    @Autowired
    private DiscoveryClient client;

    @RequestMapping(value = "/hello", method = RequestMethod.GET)
    public String index() {
        List<ServiceInstance> instances = client.getInstances("hello-service");
        for (int i = 0; i < instances.size(); i++) {
            logger.info("/hello,host:" + instances.get(i).getHost() + ",service_id:" + instances.get(i).getServiceId());
        }
        return "Hello World";
    }
}

這裏建立服務以後,在日誌中將服務相關的信息打印出來。

激活Eureka中的DiscoveryClient

在Spring Boot的入口函數處,經過添加@EnableDiscoveryClient註解來激活Eureka中的DiscoveryClient實現(由於咱們在HelloController中注入了DiscoveryClient)。

@EnableDiscoveryClient
@SpringBootApplication
public class ProviderApplication {

    public static void main(String[] args) {
        SpringApplication.run(ProviderApplication.class, args);
    }
}

配置服務名稱和註冊中心地址

最後的最後,咱們在application.properties文件中配置一下服務名和註冊中心地址便可,以下:

spring.application.name=hello-service
eureka.client.service-url.defaultZone=http://localhost:1111/eureka

這兩行代碼的含義很簡單,我就很少說了。

測試

作完這一切以後,咱們就能夠來測試了,直接運行這個Spring Boot工程,運行成功以後,咱們刷新剛纔的http://localhost:1111,就能夠看到有一個服務已經註冊成功了。以下:
 

同時,咱們查看這個服務提供者運行日誌,也能夠看到服務的信息,以下:

 

小結

OK,如此以後,咱們一個服務註冊中心就搭建成功了,同時也有一個服務提供者成功的註冊了。可是這樣還有一個小問題,那就是咱們這裏是一個單節點的服務註冊中心,一旦發生了故障整個服務就癱瘓了,因此在實際應用中,咱們須要搭建高可用註冊中心,那麼關於高可用註冊中心如何搭建的問題,咱們將在下篇文章中來介紹。

本文案例地址:https://github.com/lenve/SimpleSpringCloud  

更多JavaEE資料請關注公衆號:

 

以上。。

本文分享自微信公衆號 - 江南一點雨(a_javaboy)。
若有侵權,請聯繫 support@oschina.cn 刪除。
本文參與「OSC源創計劃」,歡迎正在閱讀的你也加入,一塊兒分享。

相關文章
相關標籤/搜索