这将是SpringBoot学习系列的最后一篇文章,主要涉及Spring Cloud和JHispter两个知识点,都具有一定综合性,需要多加实践加强理解。
Spring Cloud
微服务Microservice是今年最火的观念,它的含义是使用定义好边界的小的独立组件来做好一件事情,微服务是相对与传统单块式架构而言的。传统系统易于部署,但可伸缩性差,违反单一功能原则。Spring Cloud提供了分布式开发的完整解决方案,其基于Spring boot,提供了配置管理、服务发现、断路器、代理服务等常见功能。此外,Cloud开发的应用特别适合在Docker或Paas平台,被称为原生云应用。
配置服务:提供了Config Server,它在分布式系统中起到外部配置的功能,通过配置服务,可以集中存储所有应用的配置文件。(QConfig,Apollo)
服务发现:通过Netflix OSS的Eureka来实现服务发现,Eureka Server为微服务注册中心。(SOA服务治理中心,自动发现,Zookeeper)
路由网关:为了让所有微服务对外只有一个接口,不同请求被网关代理到不同服务。通过Zuul实现,支持自动路由映射到Eureka Server上注册的服务,提供@EnableZuulProxy
启动路由代理。
负载均衡:提供Ribbon和Feign作为客户端负载均衡,比如使用Ribbon直接注入一个RestTemplate对象,此RestTemplate已经做好负载均衡的工作;使用Feign只需要定义一个注解,有@FeignClient
注解的接口,然后使用@RequestMapping
注解在方法上映射远程的REST服务,此方法也已做好负载均衡。
断路器(Circuit Breaker):解决当某个方法调用失败的时候,调用后备方法来替代失败的方法,来达到容错,阻止级联错误的功能(关键服务的服务降级,避免服务不可用)。此外,框架提供一个控制台来监控断路器的运行情况,通过@EnableHystrixDashboard
注解开启。(问题,能否提供类似CAT的监控功能,可以查看接口调用的频次,响应时的时间等)
Tip:
GitDemo: https://github.com/wanliwang/bluesky
在构建项目时,比较复杂的就是web部分,会用到ribbon,feign,zuul,circuitbreaker等,通过会使用webjar加载脚本框架。
基于Docker的部署
Dockerfile编写,以config模块为例
- runboot.sh脚本编写,位于src/main/docker,根据启动顺序,调整sleep时间
- Dockerfile编写,位于src/main/docker
- 配置Docker的maven插件,请见config子模块
- 编译镜像,默认编译到localhost,可以在windows环境变量中配置DOCKER_HOST,并执行
mvn clean package docker:build -DskipTests
Tip:
此外还可以使用DockerCompose来定义和运行多容器应用,其使用一个docker-compose.yml来描述多容器的定义,使用docker-compose up -d
运行整个应用。
JHipster
JHipster是一个代码生成器(基于nodejs+yeoman),可以生成基于Spring Boot和AngularJS的项目,通常来说,需要按照如下步骤进行安装。安装后,可以发现代码结构和配置比较复杂,一定要用心慢慢分析。
- 安装nodejs
- 安装Git
- 安装Yeoman generator: npm install –g yo (可能需要先升级npm,npm –g install npm)
- 安装JHipster: npm install –g generator-jhipster
- 安装bower: npm install –g bower, js下载工具
- 安装grunt或gulp: npm install –g grunt-cli, js打包工具
- 生成项目,选择dir,yo jhipster
- 运行,mvn spring-boot :run,然后访问8080即可,admin:admin
Tip:
前端常见的js构建工具包括grunt, gulp和webpack。当前前端代码越来复杂,维护、打包和发布越来越繁琐,这些工具就是针对这些痛点而生的。
grunt: http://www.gruntjs.net/, http://www.gruntjs.net/getting-started
gulpjs: http://www.gulpjs.com.cn/
webpack: http://webpackdoc.com/
bower的基本使用:bower install jquery underscore,下载到当前
详情参考博文:http://www.jianshu.com/p/621dfb94c3b6
npm安装程序时的默认位置: npm config set prefix E:
odejs
ode_modules
pm
npm安装程序时的缓存位置: npm config set cache xxx
此外,该项目还依赖git和yarn,yarn是hadoop资源管理器。
参考资料
- 李智慧. 大型网站技术架构[M]. 北京:电子工业出版社, 2013.