黑马程序员十次方微服务项目开发实践,十次方项目SpringCloud初探(十六)

一、Eureka服务端开发

(1)创建tensquare_eureka模块
(2)引入依赖 父工程pom.xml定义SpringCloud版本

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Finchley.M9</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

注意:是父工程的pom.xml
tensquare_eureka模块pom.xml引入eureka-server

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

(2)添加application.yml

server:
  port: 6868 #服务端口
eureka:
  client:
    registerWithEureka: false #是否将自己注册到Eureka服务中,本身就是所有无需注册
    fetchRegistry: false #是否从Eureka中获取注册信息
    serviceUrl: #Eureka客户端与Eureka服务端进行交互的地址
      defaultZone: http://127.0.0.1:${server.port}/eureka/


(3)编写启动类
创建包com.tensquare.eureka ,包下建立类

@SpringBootApplication
@EnableEurekaServer
public class EurekaServer {
    public static void main(String[] args) {
        SpringApplication.run(EurekaServer.class, args);
    }
}

(4)启动运行启动类,然后在浏览器地址栏输入 http://localhost:6868/ 运行效果如
下:
黑马程序员十次方微服务项目开发实践,十次方项目SpringCloud初探(十六)_第1张图片

主界面中system status为系统信息 General Info为一般信息 Instances currently registered with Eureka为注册到的所有微服务列表

二、服务注册

将所有的微服务都注册到Eureka中,这样所有的微服务之间都可以互相调用了。
(1)将其他微服务模块添加依赖

	  <dependency>
		  <groupId>org.springframework.cloud</groupId>
		  <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
	  </dependency>

(2)修改每个微服务的application.yml,添加注册eureka服务的配置

eureka:
  client:
    service-url:
      defaultZone: http://localhost:6868/eureka
  instance:
    prefer-ip-address: true

(3)修改每个服务类的启动类,添加注解

@EnableEurekaClient

(4)启动测试:将每个微服务启动起来,会发现eureka的注册列表中可以看到这些微服
务了
黑马程序员十次方微服务项目开发实践,十次方项目SpringCloud初探(十六)_第2张图片
一共是九个

三、Feign实现服务间的调用

  1. Feign简介
    Feign是简化Java HTTP客户端开发的工具(java-to-httpclient-binder),它的灵感来自于Retrofit、JAXRS-2.0和WebSocket。Feign的初衷是降低统一绑定Denominator到HTTP API的复杂度,不区分是否为restful。
  2. 快速体验
    现在在问答微服务调用基础微服务的方法(根据ID查询标签)
    (1)在tensquare_qa模块添加依赖
      <dependency>
          <groupId>org.springframework.cloud</groupId>
          <artifactId>spring-cloud-starter-openfeign</artifactId>
      </dependency>

(2)修改tensquare_qa模块的启动类,添加注解

@EnableDiscoveryClient
@EnableFeignClients

(3)在tensquare_qa模块创建 com.tensquare.qa.client包,包下创建接口

@FeignClient("tensquare-base")
public interface LabelClient {
    @RequestMapping(value="/label/{id}", method = RequestMethod.GET)
    public Result findById(@PathVariable("id") String id);
}

@FeignClient注解用于指定从哪个服务中调用功能 ,注意 里面的名称与被调用的服务名保持一致,并且不能包含下划线。

@RequestMapping注解用于对被调用的微服务进行地址映射。注意 @PathVariable注解一定要指定参数名称,否则出错

(5)修改tensquare_qa模块的 ProblemController

	@Autowired
	private LabelClient labelClient;
	@RequestMapping(value = "/label/{labelid}")
	public Result findLabelById(@PathVariable String labelid){
		Result result = labelClient.findById(labelid);
		return result;
	}

(6)测试:http://localhost:9003/problem/label/1 能看到标签的信息
在这里插入图片描述

3.负载均衡
测试:同时开启多个基础微服务,看是否是轮流调用。
修改tensquare_base工程LabelController的findById方法

@RequestMapping(value="/{id}", method = RequestMethod.GET)
	public Result findById(@PathVariable String id){
		System.out.println("No.1");
		return new Result(true,StatusCode.OK,"查询成功",labelService.findById(id) );
}

启动基础微服务后,修改端口和输出信息,再次启动基础微服务
启动问答微服务,浏览器执行http://localhost:9003/problem/label/1 看是否轮流启动。

你可能感兴趣的:(十次方项目)