springcloud 学习-eureka搭建

简介:

组件名:Netflix Eureka 

作用:支撑微服务的自注册、自发现,提供负载均衡能力

开发环境使用IDEA,jdk1.8

一、搭建eureka服务

1.新建maven项目,配置pom.xml文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<parent>
     <groupId>org.springframework.cloud</groupId>
     <artifactId>spring-cloud-starter-parent</artifactId>
     <version>Camden.SR7</version>
</parent>
<dependencies>
     <dependency>
         <groupId>org.springframework.cloud</groupId>
         <artifactId>spring-cloud-starter</artifactId>
     </dependency>
     <dependency>
         <groupId>org.springframework.cloud</groupId>
         <artifactId>spring-cloud-starter-eureka-server</artifactId>
     </dependency>
</dependencies>


2.新建启动类

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


3.新建配置文件application.yml

1
2
3
4
5
6
7
8
9
10
11
server:
   port:  1000
eureka:
   instance:
     hostname:  localhost
   client:
     register-with-eureka:  false
     fetch-registry:  false
spring:
   application:
     name: eureka-server


4.启动(启动类)

wKiom1loQcWxBxOXAAFpvirsLA0941.png-wh_50

5.访问 eureka:http://localhost:1000/

wKioL1loQdPzub6yAAGmY2IEJ_0905.png-wh_50


erueka服务器启动成功,目前还未有服务注册


二、搭建服务提供方


1.新建maven项目,配置pom.xml文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<parent>
     <groupId>org.springframework.cloud</groupId>
     <artifactId>spring-cloud-starter-parent</artifactId>
     <version>Camden.SR7</version>
</parent>
<dependencies>
     <dependency>
         <groupId>org.springframework.cloud</groupId>
         <artifactId>spring-cloud-starter</artifactId>
     </dependency>
     <dependency>
         <groupId>org.springframework.cloud</groupId>
         <artifactId>spring-cloud-starter-eureka-server</artifactId>
     </dependency>
</dependencies>

2.创建Application启动类,提供/hello服务

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
@Configuration
@ComponentScan
@EnableEurekaClient
@EnableAutoConfiguration
@RestController
public  class  Application {
     @RequestMapping (value =  "hello" ,method = RequestMethod.GET)
     public  String hello(){
         return  "你好,世界" ;
     }
     public  static  void  main(String[] args){
         new  SpringApplicationBuilder(Application. class ).web( true )
                 .run(args);
     }
}

3、新建application.yml配置文件

1
2
3
4
5
6
7
8
9
eureka:
   client:
     serviceUrl:
       defaultZone: http: //localhost:1000/eureka/
spring:
   application:
     name: feign-client-test- 001
server:
   port:  2000

查看路径id展示,需要添加配置

1
2
3
4
5
6
eureka:
   client:
     serviceUrl:
       defaultZone: http: //admin:admin123@localhost:1000/eureka
   instance:
     prefer-ip-address:  true

wKiom1lriGuQiWzZAAJ4yS0-35I611.png-wh_50

4、运行,查看之前Erueka服务端的页面,FEIGN-CLIENT-TEST-001在注册中心变为了大写这个注意下

wKioL1loaEnS0ZsfAAGxI5irgfs102.png-wh_50

5、访问:http://127.0.0.1:2000/hello

wKioL1loaHqzCx-eAABKirqiF0w075.png-wh_50

三、搭建服务消费方

使用@FeignClient注解

Feign is a declarative web service client. It makes writing web service clients easier.

如上是Spring Cloud文档中对于Feign的定义,结合之前的两篇博文,在这里我们就可以吧Feign简单的理解为用户(前端)可以直接接触到的REST接口提供者。在Feign中,我们可以方便的访问和使用意已经在Erueka服务器中注册过的服务了。

1、建立maven工程,配置pom.xml文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
<parent>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter-parent</artifactId>
     <version> 1.5 . 2 .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.version> 1.8 </java.version>
</properties>
 
<dependencies>
     <dependency>
         <groupId>org.springframework.cloud</groupId>
         <artifactId>spring-cloud-starter-feign</artifactId>
     </dependency>
     <dependency>
         <groupId>org.springframework.cloud</groupId>
         <artifactId>spring-cloud-starter-eureka</artifactId>
     </dependency>
     <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>Camden.SR6</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>

2、建立包及启动类FeignApplication

1
2
3
4
5
6
7
8
9
10
11
12
13
14
/**
  * Created by gaofeng on 2017/7/14.
  */
@Configuration
@ComponentScan
@EnableAutoConfiguration
@EnableEurekaClient
@EnableFeignClients
@SpringBootApplication
public  class  FeignApplication {
     public  static  void  main(String[] args) {
         SpringApplication.run(FeignApplication. class , args);
     }
}

3、建立接口类,用来调用上文中FEIGN-CLIENT-TEST-001服务的方法hello(),FEIGN-CLIENT-TEST-001是全大写的

1
2
3
4
5
@FeignClient ( "FEIGN-CLIENT-TEST-001" )
public  interface  IHello {
     @RequestMapping (value =  "/hello" ,method = RequestMethod.GET)
     String hello();
}

其中@FeignClient中指定需要调用的微服务的名称(全大写),@RequestMapping中指定访问微服务响应接口的路径,如之前微服务的hello方法是通过"/hello"路径访问,那么这里需要配置一致

4、新建Controller类,为前端提供REST接口

1
2
3
4
5
6
7
8
9
@RestController
public  class  HelloController {
     @Autowired
     private  IHello iHello;
     @RequestMapping (value =  "gethello" ,method = RequestMethod.GET)
     public  String getHello() {
         return  iHello.hello();
     }
}

5、配置Feign的配置文件,指定Eureka服务器注册地址和访问端口application.yml

1
2
3
4
5
6
7
8
9
server:
   port:  8081
eureka:
   client:
     serviceUrl:
       defaultZone: http: //localhost:1000/eureka/
spring:
   application:
     name: feign-client-test- 002

6、运行,查看之前Erueka服务端的页面

wKioL1loa7zh0vBVAAHgmclJuas961.png-wh_50

7、访问:http://127.0.0.1:8081/gethello

wKiom1loa_TBHte8AAA_ht7WR9A893.png-wh_50

这里访问的就是feign-client-test-001的hello服务。


本文转自gaofeng36599 51CTO博客,原文链接:http://blog.51cto.com/786678398/1947471

相关文章
|
1月前
|
负载均衡 Java API
Spring Cloud 面试题及答案整理,最新面试题
Spring Cloud 面试题及答案整理,最新面试题
138 1
|
1月前
|
Java Nacos Sentinel
Spring Cloud Alibaba 面试题及答案整理,最新面试题
Spring Cloud Alibaba 面试题及答案整理,最新面试题
202 0
|
1月前
|
SpringCloudAlibaba Java 持续交付
【构建一套Spring Cloud项目的大概步骤】&【Springcloud Alibaba微服务分布式架构学习资料】
【构建一套Spring Cloud项目的大概步骤】&【Springcloud Alibaba微服务分布式架构学习资料】
146 0
|
1月前
|
SpringCloudAlibaba Java 网络架构
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(七)Spring Cloud Gateway服务网关
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(七)Spring Cloud Gateway服务网关
98 0
|
8天前
|
负载均衡 Java 开发者
细解微服务架构实践:如何使用Spring Cloud进行Java微服务治理
【4月更文挑战第17天】Spring Cloud是Java微服务治理的首选框架,整合了Eureka(服务发现)、Ribbon(客户端负载均衡)、Hystrix(熔断器)、Zuul(API网关)和Config Server(配置中心)。通过Eureka实现服务注册与发现,Ribbon提供负载均衡,Hystrix实现熔断保护,Zuul作为API网关,Config Server集中管理配置。理解并运用Spring Cloud进行微服务治理是现代Java开发者的关键技能。
|
8天前
|
Java API 对象存储
对象存储OSS产品常见问题之使用Spring Cloud Alibaba情况下文档添加水印如何解决
对象存储OSS是基于互联网的数据存储服务模式,让用户可以安全、可靠地存储大量非结构化数据,如图片、音频、视频、文档等任意类型文件,并通过简单的基于HTTP/HTTPS协议的RESTful API接口进行访问和管理。本帖梳理了用户在实际使用中可能遇到的各种常见问题,涵盖了基础操作、性能优化、安全设置、费用管理、数据备份与恢复、跨区域同步、API接口调用等多个方面。
24 2
|
23天前
|
负载均衡 网络协议 Java
构建高效可扩展的微服务架构:利用Spring Cloud实现服务发现与负载均衡
本文将探讨如何利用Spring Cloud技术实现微服务架构中的服务发现与负载均衡,通过注册中心来管理服务的注册与发现,并通过负载均衡策略实现请求的分发,从而构建高效可扩展的微服务系统。
|
23天前
|
开发框架 负载均衡 Java
Spring boot与Spring cloud之间的关系
总之,Spring Boot和Spring Cloud之间的关系是一种构建和扩展的关系,Spring Boot提供了基础,而Spring Cloud在此基础上提供了分布式系统和微服务架构所需的扩展和工具。
18 4
Spring boot与Spring cloud之间的关系
|
1月前
|
SpringCloudAlibaba 负载均衡 Java
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(目录大纲)
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(目录大纲)
65 1
|
1月前
|
Java Nacos Sentinel
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(九)Nacos+Sentinel+Seata
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(九)Nacos+Sentinel+Seata
199 0