范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文
国学影视

从零开始搭建公司SpringCloud架构技术栈,这套架构绝了!

  一、微服务基础1.什么是SpringCloud?
  SpringCloud官网:https://spring.io/projects/spring-cloud(个人建议是用谷歌浏览器访问官网打开中文翻译粗略把官网读一遍)
  个人理解:
  以前的服务器就好像,一个会语数外全能的老师,为学生提供服务,这个老师生病了,那全校停课。现在微服务流行后,学校有了数学教研组,语文教研组,外语教研组,每个教研组有一群老师具体负责某科的教学,缺了谁,学校都照样运转。
  而这个变化中,那些改变历史的程序员就是把一个服务器中的众多服务,或好几台服务器中的众多服务,分类出来,解耦合出来,把他们类似的功能交给同一个集群来做,把互相耦合在一起的功能剥离出来,按业务,按功能来把他们作为一个个微服务放在服务器上,而这个服务器就只提供一个服务,或较少的服务。让一个超大的服务逻辑,解耦合为一个个小服务,均匀的分布在各自的服务器中。微服务就微在这。
  每个教研组就是一个微服务集群。他们提供同样的服务,而注册中心Eureka就是这个存放这个教研组老师名单的地方,学生们想先访问这个注册中心获取教师名单,然后根据相应的负载方法去访问各自老师。不至于让集群中某一老师累死也不至于让某一老师闲死。
  而Zuul网关呢,就是学校的门卫,某些学生来学校找谁,它负责指引(路由),并且通过一些非常简单的配置,达到阻拦一些人进入(身份验证),或者控制想学数学的人只能去数学教研组,不能去核能教研组学怎么造原子弹(权限验证)。
  那Hystrix熔断器呢,可以把它当成学校的志愿者,当一个教研组集体罢课后,学生找不到老师了,这些志愿者及时的告诉来访问的学生,相应的结果,异常信息等,免得大量的学生在学校等待,这些志愿者赶快把这些等待的学生梳理出去,学生一直在学校等待,那其他需要学生的学校,也会等待学生,最后造成大面积的学校瘫痪。这里学生我们看成一个个请求。熔断器就是把某事故的蔓延即使熔断了。
  当然这些组件也是微服务需要注册到Eureka注册中心
  那SpringCloud就可以看成是这个学校了。众多上面提到的组件相当于都是这个学校的各职能部门。  二、微服务的搭建
  ps: 博主基于Maven+idea搭建。
  另外SpringCloud需要基于springboot搭建。
  引入Spring Boot相关依赖:这里的springboot用的是1.5.7版本;引入Spring Cloud相关依赖:这里为 Edgware.SR5  2.1 工程初始化配置
  在Idea中创建工程:File -> New ->Project
  点击 Empty Project -> Next
  项目命名 -> 项目位置
  选择模组 modules ->next
  进入新的窗口后,开始配置Maven,打开设置 setting
  因为我之前做过配置,因此只需要改变框1的路径,如第一次配置需要自己找到你maven放置的位置,以及settings.xml,repository的位置,实在不会的百度 maven集成idea
  3个框选择完毕后点击 ok
  接下来新建module
  这里可能会出现加载不出archetype list的问题
  用了网上的所有解决办法花了3个小时解决都没用,重启之后竟然可以了····你敢信?????小时候网吧网管的至理名言都忘了!!重启一下嘛!!
  出来之后 选择quickstart ->下一步
  名字自己想 想好后,复制一下你想好的 ArtifactId点击Next,groupId为组织名 也是自己想一个,一般为公司网址反写。
  粘贴后下一步
  提供注册服务的服务器pom.xml配置如下:  <?xml version="1.0" encoding="UTF-8"?>      4.0.0     com.yun   springcloud-eureka-server   1.0-SNAPSHOT     springcloud-eureka-server      http://www.example.com          UTF-8     1.7     1.7                org.springframework.boot     spring-boot-starter-parent     1.5.7.RELEASE                         org.springframework.cloud       spring-cloud-starter-netflix-eureka-server                                         org.springframework.cloud         spring-cloud-dependencies         Edgware.SR5         pom         import                
  点击Import Changes
  等待右下角加载springcloud的依赖
  2.2 Springboot的搭建 以及提供注册服务 的 服务配置
  创建resources文件夹
  并设置作为资源根目录,之后文件变成这样
  之后文件夹变成有黄色的横杠
  在resources下新建文件,文件名为application.yml (对是yml 不是xml ,博主第一次学习时,还以为是其他博主打错了,踩了一个小坑)
  配置yml,注意:如果只配置前两行端口号信息会报错
  server:   port: 8700 # 端口自己决定    # 指定当前eureka客户端的注册地址,也就是eureka服务的提供方,当前配置的服务的注册服务方 eureka:   client:     service-url:       defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka     register-with-eureka: false #自身 不在向eureka注册     fetch-registry: false  #启动时禁用client的注册   instance:     hostname: localhost   #指定应用名称 spring:   application:     name: eureka-server
  知识补充:
  开发springboot的入口类 EurekaServerApplication.java
  EurekaServerApplication.java  package com.yun;   import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;   @SpringBootApplication @EnableEurekaServer //当前使用eureka的server public class EurekaServerApplication {     public static void main(String[] args) {         SpringApplication.run(EurekaServerApplication.class,args);     } }
  右键运行当前类:
  运行成功console画面
  尝试进入eureka管理界面 端口号为 yml里配置的(端口号自己设置 需要大于公用和保留的端口号)1024~65535
  一般我喜欢设置为 8700到8800之间
  如下 管理界面已经可以登录了。
  2.3 客户端client 提供真正服务的角色的配置, 它提供服务 在 服务注册方server (注册中心)进行注册
  同样新建module,选择quickstart点击下一步
  两个位置 置空
  取名 下一步
  注意这里要在根目录springcloud 下创建模组,content root 会默认在之前的模组之下创建模组 这样创建模组会出现问题并报错
  推荐这种配置方法 在content root下springcloud后改名字 如下图配置点下一步,红框处一般默认为上一个模组的文件目录名,需要改为你的模组名
  成功后为并列状态,如不为并列或报错请重新配置
  配置servicesupport的pom,与server的pom配置相同,只需要把第一个pom的1的方框处server改为client
  和第一个微服务同理 我们需要配置入口类 pom.xml application.yml,因为是服务提供者,这里还需编写服务类controller
  application.yml  server:   port: 8701 # 服务提供方   # 指定当前eureka客户端的注册地址, eureka:   client:     service-url:       defaultZone: http://${eureka.instance.hostname}:8700/eureka   instance:     hostname: localhost   #当前服务名称 spring:   application:     name: eureka-service
  pom.xml:
  编写所提供的 服务controller:  package com.yun;   import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController;   @RestController @RequestMapping("/Hello") public class Controller {     @RequestMapping("/World")     public String helloWorld(String s){         System.out.println("传入的值为:"+s);         return "传入的值为:"+s;     } }
  入口类 并运行此微服务:  package com.yun;   import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.client.discovery.EnableDiscoveryClient;   @SpringBootApplication @EnableDiscoveryClient//代表自己是一个服务提供方 public class EurekaServiceApplication {     public static void main(String[] args) {         SpringApplication.run(EurekaServiceApplication.class,args);     } }
  右键入口类名点击 run(当然开启此服务时需要先开启server服务 就是我们第一个编写的微服务)
  此时再进入服务注册的页面 http://localhost:8700/
  可以看见服务提供者已被注册进 服务注册者
  在直接访问一下服务提供者的 网络位置http://localhost:8701/Hello/World?s=小沛
  我们已经看见 可以访问了,证明此微服务可用。
  但是我们一般不直接调用所需的微服务,而是经过提供注册服务的服务器server,获取所需的服务提供者列表(为一个列表,此列表包含了能提供相应服务的服务器),他们也许是个集群,因此server会返回一个 ip+端口号的表,服务消费者通过相应算法访问这表上的不同服务器,这些服务器提供的是相同的服务,这种在服务消费者一方挑选服务器为自己服务的方式是一种客户端的负载均衡。
  目前博主所知的有 轮询和随机两种方式 访问这些服务器,轮询就是循环的意思,假如有3台服务器,访问方式就是1,2,3,1,2,3,1,2,3····,随机就是随机,回想一下random方法,一种无规律的方式。这两种方式都是为了,访问每个服务器的可能性尽量的相同。还有权重负载这种算法,意思就是 根据服务器负载能力的分配相应的服务。能力大的干得多。能力小的干得少。  2.4 服务的调用方式
  第一种调用方式:restTemplate+ribbon
  第二种调用方式:feign
  2.4.1 restTemplate+ribbon
  ribbon是一种负载均衡的客户端,它是什么呢?请详读https://www.jianshu.com/p/1bd66db5dc46
  可以看见其中的一段如下:
  而客户端负载均衡和服务端负载均衡最大的不同点在于上面所提到服务清单所存储的位置。在客户端负载均衡中,所有客户端节点都维护着自己要访问的服务端清单,而这些服务端端清单来自于服务注册中心,比如上一章我们介绍的Eureka服务端。同服务端负载均衡的架构类似,在客户端负载均衡中也需要心跳去维护服务端清单的健康性,默认会创建针对各个服务治理框架的Ribbon自动化整合配置,比如Eureka中的org.springframework.cloud.netflix.ribbon.eureka.RibbonEurekaAutoConfiguration,Consul中的org.springframework.cloud.consul.discovery.RibbonConsulAutoConfiguration。在实际使用的时候,我们可以通过查看这两个类的实现,以找到它们的配置详情来帮助我们更好地使用它。
  接下来我们来搭建基于ribbon的客户端,他用于消费服务。
  同理先搭建springboot的环境
  与之前搭建servicesupport不同的是:
  第一步:现在pom中需要在dependencies中添加ribbon依赖                       org.springframework.cloud             spring-cloud-starter-ribbon         
  第二步:yml如下配置:  server:   port: 8702 # 服务消费方   # 指定当前eureka客户端的注册地址, eureka:   client:     service-url:       defaultZone: http://${eureka.instance.hostname}:8700/eureka   instance:     hostname: localhost   #当前服务名称 spring:   application:     name: eureka-consumer
  服务的消费方依旧需要在注册方8700端口去注册。配置当前服务消费方的端口8072,名字为eureka-consumer
  第三步:依旧需要启动类,因为它是一个springboot的架构:  package com.yun;   import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.client.discovery.EnableDiscoveryClient;     @SpringBootApplication @EnableDiscoveryClient //当前使用eureka的server public class EurekaConsumerApplication {     public static void main(String[] args) {         SpringApplication.run(EurekaConsumerApplication.class,args);     } }
  如上图:
  我们需要一个controller类来编写ribbon的代码。  package com.yun.controller;   import org.springframework.beans.factory.annotation.Autowired; import org.springframework.cloud.client.ServiceInstance; import org.springframework.cloud.client.loadbalancer.LoadBalancerClient; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.client.RestTemplate;   @RestController @RequestMapping("/Hello") class ConsumerController {     @Autowired     private LoadBalancerClient loadBalancerClient;     @Autowired     private RestTemplate restTemplate;     @RequestMapping("/Consumer")     public String helloWorld(String s){         System.out.println("传入的值为:"+s);         //第一种调用方式         //String forObject = new RestTemplate().getForObject("http://localhost:8071/Hello/World?s=" + s, String.class);           //第二种调用方式         //根据服务名 获取服务列表 根据算法选取某个服务 并访问某个服务的网络位置。         //ServiceInstance serviceInstance = loadBalancerClient.choose("EUREKA-SERVICE");         //String forObject = new RestTemplate().getForObject("http://"+serviceInstance.getHost()+":"+serviceInstance.getPort()+"/Hello/World?s="+s,String.class);           //第三种调用方式 需要restTemplate注入的方式         String forObject = restTemplate.getForObject("http://EUREKA-SERVICE/Hello/World?s=" + s, String.class);         return forObject;     } }
  我们常用第三种调用方式。
  第一种是直接调用:不经过注册中心那服务列表,直接访问的servicesupport
  第二种:是根据服务名选择调用,如上图需要做如下注入
  @Autowired
  private LoadBalancerClient loadBalancerClient;
  如上图代码中第二种调用方法的代码所示。
  用服务名去注册中心获取服务列表,当前客户端底层会做随机算法的选取获得服务并访问。
  第三种需要一个@Bean的注解自动注入并直接调用restTemplate对象调用服务。底层调用模式与第二种调用方式一样。如下:  package com.yun.beans;   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;   @Configuration public class Beans {     //管理简单对象     @Bean     @LoadBalanced     public RestTemplate getRestTemplate(){         return new RestTemplate();     } }
  @Bean注解告诉工厂,这个方法需要自动注入。
  @LoadBalanced,表示需要做负载匀衡。
  然后如controller中一样注入一下restTemplate,并且使用他,区别是可以直接使用服务名访问了
  String forObject = restTemplate.getForObject("http://EUREKA-SERVICE/Hello/World?s=" + s, String.class);
  开始测试:
  1.运行server的启动类:
  2.运行servicesupport的启动类:
  3.运行serviceconsume的启动类:
  浏览器访问:
  8072为服务消费方的端口
  访问方法解析:  访问服务消费方@RequestMapping指定的路径及消费方的端口来访问消费方的controller  controller根据服务名去server方获取获取服务列表,获取服务列表后根据随机的模式负载匀衡后去选择服务地址去访问servicesupport:如下图
  ---------- 更新于星期日2018年12月30日 20:02 待续....---------
  待续...  2.5 Eureka server的高可用配置
  点击下图配置
  接下来配置三台01,02,03的虚拟机参数
  01:8699
  02:8698
  03:8697
  之后点ok保存,可看见多出三个启动项
  接下来分别改注册端口号,defaultZone分别启动三个启动项
  打开server的yml配置,删掉前两行端口号配置(图中有错,请把instance 和hostname那两行删掉)
  配置好yml后点击启动
  同理,我们再次改动端口号为8699和8697后,把启动项改为02,之后启动(图中有错,请把instance 和hostname那两行删掉)
  同理把yml端口改为8699 和 8698后,把启动项改为03,之后启动(图中有错,请把instance 和hostname那两行删掉)
  启动后分别访问三个01,02,03端口,已经可以看见可以访问了。
  打开服务提供方的yml配置如下,把端口号改为三个中其中的一个。
  启动服务提供方之后,再次访问三个01,02,03我们会发现
  重点:即使服务提供方只注册了一个端口号8699,但是另外两个端口号,也能感知到服务提供方8701的存在了。如下图:
  接下来像服务消费方中添加服务注册者的端口号,这样在server挂掉任何一个的时候,都能有其他的server也能获取服务列表
  访问以下服务消费方,发现可以通过消费方调用server服务列表并且访问service了
  我么随便关闭其中两个server的副本,重启serviceconsume,再进行访问。必须重启serviceconsume才能清空缓存,清掉consume里面有的服务列表。
  上图发现即使关闭两台server后依旧可以访问,如下图,依旧从server中获取了服务列表,从中也能看见之后不用再获取服务列表了。
  但是当我们关掉所有server后。访问还是没问题,因为缓存了服务列表。
  但是让我们来重启一下serviceconsume,再访问就不行了。

咒术回战手游预约人数过十万官方允诺过60万送福利漫改手游咒术回战PhantomParade游戏预约人数目前已过10万。官方发推对玩家的支持表示感谢,并决定在预约人数达到60万时,将追加福利,送给每个预约的账号廻珠十连抽。咒术回战金铲铲之战S6拼多多卡牌2。0!强强联手后期新高度Hello,大家好,我是兔子,今天为大家补充一下卡牌2。0的新玩法,兔子在今天在高分段玩卡牌的时候发现后期有时候会输出效率匮乏,往往只能靠飞升来赢,过于依赖飞升,而且综合测试后,发蓝月传奇微端下载地址良心传奇蓝月传奇亮点说明嗨,各位玩家们大家好啊欢迎来到三圣乡生活圈,至尊王者页游蓝月传奇有哪些亮点呢,蓝月传奇亮点说明跟随小编一起来看看吧,希望能够给大家带来帮助哦!蓝月传奇页游是一款东方魔幻风格的即时战传奇3手游昔日传奇3,至今再续传奇缘哈喽!大家好啊!我是你们的尽言传奇!不知不觉传奇已经陪伴了我们几十载了!现在回想当年的那份热血与激情!回想十余年前在那个电脑都还未普及的年代,能在网吧玩传奇的人,绝对是走在潮流前端大话西游2盘点那些速度初值过1000的神兽首先当然是最快的年兽了,成长1。692,龙骨3块,满级4转255,技能绝境逢生春回大地化无鬼神莫测倍道兼行如人饮水终极闪现子虚乌有潮鸣电掣,最高速度可以到6200,超越18星的存在阴阳师极速上名仕阵容分享,从25253000仅需19场作者NGA伊人如梦公布答案老阵容,炸盾,中午1小时15分钟,小号从2525到3000,19场,16胜,3负。老生常谈打得好不如排得好,现阶段会打炸盾的都上去了,不会打的还在鱼塘挣扎不把孩子的自尊当回事,再多的教育方法都是无用的所有难教育的孩子,都是失去自尊心的孩子。教育者就是要千方百计地保护孩子最宝贵的东西自尊心。作者多米(富书作者)太气愤了!前阵子,一则四川老师怒扇女学生的新闻冲上热搜。视频中,老师把宗馥莉王力宏前妻深夜爆料,娃哈哈少掌门才是人间清醒啊作者山佳12月17日深夜,歌手王力宏的前妻李靓蕾爆料,王力宏婚内曾有不轨的大量事实。就此,有着王力宏往昔温润如玉谦和有礼内敛温柔的人设,就地倒下。许多代言,都在吃瓜的第一时间,声明文案I如果一直想见谁迟早肯定见得到淡蓝色气泡的天空与浅粉色交汇的你也许只有你明白,我最想要的也只是Justyouandme第一次听到keshi的声音,便觉得好听的一塌糊涂,只听到便怦然心动。仿佛置身于落雨后的黄昏,跨年文案我又陪你一年啦文沐时光之书1有人见尘埃,有人见星辰,没关系,都要翻篇了。2所爱如山海,烟火伴长明。3既要今朝醉,也要万年长。4岁末将至,敬颂冬绥,2022,万事胜意。5希望2022年是很愉快的一特别暖心的平安夜文案1。如果快乐太难,那我祝你平安2。喜欢固定的位置不变的朋友,愿在等新年烟火和更好的我们岁岁平安!3。平安夜报平安过了今天是圣诞4。平安夜吃一个苹果听一首歌看一部跨过寒冬拥抱你的电影
无霜储鲜更省心,风冷冰箱显身手对于小户型家庭来说,厨房面积一般都不会很大。因此在选择冰箱时,不妨选择一款纤薄机身的冰箱。它采用纤薄的机身设计,不仅占用空间小而且容量也更大。同时其搭载了风冷无霜技术,制冷迅速且均不爱做广告的容声冰箱,到底有多牛?容声冰箱,这个不爱做广告,却依然占据了很大国内冰箱市场份额的冰箱,在我国冰箱市场位列前五。1984年,容声就研发出中国第一台双门双温电冰箱。容声冰箱平时也很少做营销广告,主要还是靠伏天出汗多,茄子土豆靠边站!多吃这种菜,钾含量极高,安稳度夏伏天出汗多,茄子土豆靠边站!多吃这种菜,钾含量极高,安稳度夏不知道大家是否感觉到,今年的夏天似乎比往年更热一些,反正我们这里是这样,每年最高就30度,而且也没几天,今年已经连续好长篮网2换5交易?再见杜欧!湖人忍痛割爱,浓眉成牺牲品就在今天,据美记SeanDeveney报道,联盟多位西部的高管表示,湖人管理层目前想要衡量浓眉哥的交易价值。而他们做出这样的决定无疑有两点,首先詹姆斯迟迟未能和球队续约,其次,威少车轮滚滚向前三大老将或同时退役04届即将退出NBA舞台长江后浪推前浪,NBA更新换代可以说是必然的事,在03届仅剩下詹姆斯安东尼两人的情况下,04届的成员,很有可能会在新赛季开始全部退出NBA舞台,虽然球迷可能会非常不舍,但也确实要接阿拉德之怒最新版本无限点券新三职业已经加入阿拉德之怒横版格斗手游已经更新到95版本了,游戏中所有装备已经全部更新,80级以上装备可以通过深渊掉落了,相对比较老版本阿拉德之怒本次更新了限时活动堕落深渊九层要塔等玩法,80级以纳斯利亚堡新版本玩啥卡组?快来看看职业选手的构筑吧炉石传说的最新扩展包纳斯利亚堡的悬案,已经上线正式服一天了,目前标准模式的天梯环境仍未稳定下来,大家积极在尝试各种卡组。从首日的天梯环境来看,新体系没有完全撼动环境,但新卡确实补强国服前十云顶王者组最强6大阵容,S7终于迎来最平衡版本版本更新之后看一看国服前10什么阵容能上分是最重要的版本第一阵容幽秘斗炮毫无疑问外服的换形秘炮果然是扯淡的阵容虽然强势但是又不像之前的索尔敖兴那么的无解直到这个版本设计师终于完成了神印王座为何不能安排龙皓晨兼修魔法师?神印王座最新一集龙皓晨和六阶的魔法师林佳璐打了一场友谊赛,也让我们看到了魔法师的强大,如果不是强开主角光环,林佳璐必定完胜,而这种魔法攻击很像斗罗大陆中的魂技,甚至连名字都类似,冰英雄联盟未来会停止更新英雄,无尽的新英雄会增加入坑成本作者NGA浅川灬(如果有一天,英雄联盟不再更新英雄,那会是怎样的情况?截止于新英雄尼菈,英雄联盟中已经有161个英雄,这是一个非常庞大的数字。自从2009年正式上线以来,英雄列表的炉石传说标准热度最低的5张新橙卡,4张却在狂野表现突出Hello,我是马小跳。炉石传说新版本纳斯利亚堡的悬案已经正式上线了,虽说新环境首日的情况并不能完全代表卡牌的真实强度,现实情况也确实证明了这一点,但了解新橙卡的使用情况,至少可以