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,最簡單的案例搭建完成。