前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。
PS:这个系列不定时更新,只是个人的学习分享,
内容全程参考书目:
《Spring Cloud 与 Docker 微服务架构空实战 》、
《Spring Cloud 微服务实战》及此书作者博客:http://blog.didispace.com/spring-cloud-learning/
《深入理解 Spring Cloud 与微服务构建》及此书作者博客:https://blog.csdn.net/forezp/article/details/70148833
一 、在 springcloud 中 eureka 的作用 :服务注册、服务发现 。
先创建一个 父pom 工程:base
1. file -- new -- project
2. spring Initializr - module SDK 选择自己的 JDK ,其余的可以不用填写,next。
3. 填写工程相关信息:包名、工程名等,next。
4.直接 next
5. 工程名,代码存放位置等,finish 。
6.工程结构:(直接删除整个 src 文件目录)
7. pom.xml 中配置基本项:(子模块自行选择是否配置)
<?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>com.base</groupId>
<artifactId>base-config</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>base-config</name>
<packaging>pom</packaging>
<description>整个体系基本配置</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.6.RELEASE</version>
<!--
lookup parent from repository
查找顺序:relativePath元素中的地址–本地仓库–远程仓库。
设定一个空值将始终从仓库中获取,不从本地路径获取。
-->
<relativePath/>
</parent>
<!-- 配置远程发布到私服,mvn deploy -->
<distributionManagement>
<!--releases:发布-->
<repository>
<id>maven-releases</id>
<name>Nexus Release Repository</name>
<url>http://ergouzi.fun:8081/repository/maven-releases/</url>
</repository>
<!--Snapshot:快照-->
<snapshotRepository>
<id>maven-snapshots</id>
<name>Nexus Snapshot Repository</name>
<url>http://ergouzi.fun:8081/repository/maven-snapshots/</url>
</snapshotRepository>
</distributionManagement>
<!--定义子模块-->
<!--<modules>-->
<!--<module>bbb</module>-->
<!--<module>aaa</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-test</artifactId>
<scope>test</scope>
</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>
二.、创建 Eureka ,作为注册中心:
1. file - new - module
2. spring Initializr - module SDK 选择自己的 JDK ,其余的可以不用填写,next。
3. 填写工程相关信息:包名、工程名等,next。
4. spring cloud discovery - 勾选 eureka server ,next。
5. 工程名,代码存放位置等,finish 。
6. 生成工程的结构如下:
7.maven 区间 :
8. pom.xml 中 引用 父 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">
<modelVersion>4.0.0</modelVersion>
<groupId>com.es</groupId>
<artifactId>eureka</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>eureka</name>
<parent>
<groupId>com.base</groupId>
<artifactId>base-config</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>
9. 在工程启动类上加注解:@EnableEurekaServer
package com.es.eureka;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
@SpringBootApplication
// 标明自已为注册中心:Eureka
@EnableEurekaServer
public class EurekaApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaApplication.class, args);
}
}
10. 配置文件相关设置:
# 应用名
server.name= JY-eureka
# 端口
server.port=1234
# 实例主机
eureka.instance.hostname=localhost
# 此应用为注册中心,false:不向注册中心注册自己。
eureka.client.registerWithEureka=false
# 注册中心职责是维护服务实例,false:不检索服务。
eureka.client.fetchRegistry=false
# 访问地址
eureka.client.serverUrl.defaultZone= http://${eureka.instance.hostname}:${server.port}/eureka/
11.启动工程:2个红框位置方法的都可以启动工程。
启动成功:
PS: 在启动工程时,可能遇到报错,我的情况是 pom 中 spingboot 和 springcloud 的版本不对应。另外就是配置文件中设置。
12. 浏览器访问: http://localhost:1234/
目前没有注册任何服务 ,故也就没有服务被发现。
至此,Eureka 注册中心就运行起来了,服务的注册就 OK 了 。
下一篇:springCloud - 第2篇 - 服务的发现 clientOne
源码见:https://gitee.com/FJ_WoMenDeShiJie/springcloud-eureka