一、SpringCloud简介

SpringCloud是一个基于Spring Boot实现的云应用开发工具,它为基于JVM的云应用开发中的配置管理、服务发现、断路器、智能路由、微代理、控制总线、全局锁、决策竞选、分布式会话和集群状态管理等操作提供了一种简单的开发方式。

SpringCloud包含了多个子项目(针对分布式系统中涉及的多个不同开源产品),比如:Spring Cloud Config、Spring Cloud Netflix、Spring Cloud CloudFoundry、Spring Cloud AWS、Spring Cloud Security、Spring Cloud Commons、Spring Cloud Zookeeper、Spring Cloud CLI等项目。

二、微服务架构

“微服务架构”在这几年非常的火热,以至于关于微服务架构相关的产品社区也变得越来越活跃(比如:netflix、dubbo),Spring Cloud也因Spring社区的强大知名度和影响力也被广大架构师与开发者备受关注。

那么什么是“微服务架构”呢?简单的说,微服务架构就是将一个完整的应用从数据存储开始垂直拆分成多个不同的服务,每个服务都能独立部署、独立维护、独立扩展,服务与服务间通过诸如RESTful API的方式互相调用。

三、服务注册与发现

eureka 用以服务发现、服务注册。

eureka为netflix开源软件,分为三个部分:

  • eureka服务:用以提供服务注册、发现,可以编译源码,将war拷贝进tomcat即可提供服务
  • eureka-server: 相对client端的服务端,为客户端提供服务,通常情况下为一个集群
  • eureka-client:客户端,通过向eureka服务发现注册的可用的eureka-server,向后端发送请求

spring cloud eureka分为两部分:

  • @EnableEurekaClient::该注解表明应用既作为eureka实例又为eureka client 可以发现注册的服务
  • @EnableEurekaServer::该注解表明应用为eureka服务,有可以联合多个服务作为集群,对外提供服务注册以及发现功能

1、创建“服务注册中心”

使用IntelliJ IDEA中的“Spring Initializr”创建项目。

Spring Cloud系统运用到哪些开发语言 spring cloud 开发_java

Spring Cloud系统运用到哪些开发语言 spring cloud 开发_java_02

Spring Cloud系统运用到哪些开发语言 spring cloud 开发_Cloud_03

也可以手动再POM.xml中引入依赖




Spring Cloud系统运用到哪些开发语言 spring cloud 开发_spring_04

Spring Cloud系统运用到哪些开发语言 spring cloud 开发_spring_05

1 <?xml version="1.0" encoding="UTF-8"?>
 2 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 3          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
 4     <modelVersion>4.0.0</modelVersion>
 5 
 6     <groupId>com.shangxue</groupId>
 7     <artifactId>eureka-server</artifactId>
 8     <version>0.0.1-SNAPSHOT</version>
 9     <packaging>jar</packaging>
10 
11     <name>eureka-server</name>
12     <description>Demo project for Spring Boot</description>
13 
14     <parent>
15         <groupId>org.springframework.boot</groupId>
16         <artifactId>spring-boot-starter-parent</artifactId>
17         <version>2.0.2.RELEASE</version>
18         <relativePath/> <!-- lookup parent from repository -->
19     </parent>
20 
21     <properties>
22         <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
23         <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
24         <java.version>1.8</java.version>
25         <spring-cloud.version>Finchley.BUILD-SNAPSHOT</spring-cloud.version>
26     </properties>
27 
28     <dependencies>
29         <dependency>
30             <groupId>org.springframework.cloud</groupId>
31             <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
32         </dependency>
33 
34         <dependency>
35             <groupId>org.springframework.boot</groupId>
36             <artifactId>spring-boot-starter-test</artifactId>
37             <scope>test</scope>
38         </dependency>
39     </dependencies>
40 
41     <dependencyManagement>
42         <dependencies>
43             <dependency>
44                 <groupId>org.springframework.cloud</groupId>
45                 <artifactId>spring-cloud-dependencies</artifactId>
46                 <version>${spring-cloud.version}</version>
47                 <type>pom</type>
48                 <scope>import</scope>
49             </dependency>
50         </dependencies>
51     </dependencyManagement>
52 
53     <build>
54         <plugins>
55             <plugin>
56                 <groupId>org.springframework.boot</groupId>
57                 <artifactId>spring-boot-maven-plugin</artifactId>
58             </plugin>
59         </plugins>
60     </build>
61 
62     <repositories>
63         <repository>
64             <id>spring-snapshots</id>
65             <name>Spring Snapshots</name>
66             <url>https://repo.spring.io/snapshot</url>
67             <snapshots>
68                 <enabled>true</enabled>
69             </snapshots>
70         </repository>
71         <repository>
72             <id>spring-milestones</id>
73             <name>Spring Milestones</name>
74             <url>https://repo.spring.io/milestone</url>
75             <snapshots>
76                 <enabled>false</enabled>
77             </snapshots>
78         </repository>
79     </repositories>
80 
81 
82 </project>


POM.xml


通过@EnableEurekaServer注解启动一个服务注册中心提供给其他应用进行对话。只需要在一个普通的Spring Boot应用中添加这个注解就能开启此功能。



@EnableEurekaServer
@SpringBootApplication
public class EurekaServerApplication {

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



在默认设置下,该服务注册中心也会将自己作为客户端来尝试注册它自己,所以我们需要禁用它的客户端注册行为,只需要在application.properties中问增加如下配置:



# 服务注册中心端口号
server.port=8102
# 是否注册自身到eureka服务器
eureka.client.register-with-eureka=false
# 是否从eureka上获取注册信息
eureka.client.fetch-registry=false
# eureka服务地址
eureka.client.serviceUrl.defaultZone=http://127.0.0.1:${server.port}/eureka/



  启动工程后,访问:http://127.0.0.1:8102/,可以看到下面的页面,其中还没有发现任何服务

Spring Cloud系统运用到哪些开发语言 spring cloud 开发_Cloud_06