前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >nodejs框架Koa做中间层使用总结(含示例)

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

作者头像
用户1462769
发布2019-08-09 19:47:05
2.3K0
发布2019-08-09 19:47:05
举报
文章被收录于专栏:全栈者

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接口给前端
代码语言:javascript
复制
nvm install 8  //8以上可以使用最新语法
nvm use 8
npm i --save koa

② 目录结构:

③ 实现代码:

代码语言:javascript
复制
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。

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

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-07-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 全栈者 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
消息队列 TDMQ
消息队列 TDMQ (Tencent Distributed Message Queue)是腾讯基于 Apache Pulsar 自研的一个云原生消息中间件系列,其中包含兼容Pulsar、RabbitMQ、RocketMQ 等协议的消息队列子产品,得益于其底层计算与存储分离的架构,TDMQ 具备良好的弹性伸缩以及故障恢复能力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档