nodejs框架Koa做中间层使用总结(含示例)

1. Koa是什么?

一个以nodejs为基础的一个后台框架。直白一点来说,就是一个javascript语言需要编写的库,它的定位是作为服务端应用提供服务,本身对外暴露了一些api,同时也融合了比较好的思想进去。

2. Koa的出现

首先我理解koa的出现绝对不是为了取代现在已有的一些老牌后台语言框架,因为nodejs本身的一些短板和庞大而又历史悠久老牌后台语言,取代是不现实的,只能说各有所长,相互补短,协同提供服务才是正确的。

3. 真实的项目背景

最近正好公司有一个新项目启动,我也正好借此总结一下。首先公司的底层服务与人员配置均是java标准来分配的,应用本身也是涉及到支付等对可靠性安全性等较高标准的,但是后端的架构是以微服务的方式对外提供服务。

这时候面临了一个问题,像首页这类信息量大的页面,所要展示数据比较分散,需要多个服务一起提供接口,便导致了前端一个页面涉及到多个http请求,因为后端在微服务化下,没有一个合适的服务去承接聚合数据的功能,而对前端来说,很多个http请求的开销下造成的用户体验问题是不能忽视的,这时候就需要一个聚合业务层来承接。

这一层的目的也很明确,就是处理底层数据给前端层面,但是这就涉及到了谁来做这一层的问题,当然任何一个可提供服务的后端框架都是可以做这一层的,而对于有底层服务提供的同学再来关注这一层是没有太多营养的,这时候前端同学便可以利用自己本身的javascript技能功底,使用nodejs的后端框架来承接这一层,就比如上面所说的koa框架便非常合适。

但是也有一个问题,因为项目所需要的可靠性较高,而javascript本身弱语言类型再加上nodejs单进程本身比较脆弱,所以我们将nodejs所提供的中间层定位为只将查询类接口由此封装,而涉及的提交等操作类接口还是走原来底层业务系统来提供服务,这样便将本身的底层服务与新增的聚合层服务完美结合到一起,相互协作提供服务。

以下是一个简单的架构图,可供参考:

4. Koa中间层的好处

1. 语言优势:Koa是基于javascript的开发,这是比较大的一个好处,因为能够让前端们更轻松的上手。

2. 提效:方便自己页面调整数据时能够独立的完成调整,而不是跨团队效率底下的沟通工作。

3. 聚合:后端微服务体系势必存在多个数据提供者的问题,如果多次http请求,用户体验有可能变差,所以聚合业务数据也是很重要的作用。

4. 拓宽技术视野:一般前端工程师都是不能非常好的了解技术架构和业务模型,加入这一层后,前端们从页面层到接口层,可以站到更高的位置去看自己做的事情,如数据的一些流转链路方式等,还可以拓宽自己的技术,逐步变成一个技术全能选手。

5. Koa的技术模型

Koa相对于比较老牌的nodejs框架express非常明显的优点是它的"洋葱圈"模型,因为它内部利用了ES6的generate生成器函数,Koa2的版本中直接使用ES7的async语法,这样便能够更好的处理异步写法,告别难看的回调地狱。另一个就是它强大的插件式中间件能力,非常好的扩展能力,可以定制的请求处理模块,而且社区也有很多贡献的中间件模块,可提供使用。

6. Koa入门示例

下面实现一个简单使用Koa搭建服务的例子?

① 实现目标:

  • 提供http和https的服务
  • 实现查询第三方接口服务并提供json接口给前端
nvm install 8  //8以上可以使用最新语法
nvm use 8
npm i --save koa

② 目录结构:

③ 实现代码:

const http = require('http');
const https = require('https');
const Koa = require('koa');
const fs = require('fs');
const axios = require('axios');

const app = new Koa();

app.use(async (ctx, next) => {
  const now = Date.now();
  await next();
  console.log('path: %s cost time is ', ctx.path, Date.now() - now);
});
app.use(async ctx => {
  const ipInfo = await axios.get('http://ip.taobao.com/service/getIpInfo.php?ip=0.0.0.0');
  ctx.body = ipInfo.data;
});

http.createServer(app.callback()).listen(3000, ()=>{
  console.log('http server start!')
});

let options = {
  key: fs.readFileSync(__dirname+'/ssl/server.key'),
  cert: fs.readFileSync(__dirname+'/ssl/server.crt')
};
https.createServer(options, app.callback()).listen(443, ()=>{
  console.log('https server start!')
});

备注:上面的server.key和server.crt都是为了测试使用,大家需要去申请腾讯云或阿里云申请可用证书使用。

④ 测试示例:

http服务:

https服务:(没有有效证书情况下,需在浏览器勾选忽略安全问题)

有兴趣的同学强烈建议把代码拷贝到本地后自己调试观察。有需要同学可以在这里看以前写的一个koa的使用demo:https://github.com/FantasyGao/koa2。

如上内容均为自己总结,难免会有错误或者认识偏差,如有问题,希望大家留言指正,以免误人,若有什么问题请留言,会尽力回答之。如果对你有帮助不要忘了分享给你的朋友或者点击右下方的“在看”哦!也可以关注作者,查看历史文章并且关注最新动态,助你早日成为一名全栈工程师!

本文分享自微信公众号 - 全栈者(fullStackEngineer)

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2019-07-08

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏知了一笑

Java描述设计模式(05):原型模式

8810
来自专栏Fundebug

GraphQL快速入门教程

传统的api调用一般获取到的是后端组装好的一个完整对象,而前端可能只需要用其中的某些字段,大部分数据的查询和传输工作都浪费了。graphQL提供一种全新数据查询...

11130
来自专栏Node开发

Vue博客实战---前后端环境搭建

最近心血来潮在开发个人博客网站,刚好可以趁这个机会出一个系列文章讲讲前端界面的设计,后端业务逻辑的实现以及前后端的交互。具体的架构我是采用Vu...

24110
来自专栏front-end technology

深入理解class的继承,助你成为优秀的前端

Class 可以通过extends关键字实现继承,这比 ES5 的通过修改原型链实现继承,要清晰和方便很多。

9430
来自专栏好好学java的技术栈

你必须收藏的 GitHub 技巧

来 源:cnblogs.com/iamzhanglei/p/6177961.html

8820
来自专栏Java大联盟

Java8新特性:默认方法详解

Java8 中的默认方法是针对接口添加的新特性,它是指接口可以直接对方法进行实现,实现方式很简单,直接在方法定义处添加 default 关键字即可,如下所示。

10320
来自专栏front-end technology

​promise源码详解,助力你轻松掌握promise

在没有出来promise之前,为了拿到函数的回调结果,我们不得不使用callback function,这种代码的维护和理解是相当恶心了!

9050
来自专栏爱写Bug

LeetCode 138:复制带随机指针的链表 Copy List with Random Pointer

给定一个链表,每个节点包含一个额外增加的随机指针,该指针可以指向链表中的任何节点或空节点。

7640
来自专栏人工智能机器学习

轻松getHadoop大数据开发技术,这一篇文章够了

Hadoop是一个开源框架,可编写和运行分布式应用处理大规模数据。分布式计算是一个宽泛并且不断变化的领域。

11120
来自专栏达达前端

JavaScript入门篇

快速认识JavaScript 熟悉JavaScript基本语法 窗口交互方法 通过DOM进行网页元素的操作 学会如何编写JS代码 运用JavaScri...

10330

扫码关注云+社区

领取腾讯云代金券

年度创作总结 领取年终奖励