首页 > 其他分享 >SpringCloud-搭建eurekaServer

SpringCloud-搭建eurekaServer

时间:2023-03-18 20:00:12浏览次数:48  
标签:服务 spring eureka eurekaServer 注册 SpringCloud server cloud 搭建

Eureka 介绍

整体介绍

  1. 背景:在传统应用中,组件之间的调用,通过有规范的约束的接口来实现,从而实现不同模块间良好的协作。但是被拆分成微服务后,每个微服务实例的网络地址都可能动态变化,数量也会变化,使得原来硬编码的地址失去了作用。需要一个中心化的组件来进行服务的登记和管理。
  2. 概念:实现服务治理,即管理所有的服务信息和状态。
注册中心相当于买票乘车,只看有没有票(有没有服务),有就去买票(获取注册列表),然后乘车(调用)。不必关心有多少火车在运行。
  1. 注册中心好处:不用关心有多少提供方。

  2. 注册中心有哪些:Eureka,Nacos,Consul,Zookeeper等。

  3. 服务注册与发现包括两部分,一个是服务器端,另一个是客户端。

    Server是一个公共服务,为Client提供服务注册和发现的功能,维护注册到自身的Client的相关信息,同时提供接口给Client获取注册表中其他服务的信息,使得动态变化的Client能够进行服务间的相互调用。

    Client将自己的服务信息通过一定的方式登记到Server上,并在正常范围内维护自己信息一致性,方便其他服务发现自己,同时可以通过Server获取到自己依赖的其他服务信息,完成服务调用,还内置了负载均衡器,用来进行基本的负载均衡。

  4. Eureka:是一个RESTful风格的服务,是一个用于服务发现和注册的基础组件,是搭建Spring Cloud微服务的前提之一,它屏蔽了Server和client的交互细节,使得开发者将精力放到业务上。

  5. Netflix开源的组件。包括server和client两部分。

    https://github.com/Netflix/Eureka
    

 

SpringCloud官网是https://docs.spring.io/spring-cloud-netflix/docs/3.1.4/reference/html/#spring-cloud-eureka-server。要包含Eureka Server只需添加spring-cloud-starter-netflix-eureka-server依赖。

 
 
 

例子:

新建名为EurekaServer 的SpringBoot项目,添加spring-cloud-starter-netflix-eureka-server依赖,使用Gradle构建工具,build.gradle文件如下:

plugins {
    id 'java'
    id 'org.springframework.boot' version '2.7.9'
    id 'io.spring.dependency-management' version '1.0.15.RELEASE'
}

group = 'com.example'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = '17'

repositories {
    mavenCentral()
}

ext {
    set('springCloudVersion', "2021.0.6")
}

dependencies {
   // implementation 'org.springframework.cloud:spring-cloud-starter'
    implementation 'org.springframework.cloud:spring-cloud-starter-netflix-eureka-server'
    testImplementation 'org.springframework.boot:spring-boot-starter-test'
}

dependencyManagement {
    imports {
        mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
    }
}

tasks.named('test') {
    useJUnitPlatform()
}

SpringCloud版本是2021.0.6,SpringBoot版本是2.7.9,java版本是jdk17.

 

导入依赖后,在application.yml文件配置:

server:
  port: 8761

eureka:
  instance:
    hostname: localhost
  client:
    registerWithEureka: false
    fetchRegistry: false
    serviceUrl:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

其中server.port指定项目的端口,eureka.instance.hostname指定eureka的主机名,eureka.client.registerWithEureka为false表示不将自己注册到eurekaServer中,eureka.client.fetchRegistry表示此eurekaServer是否从其他eurekaServer中拉取注册的服务列表。eureka.client.serviceUrl.defaultZone指定服务注册中心的URL。

 

在启动类上加@EnableEurekaServer注解:

@EnableEurekaServer
@SpringBootApplication
public class EurekaServerApplication {

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

}

 

启动后,访问http://localhost:8761/:


标签:服务,spring,eureka,eurekaServer,注册,SpringCloud,server,cloud,搭建
From: https://www.cnblogs.com/shigongp/p/17231537.html

相关文章

  • 大型买返商城交易返利抢购小程序app定制开发h5源码二开搭建
    一.注册和登录1.可以通过手机验证码注册,也可以账号密码登录2.登录或者注册,须同意商家的协议或者规则二.主页面1.主界面分四个部分,分别是广告窗口,菜单栏,活动页面,商品展示三.......
  • 基于K8S搭建Ceph分部署存储
    基于K8S搭建Ceph分部署存储 2020年2月17日 技术、推荐博文唐玥璨7条留言版本依赖​    搭建思路很多高级运维人员都2020年了对于K8S的存储大部分都是采用主机......
  • vite/storybook/rollup搭建一个自己的组件库
    构建测试项目首先vite初始化一个项目vuecreatestory-book-demo##或者vuecreatestory-book-demo然后添加storybook,具体参看官网:​​https://storybook.js.org/docs/......
  • 失落的方舟私服服务器搭建用什么配置比较好
    最近失落的方舟游戏Steam打折让很多玩家都开始选这服务器搭建私服进行游戏,和游戏不太相同,失落的方舟即提供官方的服务器,而且也能够支持私人服务器的搭建,只要你的游戏是正版......
  • vite/storybook/rollup搭建一个自己的组件库
    构建测试项目首先vite初始化一个项目vue create story-book-demo## 或者 vue create story-book-demo然后添加storybook,具体参看官网:https://storybook.js.or......
  • 爬虫:requests高级用法、代理池搭建、爬取某视频网站、爬取新闻
    目录一、requests高级用法1.0解析json格式数据1.1ssl认证(了解)1.2使用代理(重要)1.3超时设置1.4异常处理1.5上传文件二、代理池搭建2.1代理池介绍2.2搭建步骤2.3使......
  • golang介绍和环境搭建
    一、Goland语言介绍Go和C语言、C++、Python、Java等一样都是编程语言。学习任何一门编程语言本质上都分3步走:第一步:安装解释器或编译器。第二步:学相关编程语言语......
  • 尚硅谷MyBatis_2_搭建MyBatis
    创建maven工程pom.xml配置打包方式jar引入依赖<dependencies><!--Mybatis核心--><dependency><groupId>org.mybatis</group......
  • 软件测试|一文教你轻松搭建docker环境
    前言Docker提供轻量的虚拟化,你能够从Docker获得一个额外抽象层,你能够在单台机器上运行多个Docker微容器,而每个微容器里都有一个微服务或独立应用,例如你可以将Tomcat运行在......
  • 软件测试|使用docker搞定 Python环境搭建
    前言当我们在公司的电脑上搭建了一套我们需要的Python环境,比如我们的版本是3.8的Python,那我可能有一天换了一台电脑之后,我整套环境就需要全部重新搭建,不只是Python,我们一系......