咱們在以前的博客中已經介紹過阿里的分佈式服務框架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源創計劃」,歡迎正在閱讀的你也加入,一塊兒分享。