概念:

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信息

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

      server:
      #port: 8001
      port: 8002
      spring:
      application:
      name: provider-ticket eureka:
      instance:
      prefer-ip-address: true #注册服务的时候使用服务的ip地址
      client:
      service-url:
      defaultZone: http://localhost:8761/eureka/
    2. 编写被调用的controller和service
      controller:
      @RestController
      public class TicketController { @Autowired
      TicketService ticketService; @GetMapping("/ticket")
      public String getTicket(){
      return ticketService.getTicket();
      } } service:
      @Service
      public class TicketService { public String getTicket(){
      //System.out.println("8001");
      System.out.println("8002");
      return "《拿到票了》";
      }
      }
    3. 分别打包 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消费者信息
      spring:
      application:
      name: consumer-user
      server:
      port: 8200 eureka:
      instance:
      prefer-ip-address: true #注册服务的时候使用服务的ip地址
      client:
      service-url:
      defaultZone: http://localhost:8761/eureka/
    2. 创建请求
    3. 开启发现服务功能并启动主程序,负载均衡可以使实例被调用时轮流调用

    4. 程序启动后,此时注册中心可以查看到,通过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. MySQL查询语句详解,排序、分组、聚合函数、约束

    create database day20; 查询的时候from前面的字段是需要显示出来的内容,后面是条件use day20;create table phones(id int,pinpai var ...

  2. 面试系列38 分库分表之后,id主键如何处理?

    (1)数据库自增id 这个就是说你的系统里每次得到一个id,都是往一个库的一个表里插入一条没什么业务含义的数据,然后获取一个数据库自增的一个id.拿到这个id之后再往对应的分库分表里去写入. 这个方案 ...

  3. window下apache2.2配置多个tomcat使用不同二级域名,共用80端口

    思路:分3步, 1,安装apache服务器httpd-2.2.25-win32-x86-no_ssl.msi,安装tomcat 2,配置tomcat默认访问的项目,配置apache服务器 3,测试 第 ...

  4. Centos6.5离线安装gcc

    木有网的centos折腾起来简直费劲的不要不要的~ 学校的虚拟机最开始只安装了一个libgcc-4.4.7-4,然而这是不够用的,比如安装软件的时候,需要输入"./configure&quo ...

  5. BBS论坛 自定义form组件

    二.自定义form组件 from django import forms from django.forms import widgets from app01 import models # 定制f ...

  6. 论文学习02-《On the Effectiveness of Visible Watermarks》

    I. Estimating the Matted Watermark 给定所有图像中的水印当前估计的区域,我们通过观察这些区域图像梯度的一致性来检测出水印梯度,也就是我们通过计算这些区域的图像梯度的中 ...

  7. vue-router 的重定向-redirect

    1. 我们主要在index.js重新设置路由的重新定向redirect参数 index.js import Vue from 'vue' import Router from 'vue-router' ...

  8. load data local infile

    发财 基本语法:load data [low_priority] [local] infile '文件名称' [replace替换策略 | ignore忽略策略]into table 表名称[fiel ...

  9. python 基本常用数据类型

    #字典类型 result={1:2222,2:2221111}; result.items();#获取字典中所有元素 result.keys();#获取字典的key result.values();# ...

  10. thinkphp 模板布局

    ThinkPHP的模板引擎内置了布局模板功能支持,可以方便的实现模板布局以及布局嵌套功能. 有三种布局模板的支持方式: 第一种方式:全局配置方式 这种方式仅需在项目配置文件中添加相关的布局模板配置,就 ...