新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
前言
公司主营业务:成都网站设计、网站建设、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联推出青岛免费做网站回馈大家。现在越来越多的公司开始拥抱Spring Cloud了,Spring Boot做为下一代 web 框架,Spring Cloud 作为最新最火的微服务的翘楚,你还有什么理由拒绝。很多Java方向的同学也开始积极的学习Spring Cloud,其实这边还有一个问题就是说:虽然大家学了Eureka,Ribbon,Hystrix,Zuul,Feign等等,但是要运用到实际的项目中去还是有些难度的。
微服务难就难在服务的拆分上,框架只是工具,很多人都会用,服务拆分,服务之间的关系这些都是在拆分时候需要考虑的事情。
今天就有一位同学给我发邮件,咨询我下面2个问题:
下面以我自己的经验来做一些解答,仅供参考:
关于第一个问题中的API是各个微服务下的Controller?
我们所说的API其实就是一个接口,大部分都是用Spring MVC方式去开发的,也就是Controller中的一个加了注解的方法,注解就是我们常用的那几个:
关于第一个问题中的是否需要统一的一个工程,在里面封装其他微服务的controller?
这种其实也没有固定的模式,大部分是直接通过API网关转发到你的业务服务上
以猿天地这样的博客网站的业务类举例:
有一个业务功能,当我查看具体的博客文章的时候,需要返回的信息如下:
这个时候我们这个查看文章的接口其实就涉及到了3部分的数据,文章本身的信息,评论信息,作者的信息
就是有3个服务,用户服务,博客服务,评论服务
那么问题来了,涉及到多个服务之前的交互,其实跟上面那位同学问我的是一样的问题,是否需要统一工程,组装其他服务?是否可以相互调用?
这种的话我推荐2种实现方式:
一. API网关直接转发到博客服务中
我们这个API就是一个获取博文信息的接口,主体肯定是博客服务,在博客服务中有一个博文信息的接口,在接口中去调用用户服务提供的用户信息接口,还要去调用评论服务中博文的评论信息,下面看伪代码:
@GetMapping("/blog/detail/{id}") public BlogInfo blogInfo(@PathVariable("id") Long id) { // 获取博客信息 Blog blog = blogService.getById(id); // 获取用户信息 UserInfo userInfo = userFeignClient.getUserInfo(blog.getUserId()); // 获取评论信息 CommentInfo commentInfo = commentFeignClient.getCommentInfo(id); return 组装所有信息返回。 }