当前位置 : 主页 > 编程语言 > java >

SpringCloud Eureka搭建的方法步骤

来源:互联网 收集:自由互联 发布时间:2021-05-10
1.SpringCloud是什么 以前的服务器就像是一个医院只有一个医生,什么病人都要让这个医生看,如果医生觉得太累,自我暴毙了,那整个医院都瘫痪了。而springcloud流行起来之后,就像是医

1.SpringCloud是什么

以前的服务器就像是一个医院只有一个医生,什么病人都要让这个医生看,如果医生觉得太累,自我暴毙了,那整个医院都瘫痪了。而springcloud流行起来之后,就像是医院里面有了外科诊室,内科诊室等,每一个诊室都有一群医生负责,这样不管哪一个医生不行了都不会影响整个医院的运转。把一台或好几台服务器中的众多服务,分类出来,解耦合出来,把他们类似的功能交给同一个集群来做,把互相耦合在一起的功能剥离出来,按业务,按功能来把他们作为一个个微服务放在服务器上,而这个服务器就只提供一个服务,或较少的服务。让一个超大的服务逻辑,解耦合为一个个小服务,均匀的分布在各自的服务器中。这就是springcloud。

2.Eureka是做什么用的

每一个诊室都是一个微服务集群,他们提供的作用都是一样的。注册中心Eureka相当于每个诊室的成员表。

3.Eureka的搭建

在Idea中创建工程:File -> New ->Project -> Empty Project -> Next

在这里插入图片描述

点击下一步就完事了

创建Module文件

在这里插入图片描述

选择quickstart,点击下一步(这个页面可能要加载一会时间)

在这里插入图片描述

组名和文件名自己随便编写,写完一直下一步

在这里插入图片描述

配置pom文件

<parent>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-parent</artifactId>
  <version>1.5.7.RELEASE</version>
</parent>

<!--server依赖-->
<dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>

<!--指定下载源和使用springcloud的版本-->
 <dependencyManagement>
  <dependencies>
   <dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-dependencies</artifactId>
    <version>Edgware.SR5</version>
    <type>pom</type>
    <scope>import</scope>
   </dependency>
  </dependencies>
 </dependencyManagement>

然后就开始导包。。。漫长的等待

在main下创建文件夹resources并设置为资源文件夹

在这里插入图片描述

在resources下新建file,并命名为appliaction.yml

在这里插入图片描述

配置appliaction.yml

server:
 port: 8700 # 端口号自己随意

# 指定当前eureka客户端的注册地址,也就是eureka服务的提供方,当前配置的服务的注册服务方
eureka:
 client:
  service-url:
   defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka
  register-with-eureka: false #自身 不在向eureka注册
  fetch-registry: false #启动时禁用client的注册
 instance:
  hostname: localhost

#指定应用名称
spring:
 application:
  name: eureka-server

在buting文件夹下新建文件EurekaServerAppliaction.java,然后写入以下代码。

@SpringBootApplication
@EnableEurekaServer //当前使用eureka的server
public class EurekaServerApplication {
  public static void main(String[] args) {
    SpringApplication.run(EurekaServerApplication.class,args);
    System.out.println("2333");
  }
}

右键点击Debug运行,运行成功后输入http://localhost:8700如果能出现下面这个界面我们第一步就算成功啦。

在这里插入图片描述

接下来就该配置客户端啦,它提供的是角色的配置,提供服务在服务注册方(就是我们刚刚配置的server)进行注册
跟上面的步骤一样,我们新建Module文件,需要注意的是上面的两个选为

在这里插入图片描述

创建完文件后,我们来配置pom文件,引入以下依赖

 <!--引入springboot-parent父项目-->
 <parent>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-parent</artifactId>
  <version>1.5.7.RELEASE</version>
 </parent>
  <!--引入springcloud的euekea server依赖-->
  <dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
  </dependency>


 <!--指定下载源和使用springcloud的版本-->
 <dependencyManagement>
  <dependencies>
   <dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-dependencies</artifactId>
    <version>Edgware.SR5</version>
    <type>pom</type>
    <scope>import</scope>
   </dependency>
  </dependencies>
 </dependencyManagement>

好吧,其实就是把dependency里的server改为client
接着我们创建resources文件夹,创建application.yml文件,里面这样配置

server:
 port: 8701 # 服务提供方
 
# 指定当前eureka客户端的注册地址,
eureka:
 client:
  service-url:
   defaultZone: http://${eureka.instance.hostname}:8700/eureka
 instance:
  hostname: localhost
 
#当前服务名称
spring:
 application:
  name: eureka-service
pom.xml:

因为搭建的是服务提供者,这里还需编写服务类controller

@RestController
@RequestMapping("/Hello")
public class Controller {
  @RequestMapping("/World")
  public String helloWorld(String s){
    System.out.println("传入的值为:"+s);
    return "传入的值为:"+s;
  }
}

入口类 并运行此微服务

@SpringBootApplication
@EnableDiscoveryClient//代表自己是一个服务提供方
public class EurekaServiceApplication {
  public static void main(String[] args) {
    SpringApplication.run(EurekaServiceApplication.class,args);
  }
}

右键点击Debug(当然开启此服务时需要先开启server服务 就是我们第一个编写的微服务)等待运行成功后,在进入server页面(进入的是我们第一次配置的页面,不是这个)

在这里插入图片描述

在页面中我们可以看到,此时可以看见服务提供者已被注册进 服务注册者

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。

网友评论