发表于: 2019-12-22 23:25:08
1 1258
今天完成的事:
1、查看springcloud。
单体结构:
就是将类似提供数据与显示数据的两个服务放在了一起,是单独一个项目,会有诸多的问题,比如修改其中一个服务就需要将整个项目停掉,修改后重新打包部署,性能瓶颈也很难突破。
微服务:
简单说一个springboot就是一个微服务,将单个项目分为多个微服务,分别由多个springboot执行,减少相互之间的耦合。
集群:
可以直接理解为单个微服务,本来由一个springboot执行即可,现在用两个springboot执行,功能一模一样,这就是集群,可以通过横向扩展来提高性能,其中一个springboot挂了也不影响使用,这又叫高可用。
围绕着上述的简单分布式结构,还需要做以下这些事:
查找案例,尝试运行。
这里需要用到的组件是 Spring Cloud Netflix 的Eureka,eureka是一个服务注册和发现模块。
创建一个maven父工程,再创建两个子模块,一个作为服务注册中心,即 Eureka Server,另一个作为 Eureka Client。
(1)创建服务注册中心,需要是父子工程。
这里是运行成功的是springboot 2.1.11版本,springcloud Finchley 版本。
因为版本问题浪费好多时间。。开始是使用的2.2.2 版本。。后面再说。
父子工程,也浪费了不少时间。。
首先创建父工程,选择Type为maven pom,这样省的再去删除不需要的文件了。
这里什么都不用选,直接下一步,其实应该注意下版本号,但是当时并不知道这个会出问题。。
建成的项目就只有框选的三个文件。而后在父工程文件夹的目录下新建两个子过程所需的文件夹,需要手动创建,之前以为创建模块时会自动创建文件夹,结果一直被覆盖文件。
父工程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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.springcloud</groupId>
<artifactId>parent</artifactId>
<version>0.0.1-SNAPSHOT</version>
<!-- 后添加 -->
<packaging>pom</packaging>
<name>parent</name>
<description>Demo project for Spring Boot</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.11.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<!-- 后添加,子模块 -->
<modules>
<module>eureka-server</module>
<module>eureka-client</module>
</modules>
<!-- 后添加 -->
<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</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
<exclusions>
<exclusion>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
</exclusion>
</exclusions>
</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>
在父工程项目名称处右击,选择新建模块。
只修改artifact,group名称不变。
选择 eureka server 依赖。
这个模块是注册中心,用于注册各个微服务,以便其他微服务可以找到和访问。
选择新创建的文件夹。
eureka server 子模块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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.springcloud</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>com.springcloud</groupId>
<artifactId>parent</artifactId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
</dependencies>
</project>
启动服务注册中心,需要在启动类 EurekaServerApplication 类上添加注解 @EnableEurekaServer。
package com.springcloud.eurekaserver;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaServerApplication.class, args);
}
}
添加application.yml配置文件,提供eurka的相关信息。
默认情况下eurka server也是一个eurka client,必须指定一个server。
hostname:
localhost,表示主机名称。
registerWithEureka:
false,表示是否注册到服务器,因为他本身就是服务器,所以无需注册。
fetchRegistry:
false,表示是否获取服务器的注册信息,同上。
defaultZone:
http://${eureka.instance.hostname}:${server.port}/eureka/
自己作为服务器,公布的地址,如果后续某个微服务把自己注册到eurka server,那么就需要使用这个地址,http://localhost:8761/eureka/
name:
eurka-server,表示这个微服务本身名称为eurka-server。
server:
port: 8761
eureka:
instance:
hostname: localhost
client:
registerWithEureka: false
fetchRegistry: false
serviceUrl:
defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
spring:
application:
name: eurka-server
运行 EurekaServerApplication 类,访问 http://localhost:8761/。
运行报错。
百度很久,原来是springboot版本问题。。将版本改为2.1.11,问题解决。
只修改父工程处版本即可,刷新maven栏,查看依赖的版本号修改后,即可。
也有说是不使用 Finchley 版本的springcloud,使用 Hoxton 版本即可解决问题,百度一下,原来 Hoxton 是基于springboot 2.2.1,又是升级版,有点怕,于是选择降低springboot版本解决问题。
修改后,测试类报异常。
原来是springboot 2.2 之前使用的是Junit4,后续使用的Junit5,缺少包。。
修改成对应的测试类注解即可。
这就行了,NND。。
这里显示没有服务被发现,因为还没有注册微服务。
(2)创建服务提供者eureka client。
新建子模块,步骤同上。
这里需要选择web、client依赖。
选择新创建的文件夹。
eureka client 子模块pom文件如下:
application.yml 配置文件:
因为注册到eurka server,设置注册中心地址,http://localhost:8761/eureka/
server:
port: 8762
spring:
application:
name: eureka-client
eureka:
client:
serviceUrl:
defaultZone: http://localhost:8761/eureka/
修改启动类 EurekaClientApplication,添加注解 @EnableEurekaClient 表明自己是一个EurekaClient。这里将controller也添加了,添加@RestController,用于返回json数据。
package com.springcloud.eurekaclient;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
@SpringBootApplication
@EnableEurekaClient
@RestController
public class EurekaClientApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaClientApplication.class, args);
}
@Value("${server.port}")
String port;
@RequestMapping("/hi")
public String home(@RequestParam(value = "name", defaultValue = "forezp") String name) {
return "hi " + name + " ,i am from port:" + port;
}
}
这里可以看到,有一个服务已经注册在服务中了,服务名EUREKA-CLIENT,端口为8762。
访问8762端口,也可以显示json数据。
明天计划的事:
springcloud的负载均衡、断路器、网关。
遇到的问题:
版本问题。。需要注意。
收获:
1、查看springcloud,运行实例。
2、创建服务注册中心、客户端。
评论