搭建SpringCloud注册服务提供者和服务消费者之Eureka

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/Thinkingcao/article/details/84582845

一.注册服务提供者

 根据上节讲述的服务注册之Eureka注册中心,这节讲述服务提供者和服务消费者provider

1.1、先新建一个Maven项目,会员提供者

 

1.2、 引入依赖

       <parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>2.0.1.RELEASE</version>
	</parent>
	<!-- 管理依赖 -->
	<dependencyManagement>
		<dependencies>
			<dependency>
				<groupId>org.springframework.cloud</groupId>
				<artifactId>spring-cloud-dependencies</artifactId>
				<version>Finchley.M7</version>
				<type>pom</type>
				<scope>import</scope>
			</dependency>
		</dependencies>
	</dependencyManagement>
	<dependencies>
		<!-- SpringBoot整合Web组件 -->
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-web</artifactId>
		</dependency>
		<!-- SpringBoot整合eureka客户端 -->
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
		</dependency>
	</dependencies>
	<!-- 注意: 这里必须要添加, 否者各种依赖有问题 -->
	<repositories>
		<repository>
			<id>spring-milestones</id>
			<name>Spring Milestones</name>
			<url>https://repo.spring.io/libs-milestone</url>
			<snapshots>
				<enabled>false</enabled>
			</snapshots>
		</repository>
	</repositories>

1.3 、配置application.yml

###服务启动端口号
server:
  port: 8000
###服务名称(服务注册到eureka名称)  
spring:
    application:
        name: app-thinkingcao-member
###在此指定服务注册中心地址,服务注册到eureka地址
eureka:
  client:
    service-url:
           defaultZone: http://localhost:8888/eureka
          
###启动注册操作,该值默认为true。若设置为fasle将不会启动注册操作。是否需要去检索寻找服务,默认是###true
    register-with-eureka: true
###是否需要从eureka上获取注册信息
    fetch-registry: true

1.4 编写MemberController

package com.thinkingcao.modules.controller;

import java.util.ArrayList;
import java.util.List;

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class MemberController {

	@RequestMapping("/getUserList")
	public List<String> getUserList() {
		List<String> listUser = new ArrayList<String>();
		listUser.add("zhangsan");
		listUser.add("lisi");
		listUser.add("caowencao");
		return listUser;
	}

}

1.5、 编写member-provider启动类,然后启动member-provider会员服务,(注意:在启动member-provider服务之前,必须先启动eureka—server服务,否则报错,因为要将member-provider服务注册到eureka—server注册中心)

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;

/**
 * <pre>
 * @author cao_wencao
 * @date 2018年11月14日 上午10:16:42
 * </pre>
 */
@SpringBootApplication
@EnableEurekaClient
public class ProviderApplication {

	/**
	 * <pre>  
	 * @author cao_wencao
	 * @param args
	 * </pre>  
	 */
	public static void main(String[] args) {
		SpringApplication.run(ProviderApplication.class, args);

	}

}

1.6、 访问Eureka注册中心,URL地址 : http://localhost:8888/ , 会员服务已经注册到Eureka注册中心了

二.注册服务消费者

2.1、新建一个Maven项目,订单消费者

扫描二维码关注公众号,回复: 4382419 查看本文章

2.2、引入依赖pom.xml

     <parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>2.0.1.RELEASE</version>
	</parent>
	<!-- 管理依赖 -->
	<dependencyManagement>
		<dependencies>
			<dependency>
				<groupId>org.springframework.cloud</groupId>
				<artifactId>spring-cloud-dependencies</artifactId>
				<version>Finchley.M7</version>
				<type>pom</type>
				<scope>import</scope>
			</dependency>
		</dependencies>
	</dependencyManagement>
	<dependencies>
		<!-- SpringBoot整合Web组件 -->
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-web</artifactId>
		</dependency>
		<!-- SpringBoot整合eureka客户端 -->
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
		</dependency>

	</dependencies>
	<!-- 注意: 这里必须要添加, 否者各种依赖有问题 -->
	<repositories>
		<repository>
			<id>spring-milestones</id>
			<name>Spring Milestones</name>
			<url>https://repo.spring.io/libs-milestone</url>
			<snapshots>
				<enabled>false</enabled>
			</snapshots>
		</repository>
	</repositories>

2.3、配置application.yml

###服务启动端口号
server:
  port: 8001
###服务名称(服务注册到eureka名称)  
spring:
    application:
        name: app-thinkingcao-order
###服务注册到eureka地址
eureka:
  client:
    service-url:
           defaultZone: http://localhost:8888/eureka

           
###因为该应用为注册中心,不会注册自己
    register-with-eureka: true
###是否需要从eureka上获取注册信息
    fetch-registry: true

2.4、 编写OrderController

package com.thinkingcao.modules.controller;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;

/**
 * <pre>
 * @author cao_wencao
 * @date 2018年11月28日 下午2:43:19
 * </pre>
 */
@RestController
public class OrderController {
	@Autowired
	private RestTemplate restTemplate;

	@RequestMapping("/getOrder")
	public String getOrder() {
		// order 使用rpc 远程调用技术 调用 会员服务
		String memberUrl = "http://app-thinkingcao-member/getUserList";
		String result = restTemplate.getForObject(memberUrl, String.class);
		System.out.println("会员服务调用订单服务,result:" + result);
		return result;
	}

}

2.5、 编写order-consumer启动类,然后启动order-consumer 订单服务(启动顺序: 注册中心——会员提供者——订单消费者)

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;

/**
 * <pre>
 * &#64;author cao_wencao
 * &#64;date 2018年11月14日 上午10:16:42
 * </pre>
 */
@SpringBootApplication
@EnableEurekaClient
public class ConsumerApplication {

	/**
	 * <pre>
	 *   
	 * &#64;author cao_wencao
	 * &#64;param args
	 * </pre>
	 */
	public static void main(String[] args) {
		SpringApplication.run(ConsumerApplication.class, args);

	}
 
	// @LoadBalanced就能让这个RestTemplate在请求时拥有客户端负载均衡的能力
	@Bean
	@LoadBalanced
	RestTemplate restTemplate() {
		return new RestTemplate();
	}

}

2.6、 Console截图:

2.7、 访问Eureka注册中心,URL地址 : http://localhost:8888/ ,订单服务已经注册到Eureka注册中心了

2.8、 访问订单服务,测试订单服务通过注册中心调取会员服务获取的数据,URL:http://localhost:8001/getorder

 

2.9、查看Console控制台

项目源码:https://github.com/Thinkingcao/SpringCloudBucket.git

猜你喜欢

转载自blog.csdn.net/Thinkingcao/article/details/84582845