Spring Cloud学习心得(一)注册中心Eureka

一、注册中心Eureka简介

其实Eureka仅仅是微服务注册与发现功能实现的一种组件之一,能够实现服务注册与发现的东西有很多,比如Consul、Zookeeper等等,还有一些名不见经传的小东西,我就不一一列举了。目前使用得比较火的注册中心也是Consul了,那为什么我还在写Eureka呢?好吧,其实是我还没时间去细细研究过Consul。不过后续打算换成Consul,据说代价也不大,仅仅是换个注解跟配置而已。

二、创建注册中心Eureka

本文旨在记录自己学习心得,不会编写太多细节来当作教程,所以很多地方肯定不够详细或不够严谨,欢迎留言评论。本项目基于Spring boot的多模块开发。

  1. 先创建父项目cloud_parent,可以删除冗余的src等文件夹,仅保留的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.company</groupId>
   <artifactId>cloud_parent</artifactId>
   <version>1.0-SNAPSHOT</version>

   <name>cloud_parent</name>
   <packaging>pom</packaging>
   <description>Demo project for Spring Boot</description>

   <modules>
       <module>eureka-server</module>
   </modules>

   <parent>
       <groupId>org.springframework.boot</groupId>
       <artifactId>spring-boot-starter-parent</artifactId>
       <version>2.1.6.RELEASE</version>
       <relativePath/> <!-- lookup parent from repository -->
   </parent>

   <properties>
       <!-- 源文件编码格式 -->
       <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
       <!-- 输出流编码格式 -->
       <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
       <!-- java 版本 -->
       <java.version>1.8</java.version>
       <!-- spring-cloud 版本 ,不同的Spring Boot版本对应不同的spring-cloud版本-->
       <spring-cloud.version>Greenwich.SR1</spring-cloud.version>
   </properties>


   <!--添加依赖,子项目无需再次添加-->
   <dependencies>
       <!--Spring Boot 执行器组件-->
       <dependency>
           <groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-starter-actuator</artifactId>
       </dependency>

       <!--Spring Boot Web组件-->
       <dependency>
           <groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-starter-web</artifactId>
       </dependency>
       <dependency>
           <groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-starter-test</artifactId>
           <scope>test</scope>
       </dependency>
   </dependencies>

   <!--Spring Cloud 版本序列配置-->
   <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>
  1. 创建子模块之一,注册中心eureka-server,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.company.server</groupId>
   <artifactId>eureka-server</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <name>eureka-server</name>
   <description>Demo project for Spring Boot</description>

   <parent>
       <groupId>com.company</groupId>
       <artifactId>cloud_parent</artifactId>
       <version>1.0-SNAPSHOT</version>
   </parent>

   <dependencies>
       <dependency>
           <groupId>org.springframework.cloud</groupId>
           <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
       </dependency>
   	   <!-- 注册中心权限控制包 -->
       <dependency>
           <groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-starter-security</artifactId>
       </dependency>
   </dependencies>

</project>

注册中心启动类:

@SpringBootApplication
@EnableEurekaServer // 开启注册中心服务
public class EurekaServerApplication {

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

}

配置文件,application.yml:

server:
 port: 8761

spring:
 application:
   name: eurka-server
 security:
   user:
     name: admin # 注册中心账号
     password: 123456 # 注册中心密码

eureka:
 instance:
   hostname: localhost
 client:
   registerWithEureka: false
   fetchRegistry: false
   service-url:
     defaultZone: http://${spring.security.user.name}:${spring.security.user.password}@${eureka.instance.hostname}:${server.port}/eureka/
     
# registerWithEureka :表示是否将自己注册到Eureka Server,默认为true。由于当前这个应用就是Eureka Server,故而设为false  
# fetchRegistry :表示是否从Eureka Server获取注册信息,默认为true。因为这是一个单点的Eureka Server,不需要同步其他的Eureka Server节点的数据,若需要配置为高可用的注册中心,可以设置为true。
# service-url.defaultZone :设置与Eureka Server交互的地址,查询服务和注册服务都需要依赖这个地址。默认是http://localhost:8761/eureka ;多个地址可使用逗号分隔,这样这个注册中心就是一个高可用的注册中心了。

注: 在此作者遇到一个小的坑,本想把密码设置的复杂一点用了@符号,结果注册中心启动后,在注册中心里报错了 FreeMarker template error,暂时还不知道原因,需要后续阅读一下源码再来解释,如果有知道的朋友,欢迎在评论里讲解一下
在这个注册中心中我配置了用户认证的功能,在1.5.x的版本中这样的配置就可以了,但是在2.0.x版本之后,新版的security开启了crsf检验,如果不关闭该检验,那么后面添加其他微服务将注册失败

/**
* @author super
*/
@EnableWebSecurity
@Configuration
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {

   @Override
   protected void configure(HttpSecurity httpSecurity) throws Exception {
       httpSecurity.csrf().disable();
       super.configure(httpSecurity);
   }
}

好的,到此注册中心的创建基本已经完成,我们可以开心的启动它了
注册中心登陆页
输入在配置文件中配置的账号密码
注册中心页面
至此,一个单点的注册中心就搭建完成了!后续就可以陆陆续续的往里面注册各种服务了!

在这里我有一个小问题就是为什么注册中心的安全认证的账号密码是写在配置文件中的,而不是像其他的系统,把账号密码配置在数据里呢?而且我找了好久的关于这方面的文章,都没看到有提及这个问题的,后续我会研究一下怎么把账号密码配置到数据库中,如果有已经解决了的朋友,欢迎在评论里讲一讲

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Cloud Config Server注册到Eureka注册中心的步骤如下: 1. 首先需要在pom.xml文件中添加Eureka Client的依赖,如下所示: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> <version>2.2.1.RELEASE</version> </dependency> ``` 2. 在应用程序的配置文件中添加以下配置: ```yaml eureka: client: serviceUrl: defaultZone: http://localhost:8761/eureka/ ``` 其中,`defaultZone`指定了Eureka Server的地址。 3. 在Spring Boot应用程序类上添加@EnableEurekaClient注解,以将Config Server注册到Eureka Server上: ```java @EnableConfigServer @EnableDiscoveryClient @SpringBootApplication public class ConfigServerApplication { public static void main(String[] args) { SpringApplication.run(ConfigServerApplication.class, args); } } ``` 4. 运行Config Server应用程序,查看Eureka Server的管理页面(http://localhost:8761)上是否已经注册成功。 5. 客户端应用程序可以通过以下方式从Config Server获取配置: ```yaml spring: application: name: client-service cloud: config: uri: http://localhost:8888 fail-fast: true retry: maxAttempts: 20 multiplier: 1.5 maxInterval: 5000 label: master ``` 其中,`cloud.config.uri`指定了Config Server的地址,`spring.application.name`指定了客户端应用程序的名称,`label`指定了Git仓库的分支名称。 6. 运行客户端应用程序,即可从Config Server获取配置。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值