springCloud学习笔记(一)——eureka服务注册中心

一、eureka是什么?

Spring-Cloud Euraka是Spring Cloud集合中一个组件,它是对Euraka的集成,用于服务注册和发现。Eureka是Netflix中的一个开源框架。它和 zookeeper、Consul一样,都是用于服务注册管理的,同样,Spring-Cloud 还集成了Zookeeper和Consul。

在项目中使用Spring Cloud Euraka的原因是它可以利用Spring Cloud Netfilix中其他的组件,如zull等,因为Euraka是属于Netfilix的。

eureka详细划分可分为三个部分:

  • Eureka Server 提供服务注册和发现- Service Provider 服务提供方,将自身服务注册到Eureka,从而使服务消费方能够找到- Service Consumer服务消费方,从Eureka获取注册服务列表,从而能够消费服务
    此文章仅针对Eureka Server服务注册和发现进行学习。

二、构建项目

1.引入jar包

  1. <dependency>
  2. <groupId>org.springframework.cloud</groupId>
  3. <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
  4. </dependency>

2.完整pom内容

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  5. <parent>
  6. <artifactId>com.springcloud</artifactId>
  7. <groupId>com.sc2020</groupId>
  8. <version>1.0-SNAPSHOT</version>
  9. </parent>
  10. <modelVersion>4.0.0</modelVersion>
  11. <artifactId>cloud-eureka-server7001</artifactId>
  12. <dependencies>
  13. <dependency>
  14. <groupId>org.springframework.cloud</groupId>
  15. <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
  16. </dependency>
  17. <!-- 引入自定义的api通用包,可以使用Payment支付Entity -->
  18. <dependency>
  19. <groupId>com.sc2020</groupId>
  20. <artifactId>cloud-api-commons</artifactId>
  21. <version>1.0-SNAPSHOT</version>
  22. </dependency>
  23. <!-- boot web actuator -->
  24. <dependency>
  25. <groupId>org.springframework.boot</groupId>
  26. <artifactId>spring-boot-starter-web</artifactId>
  27. </dependency>
  28. <dependency>
  29. <groupId>org.springframework.boot</groupId>
  30. <artifactId>spring-boot-starter-actuator</artifactId>
  31. </dependency>
  32. <!-- 一般通用配置 -->
  33. <dependency>
  34. <groupId>org.springframework.boot</groupId>
  35. <artifactId>spring-boot-devtools</artifactId>
  36. <scope>runtime</scope>
  37. </dependency>
  38. <!-- 热部署 -->
  39. <dependency>
  40. <groupId>org.springframework.boot</groupId>
  41. <artifactId>spring-boot-devtools</artifactId>
  42. <scope>runtime</scope>
  43. <optional>true</optional>
  44. </dependency>
  45. <!-- 单元测试 -->
  46. <dependency>
  47. <groupId>org.springframework.boot</groupId>
  48. <artifactId>spring-boot-starter-test</artifactId>
  49. <scope>test</scope>
  50. </dependency>
  51. </dependencies>
  52. </project>

3.yml配置文件

  1. server:
  2. port: 7001
  3. eureka:
  4. instance:
  5. hostname: eureka7001.com #eureka服务端的实例名称
  6. client:
  7. register-with-eureka: false #false表示不向注册中心注册自己
  8. fetch-registry: false #false表示自己端就是注册中心
  9. service-url:
  10. defaultZone: http://eureka7001.com:7001/eureka/ #单机
  11. # defaultZone: http://eureka7001.com:7001/eureka/, http://eureka7002.com:7002/eureka/ #集群, eureka7001.com在配置hosts文件时生效,未配置时使用localhost代替
  12. server:
  13. # 关闭自我保护机制,保证不可用服务被及时剔除
  14. enable-self-preservation: false
  15. eviction-interval-timer-in-ms: 2000
  16. spring:
  17. application:
  18. name: cloud-eureka-service7001

注意:eureka7001.com在配置hosts文件时生效,未配置时使用localhost代替

4.Application,main方法

  1. @SpringBootApplication
  2. @EnableEurekaServer
  3. public class CloudEurekaServer7001Application {
  4. public static void main(String[] args) {
  5. SpringApplication.run(CloudEurekaServer7001Application.class, args);
  6. }
  7. }

在main方法中声明使用@EnableEurekaServer组件。

三、方法运行

输入地址 : 出现此页面则成功配置服务注册中心。

1.eureka服务注册中心 - 图1

项目地址: