概念:

Spring Cloud是一个分布式的整体解决方案。

Spring Cloud 为开发者提供了在分布式系统(配置管理,服务发现,熔断,路由,微代理,控制总线,一次性token,全局琐,leader选举,分布式session,集群状态)中快速构建的工具,使用Spring Cloud的开发者可以快速的启动服务或构建应用、同时能够快速和云平台资源进行对接。

SpringCloud分布式开发五大常用组件:

  • 服务发现——Netflix Eureka(注册中心)
  • 客服端负载均衡——Netflix Ribbon (具体调用)
  • 断路器——Netflix Hystrix  (当流程中某一服务出问题时可以快速响应失败)
  • 服务网关——Netflix Zuul  (流程中过滤请求)
  • 分布式配置——Spring Cloud Config  (配置)

项目流程:

首先,新建一个空项目springcloud

  1. 创建注册中心
      1. 配置Eureka信息

      1. server:
      2. port: 8761
      3. eureka:
      4. instance:
      5. hostname: eureka-server #eureka实例的主机名
      6. client:
      7. register-with-eureka: false #不把自己注册到eureka 上
      8. fetch-registry: false #不从eureka上获取服务的注册信息
      9. service-url:
      10. defaultZone: http://localhost:8761/eureka/
      1.  
      1. @EnableEurekaServer
      1. 启动类:
      2. @EnableEurekaServer
      3. @SpringBootApplication
      4. public class EurekaServerApplication {
      5.  
      6. public static void main(String[] args) {
      7. SpringApplication.run(EurekaServerApplication.class, args);
      8. }
      9.  
      10. }
    1. 启动主注册中心主程序
  2. 创建provider提供者
      1. 配置Eureka提供者信息

      1. server:
      2. #port: 8001
      3. port: 8002
      4. spring:
      5. application:
      6. name: provider-ticket
      7.  
      8. eureka:
      9. instance:
      10. prefer-ip-address: true #注册服务的时候使用服务的ip地址
      11. client:
      12. service-url:
      13. defaultZone: http://localhost:8761/eureka/
    1. 编写被调用的controller和service
      1. controller:
      2. @RestController
      3. public class TicketController {
      4.  
      5. @Autowired
      6. TicketService ticketService;
      7.  
      8. @GetMapping("/ticket")
      9. public String getTicket(){
      10. return ticketService.getTicket();
      11. }
      12.  
      13. }
      14.  
      15. service:
      16. @Service
      17. public class TicketService {
      18.  
      19. public String getTicket(){
      20. //System.out.println("8001");
      21. System.out.println("8002");
      22. return "《拿到票了》";
      23. }
      24. }
    2. 分别打包 8001 ,8002 成jar包,并分别用cmd命令运行   java -jar provider-ticket-0.0.1-SNAPSHOT-8001T.jar   /   java -jar provider-ticket-0.0.1-SNAPSHOT-8002T.jar,此时http://localhost:8761/注册中心下会看到同一个应用的两个实例
  3. 创建consumer-user消费者
      1. 配置Eureka消费者信息
      1. spring:
      2. application:
      3. name: consumer-user
      4. server:
      5. port: 8200
      6.  
      7. eureka:
      8. instance:
      9. prefer-ip-address: true #注册服务的时候使用服务的ip地址
      10. client:
      11. service-url:
      12. defaultZone: http://localhost:8761/eureka/
    1. 创建请求
      1. 开启发现服务功能并启动主程序,负载均衡可以使实例被调用时轮流调用

      1.  
    2. 程序启动后,此时注册中心可以查看到,通过url:http://localhost:8200/buy?name=zhangsanfeng      刷新  可以测试负载均衡

springcluoud入门的更多相关文章

  1. Angular2入门系列教程7-HTTP(一)-使用Angular2自带的http进行网络请求

    上一篇:Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数 感觉这篇不是很好写,因为涉及到网络请求,如果采用真实的网络请求,这个例子大家拿到手估计还要自己写一个web ...

  2. ABP入门系列(1)——学习Abp框架之实操演练

    作为.Net工地搬砖长工一名,一直致力于挖坑(Bug)填坑(Debug),但技术却不见长进.也曾热情于新技术的学习,憧憬过成为技术大拿.从前端到后端,从bootstrap到javascript,从py ...

  3. Oracle分析函数入门

    一.Oracle分析函数入门 分析函数是什么?分析函数是Oracle专门用于解决复杂报表统计需求的功能强大的函数,它可以在数据中进行分组然后计算基于组的某种统计值,并且每一组的每一行都可以返回一个统计 ...

  4. Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数

    上一篇:Angular2入门系列教程5-路由(一)-使用简单的路由并在在路由中传递参数 之前介绍了简单的路由以及传参,这篇文章我们将要学习复杂一些的路由以及传递其他附加参数.一个好的路由系统可以使我们 ...

  5. Angular2入门系列教程5-路由(一)-使用简单的路由并在在路由中传递参数

    上一篇:Angular2入门系列教程-服务 上一篇文章我们将Angular2的数据服务分离出来,学习了Angular2的依赖注入,这篇文章我们将要学习Angualr2的路由 为了编写样式方便,我们这篇 ...

  6. Angular2入门系列教程4-服务

    上一篇文章 Angular2入门系列教程-多个组件,主从关系 在编程中,我们通常会将数据提供单独分离出来,以免在编写程序的过程中反复复制粘贴数据请求的代码 Angular2中提供了依赖注入的概念,使得 ...

  7. wepack+sass+vue 入门教程(三)

    十一.安装sass文件转换为css需要的相关依赖包 npm install --save-dev sass-loader style-loader css-loader loader的作用是辅助web ...

  8. wepack+sass+vue 入门教程(二)

    六.新建webpack配置文件 webpack.config.js 文件整体框架内容如下,后续会详细说明每个配置项的配置 webpack.config.js直接放在项目demo目录下 module.e ...

  9. wepack+sass+vue 入门教程(一)

    一.安装node.js node.js是基础,必须先安装.而且最新版的node.js,已经集成了npm. 下载地址 node安装,一路按默认即可. 二.全局安装webpack npm install ...

随机推荐

  1. SparkListener监听使用方式及自定义的事件处理动作

    本文针对spark 2.0+版本 概述 spark 提供了一系列整个任务生命周期中各个阶段变化的事件监听机制,通过这一机制可以在任务的各个阶段做一些自定义的各种动作.SparkListener便是这些 ...

  2. 2019-2020 ICPC, Asia Jakarta Regional Contest (Online Mirror, ICPC Rules, Teams Preferred)

    2019-2020 ICPC, Asia Jakarta Regional Contest (Online Mirror, ICPC Rules, Teams Preferred) easy: ACE ...

  3. Codeforces Round #526 D - The Fair Nut and the Best Path /// 树上两点间路径花费

    题目大意: 给定一棵树 树上每个点有对应的点权 树上每条边有对应的边权 经过一个点可得到点权 经过一条边必须花费边权 即从u到v 最终得分=u的点权-u到v的边权+v的点权 求树上一条路径使得得分最大 ...

  4. 2018今日头条湖北省赛【A】

    [题目链接]https://www.nowcoder.com/acm/contest/104/A 这题就是很简单的几何题..md现场推了很久的cos sin仿佛像个zz.自己都想给自己一巴掌. 题意就 ...

  5. vue点击跳转拨号界面

    <a :href="'tel:' + VipInfo.HotelPhone" style="text-decoration:none;color:black;opa ...

  6. DLL相关下断点

    加载DLL 的时候断: sxe ld:[dll] 卸载DLL 的时候断: sxe ud:[dll] 比如: sxe ld:wininet.dll  (在wininet.dll 被装载的时候断点) 这里 ...

  7. finalize的作用

    1. finalize的作用 finalize()是Object的protected方法,子类可以覆盖该方法以实现资源清理工作,GC在回收对象之前调用该方法. finalize()与C++中的析构函数 ...

  8. Android开发 多媒体提取器MediaExtractor详解_将一个视频文件分离视频与音频

    前言 此篇博客讲解MediaExtractor将一个视频文件分离视频与音频,如果你对MediaExtractor还没有一个笼统的概念建议先了解我的另一篇入门博客:https://www.cnblogs ...

  9. Redis 常用的数据结构

    String 字符串 set get 使用场景: 可以用来作为缓存使用(缓存更新策略和缓存雪崩如何处理) List lpop rpop lpush rpush 使用场景: set 无序集合 使用场景: ...

  10. 基于V8引擎的C++和JS的相互交互

    基于什么原因略! 1. 脚本引擎的基本功能 V8只是一个JS引擎.去除它的特点功能出处,它必须要实现JS引擎的几个基础功能: 脚本执行:脚本可能是一个表达式:一段js代码:或者一个文件执行表达式返回j ...