发表于: 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、创建服务注册中心、客户端。

返回列表 返回列表
评论

    分享到