内容简介:作者:Sergey Kravchenko
每日前端夜话 第291篇
翻译: 疯狂的技术宅
作者:Sergey Kravchenko
来源:medium
正文共:1099 字
预计阅读时间:5 分钟
微服务已成为在 Node.js 中构建可扩展且强大的云应用的主流方法。同时也存在一些门槛,其中一些难点需要你在以下方面做出决策:
-
组织项目结构。
-
将自定义服务连接到第三方服务(数据库,消息代理等)
-
处理微服务之间共享的代码。
-
将项目容器化。
-
在本地运行和调试,然后将其部署到云中。
SMF 框架是开箱即用的解决方案:
https://github.com/krawa76/smf
让我们看看它如何帮你创建和部署微服务原型而 无需编写任何代码。
创建项目
安装框架,创建一个新项目并 cd 到项目目录:
1$ npm install -g sokyra-microservice-factory 2$ smf new test-stack 3$ cd test-stack
带有演示服务的样板代码已生成,我们可以轻松地运行该项目:
1$ smf up
这将生成 Docker 工件(docker-compose 和环境变量文件),构建映像并在本地运行容器:
如果在编辑器中打开项目,则会看到带有 main.ts
模块的自动生成的 demo
服务,该服务在上面的日志中生成了记录。其他的重要文件是 smf-stack.json
(项目配置), smf-env.json
(容器 env 变量),通用的 Dockerfile 和 smf-docker.yml
(docker-compose):
要停止项目,请运行
1$ smf down
添加新服务
让我们添加一项服务,该服务可以通过消息代理发送和接收消息,并将某些内容保存到数据库中:
1$ smf add service service1
选择 RabbitMQ
和 MongoDB
,然后输入 “0” 退出菜单:
这将在 main 模块中创建新的带有样板代码的 service 子文件夹:
让我们再次运行该项目查看其运行情况:
1$ smf up
现在我们有 4 个容器在运行:RabbitMQ、 MongoDB 、demo 和 service1。后者通过 RabbitMQ 发送接收消息,并将模拟数据保存到 MongoDB:
可以再次使用 smf down
命令停止该项目。
我们可以类似地添加更多服务,如果选择相同的消息代理服务,它们都会通过消息中心交换消息。
部署
将我们的项目部署到安装了 Docker 和 Docker-Compose 的远程服务器上很容易。如果你还没有,请按照以下简单说明在 Amazon AWS EC2 中创建它:
https://github.com/krawa76/smf/blob/master/README-provisioner.md
还需要 Docker Hub 帐户。如果丢失,你可以在这里免费注册:
https://hub.docker.com/
在编辑器中打开 smf-deploy.json
文件,并填写 Docker Hub 登录名及密码、主机地址和远程计算机 SSH 凭据(ssh密钥路径)。
运行以下命令部署项目:
1$ smf deploy
当该过程结束时,我们可以 ssh 到远程机器,并查看在那里运行的微服务:
1$ ssh -i "/Users/me/.ssh/aws-key.pem" ubuntu@ec2-x-x-x-x.compute1.amazonaws.com$ docker ps 2(gives the list of services)$ docker logs -f test-stack-service1 3(give the live log)
现在,我们在云中有了容器化微服务栈的有效原型。
下一步是什么?
开始添加更多逻辑。由于每个服务都是一个单独的NPM软件包,因此我们可以进入到 service 文件夹,安装其他软件包,在 main.ts
模块中编写模式代码,添加新的 JavaScript 模块,等等:
1$ cd services/service1 2$ npm install ...
编码愉快!
原文链接
https://medium.com/@krawa76/bootstrap-node-js-microservice-stack-4a348db38e51
2020年京程一灯全新课程体系即将推出,请保持关注。
愿你在新的一年里保持技术领先,有个好前程,愿你月薪30K。我们是认真的 !
✎ 往期精彩回顾
从 JavaScript、ES6、ES7 到 ES10,你学到哪儿了?
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- [译] 5 分钟搭建 Node.js 微服务原型
- 使用minio搭建高性能对象存储-第一部分:原型
- 图解原型和原型链
- 创建对象、原型、原型链
- 构造函数、原型、原型链、继承
- JavaScript原型与原型链
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Effective C++
梅耶 (Scott Meyers) / 侯捷 / 电子工业出版社 / 2011-1-1 / 65.00元
《Effective C++:改善程序与设计的55个具体做法(第3版)(中文版)(双色)》内容简介:有人说C++程序员可以分为两类,读过Effective C++的和没读过的。世界项级C++大师scott Meyers成名之作的第三版的确当得起这样的评价。当您读过《Effective C++:改善程序与设计的55个具体做法(第3版)(中文版)(双色)》之后,就获得了迅速提升自己C++功力的一个契机......一起来看看 《Effective C++》 这本书的介绍吧!