1. 程式人生 > >Spring cloud入門教程(1)

Spring cloud入門教程(1)

       看到網上關於Spring cloud的入門教程基本是基於Eclipse的,因為我用的是IDEA,所以打算寫一份IDEA使用Spring cloud的入門教程。

       廢話不多說,直接來幹。

       Spring cloud是一個分散式架構的服務治理,和Dubbo差不多,但是這個更簡單,看教程來搭建一個微服務架構吧。

       第一步:先建立一個主Maven工程

           

           在pom.xml新增依賴

<?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>com.xuye.parent</groupId>
    <artifactId>parent</artifactId>
    <version>1.0-SNAPSHOT</version>

    <name>sc-f-chapter1</name>
    <description>Demo project for Spring Boot</description>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.3.RELEASE</version>
        <relativePath/>
    </parent>

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

    <dependencies>
        <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>${spring-cloud.version}</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>

          第二步:在此專案下,建立一個Module,作為註冊中心。

              

              注意該Module是基於spring boot的。然後填好資訊一路next,到此步驟,按下圖選擇,Cloud Discovery—Eureka Server

              

       該模組的pom.xml暫時也沒什麼需要新增和修改的,因為已經繼承了父專案的pom.xml。

       我們此時,需要去做的事情是,修改application.yml,如果字尾是properties的記得改字尾,如果看得懂的話,就自己修改成properties的格式。。註冊中心的,配置內容如下。

#服務埠號
server:
  port: 8901
#服務名稱
spring:
  application:
    name: server

eureka:
  instance:
    hostname: localhost
  client:
    #註冊中心不需要註冊自己,這兩處預設值都為true,我們設為false
    registerWithEureka: false
    #註冊中心不需要去發現服務
    fetchRegistry: false
    #設定服務註冊中心的URL,此處則表示為http://localhost:8901/eureka/
    serviceUrl:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

           然後去入口,Application中添加註解:@EnableEurekaServer,表示是一個註冊中心。

     OK,此時註冊中心已經配置完了,直接啟動註冊中心的伺服器。

              

          出現如圖所示的樣子,則表示註冊中心啟動成功,如果出現問題的話,請換個埠試試,可能你的埠被使用了。

               第三步:在此專案下,新建一個Module,作為服務提供者。

           建立Module的步驟和建立註冊中心的Module一模一樣,注意名字不要一樣就行了。

           建立好了後,我們再來看application.yml 注意,如果字尾是properties的記得改字尾,如果看得懂的話,就自己修改成properties的格式。          

server:
  port: 8902
#此處需要加上該服務的名字
spring:
  application:
    name: client

eureka:
  client:
      #向註冊中心註冊自己,此處預設為true,可以不用加的,但為了教學解釋
      registerWithEureka: true
      #讓註冊中心發現自己,預設也為true,可以不用加的,但為了教學解釋
      fetchRegistry: true
      #設定服務註冊中心的URL,註冊中心已經設定過了,直接去註冊中心檢視即可。
      serviceUrl:
        defaultZone: http://localhost:8901/eureka/

         注意上面的registerWithEureka: true和fetchRegistry: true是可以不用新增的,因為預設就是true的。

         再去入口處添加註解@EnableEurekaClient,表示是一個服務提供者。我們來測試一下。

           

         啟動服務,註冊中心和服務提供者都需要啟動。

           

          注意看中間的位置,多了一個服務提供者。

           

             OK,最簡單的案例搭建完成。