项目结构

环境:

idea:2020.1 版

jdk:8

maven:3.6.2

1. 搭建项目

( 1 )父工程:spring_cloud_demo_parent

pom 文件

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<modules>
<module>miscroservice-eureka-server</module>
<module>miscroservice-eureka-user</module>
<module>miscroservice-eureka-order</module>
</modules>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.0.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.kevin.parent</groupId>
<artifactId>demo_parent</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>demo_parent</name>
<description>Demo project for Spring Boot</description>
<packaging>pom</packaging> <properties>
<java.version>1.8</java.version>
<spring-cloud.version>Hoxton.SR4</spring-cloud.version>
</properties> <dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement> <dependencies>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.68</version>
</dependency>
</dependencies> <build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build> </project>

  

( 2 ) 注册中心 eureka: miscroservice-eureka-server

pom 文件

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>demo_parent</artifactId>
<groupId>com.kevin.parent</groupId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion> <artifactId>miscroservice-eureka-server</artifactId> <dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka-server</artifactId>
<version>1.4.7.RELEASE</version>
</dependency>
</dependencies> </project>  

application.yml 文件:

server:
port: 8761
eureka:
instance: # 实例
hostname: localhost
client:
register-with-eureka: false # 不需要向自己注册
fetch-registry: false # 不需要向自己检索
service-url: #注册中心访问方式
defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka

  

( 3 )服务提供者:miscroservice-eureka-order

pom 文件

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>demo_parent</artifactId>
<groupId>com.kevin.parent</groupId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion> <artifactId>miscroservice-eureka-order</artifactId> <dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
<version>1.4.7.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies> </project>

 application.yml:

server:
port: 7900
eureka:
instance:
prefer-ip-address: true # 是否显示主机 ip
client:
service-url:
defaultZone: http://localhost:8761/eureka/
spring:
application:
name: miscroservice-eureka-order

 ( 4 )服务消费者:miscroservice-eureka-user

pom 文件

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>demo_parent</artifactId>
<groupId>com.kevin.parent</groupId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion> <artifactId>miscroservice-eureka-user</artifactId> <dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
<version>1.4.7.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-commons</artifactId>
</dependency>
</dependencies> </project>

  application.yml:

server:
port: 8000
eureka:
instance:
prefer-ip-address: false # 是否显示主机的 ip
instance-id: ${spring.cloud.client.ip-address}:${server.port} # 将服务实例 id 设置为 ip:端口号形式
client:
service-url:
defaultZone: http://localhost:8761/eureka/ # 指定 eureka 服务地址
spring:
application:
name: miscroservice-eureka-user

  

2. 编写业务代码

( 1 )注册中心 eureka 启动类

package com.kevin.eureka.server;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer; /**
* @author kevin
* @version: EurekaApplication.java v 1.0, 2020年05月21日 12:57
* @Description
*
* @EnableEurekaServer 表明该服务是一个 eureka 注册中心服务
**/
@SpringBootApplication
@EnableEurekaServer
public class EurekaApplication { public static void main(String[] args) {
SpringApplication.run(EurekaApplication.class, args);
}
}

( 2 )服务提供者

A. 启动类:

package com.kevin.eureka.order;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient; /**
* @author kevin
* @version: OrderApplication.java v 1.0, 2020年05月21日 21:43
* @Description
**/
@SpringBootApplication
@EnableEurekaClient
public class OrderApplication { public static void main(String[] args) {
SpringApplication.run(OrderApplication.class, args);
}
}

B. po:

package com.kevin.eureka.order.po;

import lombok.Data;
import lombok.ToString; import java.io.Serializable; /**
* @author kevin
* @version: Order.java v 1.0, 2020年05月21日 21:48
* @Description
**/
@Data
@ToString
public class Order implements Serializable { private String id;
private Double price;
private String receiverName;
private String receiverAddress;
private String receiverPhone;
}

C. controller

package com.kevin.eureka.order.controller;

import com.alibaba.fastjson.JSON;
import com.kevin.eureka.order.po.Order;
import com.kevin.eureka.order.service.ServiceInfoManager;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController; /**
* @author kevin
* @version: OrderController.java v 1.0, 2020年05月21日 21:51
* @Description
**/
@RestController
public class OrderController { @Autowired
private ServiceInfoManager manager; /**
* 通过 id 查询订单
*
* @param id
* @return
*/
@RequestMapping("/order/{id}")
public String findOrderById(@PathVariable String id) {
int port = manager.getPort();
System.out.println("port = " + port);
Order order = new Order();
order.setId("123");
order.setPrice(20.00);
order.setReceiverName("小李");
order.setReceiverAddress("北京市昌平区");
order.setReceiverPhone("123456");
return JSON.toJSONString(order);
}
}

D. 获取服务端口号

package com.kevin.eureka.order.service;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.core.env.Environment;
import org.springframework.stereotype.Component; /**
* @author kevin
* @version: ServiceInfoManager.java v 1.0, 2020年05月22日 10:48
* @Description
**/
@Component
public class ServiceInfoManager { @Autowired
private Environment env; /**
* 获取端口号
*
* @return
*/
public int getPort() {
String s = env.getProperty("server.port");
return Integer.parseInt(s);
}
}

( 3 )服务消费者:

A. 启动类

package com.kevin.eureka.user;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient; /**
* @author kevin
* @version: UserApplication.java v 1.0, 2020年05月21日 13:09
* @Description
**/
@SpringBootApplication
@EnableEurekaClient
public class UserApplication { public static void main(String[] args) {
SpringApplication.run(UserApplication.class, args);
}
}

B. controller:

package com.kevin.eureka.user.com.kevin.eureka.controller;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate; /**
* @author kevin
* @version: UserController.java v 1.0, 2020年05月22日 10:15
* @Description
**/
@RestController
public class UserController { public static final String ORD_URL = "http://miscroservice-eureka-order/order/"; @Autowired
private RestTemplate restTemplate; @RequestMapping("/findOrdersByUser/{id}")
public String findOrdersByUser(@PathVariable String id) {
String oId = "123";
return restTemplate.getForObject(ORD_URL + oId, String.class); }
}

C. 配置类

package com.kevin.eureka.user.com.kevin.eureka.config;

import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.client.RestTemplate; /**
* @author kevin
* @version: UserConfig.java v 1.0, 2020年05月22日 10:13
* @Description
**/
@Configuration
public class UserConfig { @Bean
@LoadBalanced // 通过 ribbon 实现客户端请求的负载均衡
public RestTemplate createResTemp(){
return new RestTemplate();
}
}

 

3.  分别启动 eureka、order、user 服务

浏览器中打开  http://localhost:8761/ ,可以看到 order、user 服务都已经注册进来

4. 修改 order 端口号为 7901 (不要停止 order 服务)

5. 修改idea 配置,由单一启动改为 平行启动,即 将一个服务只能启动一次 改为 可以启动多次

选择 OrderApplication,并 勾上 Allow parallel run

启动 OrderAoolication

查看注册中心

6. postman 测试

快速按 send,查看 idea 控制台,两个服务都有请求

端口号为 7900 的服务:

端口号为 7901 的服务:

spring cloud 通过 ribbon 实现客户端请求的负载均衡(入门级)的更多相关文章

  1. 一起来学Spring Cloud | 第三章:服务消费者 (负载均衡Ribbon)

    一.负载均衡的简介: 负载均衡是高可用架构的一个关键组件,主要用来提高性能和可用性,通过负载均衡将流量分发到多个服务器,多服务器能够消除单个服务器的故障,减轻单个服务器的访问压力. 1.服务端负载均衡 ...

  2. Spring Cloud分区发布实践(3) 网关和负载均衡

    注意: 因为涉及到配置测试切换, 中间环节需按此文章操作体验, 代码仓库里面的只有最后一步的代码 准备好了微服务, 那我们就来看看网关+负载均衡如何一起工作 新建一个模块hello-gateway, ...

  3. spring boot 2.0.3+spring cloud (Finchley)2、搭建负载均衡Ribbon (Eureka+Ribbon+RestTemplate)

    Ribbon是Netflix公司开源的一个负载均衡组件,将负载均衡逻辑封装在客户端中,运行在客户端的进程里. 本例子是在搭建好eureka的基础上进行的,可参考spring boot 2.0.3+sp ...

  4. spring cloud使用zuul实现反向代理和负载均衡

    首先,这篇文章参考的是http://blog.didispace.com/springcloud5/这位大牛的博客.本人是通过这篇博客来学习zuul的,现在写的博客只是个人在学习时个人的一些感受和理解 ...

  5. Spring cloud gateway 如何在路由时进行负载均衡

    本文为博主原创,转载请注明出处: 1.spring cloud gateway 配置路由 在网关模块的配置文件中配置路由: spring: cloud: gateway: routes: - id: ...

  6. spring cloud 注册、发现、消费、负载均衡

  7. spring cloud 使用ribbon简单处理客户端负载均衡

    假如我们的multiple服务的访问量剧增,用一个服务已经无法承载, 我们可以把Hello World服务做成一个集群. 很简单,我们只需要复制Hello world服务,同时将原来的端口8762修改 ...

  8. Spring Cloud第四篇 | 客户端负载均衡Ribbon

    ​ 本文是Spring Cloud专栏的第四篇文章,了解前三篇文章内容有助于更好的理解本文: ​Spring Cloud第一篇 | Spring Cloud前言及其常用组件介绍概览 Spring Cl ...

  9. Spring cloud 之Ribbon(一)基本使用

    简介 Spring cloud Ribbon是一个基于HTTP和TCP的客户端负载均衡工具,它是基于Netflix的Riboon实现的.Ribbon是客户端负载均衡器,这有别语例如Nginx服务端负载 ...

随机推荐

  1. JetBrains IntelliJ IDEA汉化

    JetBrains IntelliJ IDEA汉化 开启 IntelliJ IDEA,点击右下角Configure菜单,选择 Plugins.在弹出的 Plugins窗口里,切换至 Marketpla ...

  2. PTA 根据后序和中序遍历输出先序遍历 (25分)

    PTA 根据后序和中序遍历输出先序遍历 (25分) 本题要求根据给定的一棵二叉树的后序遍历和中序遍历结果,输出该树的先序遍历结果. 输入格式: 第一行给出正整数N(≤30),是树中结点的个数.随后两行 ...

  3. flask cache

    http://brunorocha.org/python/flask/using-flask-cache.html 如何在大项目中使用cache 新建全局cache.py cache = Cache( ...

  4. k8s 测试环境搭建

    # 安装kubectl https://kubernetes.io/docs/tasks/tools/install-kubectl/#install-kubectl-on-linux  # 官方安装 ...

  5. 解决一个无聊的问题,如何处理Java用户在dos被收集信息时拷贝带换行符的文本信息造成的while的多次循环(java解决Scanner.next在接收用户输入时出现多个换行的形况)[解决方案一]

    问题描述: 用户在dos窗口输入的时候(web项目不会出现这样的问题,所以这个问题日常碰不到),摁下回车时,Scanner对象的next()扫描用户输入的文本,后面就可以根据输入的字符串进行判断,并执 ...

  6. 虚拟化中虚拟机处理器核数与物理主机cpu的关系

    vCPU,顾名思义,是虚拟CPU. 创建虚拟机时,需要配置vCPU资源. 因此vCPU是虚拟机的部件. 因此脱离VM,谈论vCPU是没有意义的.虚拟化管理系统如何调度vCPU,取决于系统内的虚拟机数目 ...

  7. 细说ThreadLocal(一)

    前言 java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干个不同的数据区域.如下图所示: 其中堆是占虚拟机中内存最大的,堆被所有线程所共享,其最主要的便是存放实例对象.也因为堆内存是共 ...

  8. Docker 急速入门

    1. 概述 之前聊了很多 SpringCloud 相关的话题,今天我们来聊聊服务容器 Docker. 2. 在 CentOS7 安装 Docker 2.1 卸载旧版本的Docker  # yum re ...

  9. 多线程01.newThread的方式创建线程

    1.java应用程序的main函数是一个线程,是被jvm启动的时候调用,线程的名字叫main 2.实现一个线程,必须创建一个thread实例,override run方法,并且调用start方法. 3 ...

  10. Python之99乘法表代码

    #coding=utf-8 #左下三角格式输出九九乘法表 for i in range(1,10):      for j in range(1,i+1):          print " ...