简述
SpringCloud是一个微服务治理框架,基于SpringBoot,在项目构建与初期测试学习时使用多module的方式创建比较方便;idea可以使用maven或gradle的方式,这里选择maven;
Environment
- Intellij Idea version : 2017.2.4
- JavaSDK version : 1.8
- Maven version : 3.5.2
- SpringCloud version : Dalston.SR4
- SpringBoot version : 1.5.9.RELEASE
创建Project
1. NewProject -> Maven
2. 填写GroupId、ArtifactId
3. 选择存储位置
4. 删除src
这里把src目录删掉;
创建第一个module : 注册中心 Eureka
1. New Module : Spring
- 一定要在CloudSample上右键
- New Module后选择Spring Initializr
填写GroupId以及ArtifactId,以及版本号等
2. 选择CloudDiscovery -> Eureka Server
3. Project的pom和module的pom的对比
cloud-sample的pom内容如下:
<?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"> <!-- 指定pom版本,所有模块的pom均需指定 --> <modelVersion>4.0.0</modelVersion> <!-- 本模块的坐标 --> <groupId>com.cloud.sample</groupId> <artifactId>cloud-sample</artifactId> <version>1.0-SNAPSHOT</version> <!-- 打包类型,默认为jar,含有子模块的模块自动被设置为pom --> <packaging>pom</packaging> <!-- 被聚合的子模块索引 --> <modules> <module>sample-eureka</module> </modules> <!-- 引用maven仓库源 --> <url>http://maven.apache.org</url> <!-- 这里集中定义整个项目里边所有第三方依赖的版本及其他可作用于所有pom的常量 --> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <spring-cloud.version>Dalston.SR3</spring-cloud.version> </properties> <!--父模块:空的父模块,定义整个maven项目的依赖、版本等信息,继承: 子模块可以直接引用父模块依赖包的定义,避免重复定义dependencesManagement:管理子模块重复使用的依赖包定义,子类在引用父类的包时使用parent标签,引用父类的maven坐标,通过relativePath标签指明父类pom文件的位置,通过groupId和artifactId两个标签来引用父类中定义的重复依赖包注意:父类本身的groupId artifactId version都可以继承(但是不能全部继承,唯一性) --> <!-- 这里集中陈列整个项目需要用到的第三方依赖及其版本 --> <dependencyManagement> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.7</version> <scope>test</scope> </dependency> <!--父模块可以将子模块设定为依赖,例如提供整个maven项目最基础的功能--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.6.RELEASE</version> </dependency> <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> </project>
sample-eureka的pom文件内容如下:
<?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"> <!-- 指定pom版本,所有模块的pom均需指定 --> <modelVersion>4.0.0</modelVersion> <!-- 本模块的坐标 --> <groupId>com.sample.eureka</groupId> <artifactId>sample-eureka</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <url>http://maven.apache.org</url> <name>sample-eureka</name> <description>Demo project for Spring Boot</description> <parent> <groupId>com.cloud.sample</groupId> <artifactId>cloud-sample</artifactId> <version>1.0-SNAPSHOT</version> <relativePath>../pom.xml</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.cloud</groupId> <artifactId>spring-cloud-starter-eureka-server</artifactId> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>
application.properties内容如下:
server.port=2222 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/ eureka.client.registry-fetch-interval-seconds=30
启动类内容如下:
package com.sample.eureka; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer; @SpringBootApplication @EnableEurekaServer public class SampleEurekaApplication { public static void main(String[] args) { SpringApplication.run(SampleEurekaApplication.class, args); } }项目访问地址