生活工程体验信仰哲学精神
投稿投诉
精神世界
探索历史
哲学文学
艺术价值
信仰创造
境界审美
体验技术
技能工具
工程信息
医学生产
生活运用
操作能力

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

3月15日 飞虹塔投稿
  一、微服务基础1。什么是SpringCloud?
  SpringCloud官网:https:spring。ioprojectsspringcloud(个人建议是用谷歌浏览器访问官网打开中文翻译粗略把官网读一遍)
  个人理解:
  以前的服务器就好像,一个会语数外全能的老师,为学生提供服务,这个老师生病了,那全校停课。现在微服务流行后,学校有了数学教研组,语文教研组,外语教研组,每个教研组有一群老师具体负责某科的教学,缺了谁,学校都照样运转。
  而这个变化中,那些改变历史的程序员就是把一个服务器中的众多服务,或好几台服务器中的众多服务,分类出来,解耦合出来,把他们类似的功能交给同一个集群来做,把互相耦合在一起的功能剥离出来,按业务,按功能来把他们作为一个个微服务放在服务器上,而这个服务器就只提供一个服务,或较少的服务。让一个超大的服务逻辑,解耦合为一个个小服务,均匀的分布在各自的服务器中。微服务就微在这。
  每个教研组就是一个微服务集群。他们提供同样的服务,而注册中心Eureka就是这个存放这个教研组老师名单的地方,学生们想先访问这个注册中心获取教师名单,然后根据相应的负载方法去访问各自老师。不至于让集群中某一老师累死也不至于让某一老师闲死。
  而Zuul网关呢,就是学校的门卫,某些学生来学校找谁,它负责指引(路由),并且通过一些非常简单的配置,达到阻拦一些人进入(身份验证),或者控制想学数学的人只能去数学教研组,不能去核能教研组学怎么造原子弹(权限验证)。
  那Hystrix熔断器呢,可以把它当成学校的志愿者,当一个教研组集体罢课后,学生找不到老师了,这些志愿者及时的告诉来访问的学生,相应的结果,异常信息等,免得大量的学生在学校等待,这些志愿者赶快把这些等待的学生梳理出去,学生一直在学校等待,那其他需要学生的学校,也会等待学生,最后造成大面积的学校瘫痪。这里学生我们看成一个个请求。熔断器就是把某事故的蔓延即使熔断了。
  当然这些组件也是微服务需要注册到Eureka注册中心
  那SpringCloud就可以看成是这个学校了。众多上面提到的组件相当于都是这个学校的各职能部门。二、微服务的搭建
  ps:博主基于Mavenidea搭建。
  另外SpringCloud需要基于springboot搭建。
  引入SpringBoot相关依赖:这里的springboot用的是1。5。7版本;引入SpringCloud相关依赖:这里为Edgware。SR52。1工程初始化配置
  在Idea中创建工程:FileNewProject
  点击EmptyProjectNext
  项目命名项目位置
  选择模组modulesnext
  进入新的窗口后,开始配置Maven,打开设置setting
  因为我之前做过配置,因此只需要改变框1的路径,如第一次配置需要自己找到你maven放置的位置,以及settings。xml,repository的位置,实在不会的百度maven集成idea
  3个框选择完毕后点击ok
  接下来新建module
  这里可能会出现加载不出archetypelist的问题
  用了网上的所有解决办法花了3个小时解决都没用,重启之后竟然可以了你敢信?????小时候网吧网管的至理名言都忘了!!重启一下嘛!!
  出来之后选择quickstart下一步
  名字自己想想好后,复制一下你想好的ArtifactId点击Next,groupId为组织名也是自己想一个,一般为公司网址反写。
  粘贴后下一步
  提供注册服务的服务器pom。xml配置如下:?xmlversion1。0encodingUTF8?projectxmlnshttp:maven。apache。orgPOM4。0。0xmlns:xsihttp:www。w3。org2001XMLSchemainstancexsi:schemaLocationhttp:maven。apache。orgPOM4。0。0http:maven。apache。orgxsdmaven4。0。0。xsdmodelVersion4。0。0modelVersiongroupIdcom。yungroupIdspringcloudeurekaserverartifactIdversion1。0SNAPSHOTversionnamespringcloudeurekaservername!FIXMEchangeittotheprojectswebsiteurlhttp:www。example。comurlpropertiesproject。build。sourceEncodingUTF8project。build。sourceEncodingmaven。compiler。source1。7maven。compiler。sourcemaven。compiler。target1。7maven。compiler。targetproperties!引入springbootparent父项目parentgroupIdorg。springframework。bootgroupIdspringbootstarterparentartifactIdversion1。5。7。RELEASEversionparentdependencies!引入springcloud的euekeaserver依赖dependencygroupIdorg。springframework。cloudgroupIdspringcloudstarternetflixeurekaserverartifactIddependencydependencies!指定下载源和使用springcloud的版本dependencyManagementdependenciesdependencygroupIdorg。springframework。cloudgroupIdspringclouddependenciesartifactIdversionEdgware。SR5versiontypepomtypescopeimportscopedependencydependenciesdependencyManagementproject
  点击ImportChanges
  等待右下角加载springcloud的依赖
  2。2Springboot的搭建以及提供注册服务的服务配置
  创建resources文件夹
  并设置作为资源根目录,之后文件变成这样
  之后文件夹变成有黄色的横杠
  在resources下新建文件,文件名为application。yml(对是yml不是xml,博主第一次学习时,还以为是其他博主打错了,踩了一个小坑)
  配置yml,注意:如果只配置前两行端口号信息会报错
  server:port:8700端口自己决定指定当前eureka客户端的注册地址,也就是eureka服务的提供方,当前配置的服务的注册服务方eureka:client:serviceurl:defaultZone:http:{eureka。instance。hostname}:{server。port}eurekaregisterwitheureka:false自身不在向eureka注册fetchregistry:false启动时禁用client的注册instance:hostname:localhost指定应用名称spring:application:name:eurekaserver
  知识补充:
  开发springboot的入口类EurekaServerApplication。java
  EurekaServerApplication。javapackagecom。importorg。springframework。boot。SpringAimportorg。springframework。boot。autoconfigure。SpringBootAimportorg。springframework。cloud。netflix。eureka。server。EnableEurekaSSpringBootApplicationEnableEurekaServer当前使用eureka的serverpublicclassEurekaServerApplication{publicstaticvoidmain(String〔〕args){SpringApplication。run(EurekaServerApplication。class,args);}}
  右键运行当前类:
  运行成功console画面
  尝试进入eureka管理界面端口号为yml里配置的(端口号自己设置需要大于公用和保留的端口号)102465535
  一般我喜欢设置为8700到8800之间
  如下管理界面已经可以登录了。
  2。3客户端client提供真正服务的角色的配置,它提供服务在服务注册方server(注册中心)进行注册
  同样新建module,选择quickstart点击下一步
  两个位置置空
  取名下一步
  注意这里要在根目录springcloud下创建模组,contentroot会默认在之前的模组之下创建模组这样创建模组会出现问题并报错
  推荐这种配置方法在contentroot下springcloud后改名字如下图配置点下一步,红框处一般默认为上一个模组的文件目录名,需要改为你的模组名
  成功后为并列状态,如不为并列或报错请重新配置
  配置servicesupport的pom,与server的pom配置相同,只需要把第一个pom的1的方框处server改为client
  和第一个微服务同理我们需要配置入口类pom。xmlapplication。yml,因为是服务提供者,这里还需编写服务类controller
  application。ymlserver:port:8701服务提供方指定当前eureka客户端的注册地址,eureka:client:serviceurl:defaultZone:http:{eureka。instance。hostname}:8700eurekainstance:hostname:localhost当前服务名称spring:application:name:eurekaservice
  pom。xml:
  编写所提供的服务controller:packagecom。importorg。springframework。web。bind。annotation。RequestMimportorg。springframework。web。bind。annotation。RestCRestControllerRequestMapping(Hello)publicclassController{RequestMapping(World)publicStringhelloWorld(Strings){System。out。println(传入的值为:s);return传入的值为:s;}}
  入口类并运行此微服务:packagecom。importorg。springframework。boot。SpringAimportorg。springframework。boot。autoconfigure。SpringBootAimportorg。springframework。cloud。client。discovery。EnableDiscoveryCSpringBootApplicationEnableDiscoveryClient代表自己是一个服务提供方publicclassEurekaServiceApplication{publicstaticvoidmain(String〔〕args){SpringApplication。run(EurekaServiceApplication。class,args);}}
  右键入口类名点击run(当然开启此服务时需要先开启server服务就是我们第一个编写的微服务)
  此时再进入服务注册的页面http:localhost:8700
  可以看见服务提供者已被注册进服务注册者
  在直接访问一下服务提供者的网络位置http:localhost:8701HelloWorld?s小沛
  我们已经看见可以访问了,证明此微服务可用。
  但是我们一般不直接调用所需的微服务,而是经过提供注册服务的服务器server,获取所需的服务提供者列表(为一个列表,此列表包含了能提供相应服务的服务器),他们也许是个集群,因此server会返回一个ip端口号的表,服务消费者通过相应算法访问这表上的不同服务器,这些服务器提供的是相同的服务,这种在服务消费者一方挑选服务器为自己服务的方式是一种客户端的负载均衡。
  目前博主所知的有轮询和随机两种方式访问这些服务器,轮询就是循环的意思,假如有3台服务器,访问方式就是1,2,3,1,2,3,1,2,3,随机就是随机,回想一下random方法,一种无规律的方式。这两种方式都是为了,访问每个服务器的可能性尽量的相同。还有权重负载这种算法,意思就是根据服务器负载能力的分配相应的服务。能力大的干得多。能力小的干得少。2。4服务的调用方式
  第一种调用方式:restTemplateribbon
  第二种调用方式:feign
  2。4。1restTemplateribbon
  ribbon是一种负载均衡的客户端,它是什么呢?请详读https:www。jianshu。comp1bd66db5dc46
  可以看见其中的一段如下:
  而客户端负载均衡和服务端负载均衡最大的不同点在于上面所提到服务清单所存储的位置。在客户端负载均衡中,所有客户端节点都维护着自己要访问的服务端清单,而这些服务端端清单来自于服务注册中心,比如上一章我们介绍的Eureka服务端。同服务端负载均衡的架构类似,在客户端负载均衡中也需要心跳去维护服务端清单的健康性,默认会创建针对各个服务治理框架的Ribbon自动化整合配置,比如Eureka中的org。springframework。cloud。netflix。ribbon。eureka。RibbonEurekaAutoConfiguration,Consul中的org。springframework。cloud。consul。discovery。RibbonConsulAutoConfiguration。在实际使用的时候,我们可以通过查看这两个类的实现,以找到它们的配置详情来帮助我们更好地使用它。
  接下来我们来搭建基于ribbon的客户端,他用于消费服务。
  同理先搭建springboot的环境
  与之前搭建servicesupport不同的是:
  第一步:现在pom中需要在dependencies中添加ribbon依赖dependencygroupIdorg。springframework。cloudgroupIdspringcloudstarterribbonartifactIddependency
  第二步:yml如下配置:server:port:8702服务消费方指定当前eureka客户端的注册地址,eureka:client:serviceurl:defaultZone:http:{eureka。instance。hostname}:8700eurekainstance:hostname:localhost当前服务名称spring:application:name:eurekaconsumer
  服务的消费方依旧需要在注册方8700端口去注册。配置当前服务消费方的端口8072,名字为eurekaconsumer
  第三步:依旧需要启动类,因为它是一个springboot的架构:packagecom。importorg。springframework。boot。SpringAimportorg。springframework。boot。autoconfigure。SpringBootAimportorg。springframework。cloud。client。discovery。EnableDiscoveryCSpringBootApplicationEnableDiscoveryClient当前使用eureka的serverpublicclassEurekaConsumerApplication{publicstaticvoidmain(String〔〕args){SpringApplication。run(EurekaConsumerApplication。class,args);}}
  如上图:
  我们需要一个controller类来编写ribbon的代码。packagecom。yun。importorg。springframework。beans。factory。annotation。Aimportorg。springframework。cloud。client。ServiceIimportorg。springframework。cloud。client。loadbalancer。LoadBalancerCimportorg。springframework。web。bind。annotation。RequestMimportorg。springframework。web。bind。annotation。RestCimportorg。springframework。web。client。RestTRestControllerRequestMapping(Hello)classConsumerController{AutowiredprivateLoadBalancerClientloadBalancerCAutowiredprivateRestTemplaterestTRequestMapping(Consumer)publicStringhelloWorld(Strings){System。out。println(传入的值为:s);第一种调用方式StringforObjectnewRestTemplate()。getForObject(http:localhost:8071HelloWorld?ss,String。class);第二种调用方式根据服务名获取服务列表根据算法选取某个服务并访问某个服务的网络位置。ServiceInstanceserviceInstanceloadBalancerClient。choose(EUREKASERVICE);StringforObjectnewRestTemplate()。getForObject(http:serviceInstance。getHost():serviceInstance。getPort()HelloWorld?ss,String。class);第三种调用方式需要restTemplate注入的方式StringforObjectrestTemplate。getForObject(http:EUREKASERVICEHelloWorld?ss,String。class);returnforO}}
  我们常用第三种调用方式。
  第一种是直接调用:不经过注册中心那服务列表,直接访问的servicesupport
  第二种:是根据服务名选择调用,如上图需要做如下注入
  Autowired
  privateLoadBalancerClientloadBalancerC
  如上图代码中第二种调用方法的代码所示。
  用服务名去注册中心获取服务列表,当前客户端底层会做随机算法的选取获得服务并访问。
  第三种需要一个Bean的注解自动注入并直接调用restTemplate对象调用服务。底层调用模式与第二种调用方式一样。如下:packagecom。yun。importorg。springframework。cloud。client。loadbalancer。LoadBimportorg。springframework。context。annotation。Bimportorg。springframework。context。annotation。Cimportorg。springframework。web。client。RestTConfigurationpublicclassBeans{管理简单对象BeanLoadBalancedpublicRestTemplategetRestTemplate(){returnnewRestTemplate();}}
  Bean注解告诉工厂,这个方法需要自动注入。
  LoadBalanced,表示需要做负载匀衡。
  然后如controller中一样注入一下restTemplate,并且使用他,区别是可以直接使用服务名访问了
  StringforObjectrestTemplate。getForObject(http:EUREKASERVICEHelloWorld?ss,String。class);
  开始测试:
  1。运行server的启动类:
  2。运行servicesupport的启动类:
  3。运行serviceconsume的启动类:
  浏览器访问:
  8072为服务消费方的端口
  访问方法解析:访问服务消费方RequestMapping指定的路径及消费方的端口来访问消费方的controllercontroller根据服务名去server方获取获取服务列表,获取服务列表后根据随机的模式负载匀衡后去选择服务地址去访问servicesupport:如下图
  更新于星期日2018年12月30日20:02待续。。。。
  待续。。。2。5Eurekaserver的高可用配置
  点击下图配置
  接下来配置三台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,再访问就不行了。
投诉 评论

超223亿元!莱西77个重大项目集中开工不负好春光,项目开工忙。2月17日上午,随着一声令下,莱西市总投资超223亿元的77个重大项目集中开工,吹响攻坚克难年加快项目建设的冲锋号。该市上下只争朝夕、铆劲赶超,以干实、……你要知道2023年秋冬季巴黎时装周6大看点!自每年一月起,各大时装周于各地举行,而重头戏巴黎时装周将于2月底举行。除了经典品牌的时装展外,为大家精选了6场绝不能错过的时装展!1NinaRicciNinaRic……中年女人的元宵节元宵节那天坐公交车逛了大半个郑州。其实前几天就一直想去人民公园了,有一天下午和朋友商量要不要一起去逛公园,他说行,还以为是去西流湖。西流湖逛过八百遍了,再去实在提不……窥探海洋的未来古代海洋ampampquot死区ampampq科学家们绘制了上新世时代的海洋死亡区地图,当时地球的温度比今天高2摄氏度到3摄氏度。这可以为未来地球上更温暖的海洋中的低氧区的位置和影响提供启示。OMZ(氧气最小区)是海洋中的……养生知识健康对于每一个人来说都是非常重要的,但是随着年龄的增长,人体各个机能在慢慢下降,身体的很多疾病也就随之而来,近些年来,大家的养生意识是越来越高,如果我们平时学会一些养生的只是,……汽车芯片供应短缺?大众丰田仍是如此最新数据显示,尽管全球芯片短缺状况正在缓慢改善,但一些汽车制造商受到短缺的影响要比其他汽车制造商严重得多。本田汽车本月告诉股东,半导体芯片短缺正在见底,但该公司仍下调了对……马斯克没解决的难题,这家独角兽先跑通!或成为人形机器人第一股编辑:Aeneas好困【新智元导读】8年深耕,OpenAI做出让全世界瞩目的ChatGPT;而优必选在人形机器人领域已经深耕十几年,它的入局,彻底改写了中国人形机器人的历史。……竞拍第四日K912加入战场!竞拍活动第4天!各位《坦克世界》的玩家们大家好,竞拍活动今天已经进行到第4天了,不知各位收获如何?这些拍品都拥有独特的玩法和很高的收藏价值。您可以通过点击车库右下方的活动……国奥队正式集结成耀东机遇与挑战并存京报体育记者李立2月7日,新一届国奥队(U22男足)在上海正式集结。新的奥运会备战周期正式开启,主帅成耀东表示,对于球队说,是机遇与挑战同在。球队的起步有点难……人不成器的征兆人到四十,还喜欢做这3件事,很难有出息人活在世,日复一日,年复一年,时光一去不复返,但每个年纪都有每个年纪的成长与收获。孔子曾曰:吾十有五而志于学,三十而立,四十不惑,五十知天命,六十耳顺,七十从心所欲不逾矩……从零开始搭建公司SpringCloud架构技术栈,这套架构绝一、微服务基础1。什么是SpringCloud?SpringCloud官网:https:spring。ioprojectsspringcloud(个人建议是用谷歌浏览器访……每天过的快乐,有三大秘诀要想每天过的快乐,有三大秘诀有事干,有钱花,有人爱1。有事干有一件你热爱的事情,心甘情愿为之付出,会激发起来你巨大的创造力,生命力和激情。2。有钱花……
冬日计划一款狼人杀主题的多人游戏,你玩过吗?退赛还是迎来转机?武汉长江不认可足协仲裁,金额庞大约千万如何准确分辨泰国特殊的人?知道这三个特征女性膝盖痛关节早期僵硬微信重大更新!网友这个好,很实用x86处理器市场变天Intel份额首次跌破7成趁着天气晴好走走东部华侨城群山在火车站拉客的大妈,推荐的住宿地一晚才40元,是有何内幕?山东四胞胎冰清玉洁,12岁离家求学,一同考上大学住一间宿舍王曼昱世界第一来之不易,巴黎资格竞争激烈,孙颖莎产生掉队危机发展进入新阶段,江特电机提锂技术领先,加快推进矿山ampam郭明錤爆料!又一中国企业打入苹果iPhone14供应链赵明确CBA中职篮各家俱乐部的主教练都已经基本落地只有福建还在犹豫孩子犯错要不要打孩子?如果不打孩子,有没有更好的办法解决问题再见,是为了告别,还是为了下一次约定?醉驾与危害公共安全能不能并罪?怎样去掉老年斑(怎样才能去掉老年斑)她和他的故事展讯丨造化为师伍海成中国画作品展如何学点心理学?对于非专业人学心理学的一点建议德罗赞洛瑞欲降薪加盟湖人,以前被老詹支配,现在想受宠浅析检察环节非法证据排除的要素解读A股散户不能玩腊八来我家作文

友情链接:中准网聚热点快百科快传网快生活快软网快好知文好找