Javascript

在 5 分钟内搭建 Node.js 微服务原型

本文主要是介绍在 5 分钟内搭建 Node.js 微服务原型,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
作者:Sergey Kravchenko

翻译:疯狂的技术宅

原文:https://medium.com/@krawa76/b...

未经允许严禁转载

微服务已成为在 Node.js 中构建可扩展且强大的云应用的主流方法。同时也存在一些门槛,其中一些难点需要你在以下方面做出决策:

  • 组织项目结构。
  • 将自定义服务连接到第三方服务(数据库,消息代理等)
  • 处理微服务之间共享的代码。
  • 将项目容器化。
  • 在本地运行和调试,然后将其部署到云中。

SMF 框架是开箱即用的解决方案:

https://github.com/krawa76/smf

让我们看看它如何帮你创建和部署微服务原型而无需编写任何代码。

创建项目

安装框架,创建一个新项目并 cd 到项目目录:

$ npm install -g sokyra-microservice-factory
$ smf new test-stack
$ cd test-stack

带有演示服务的样板代码已生成,我们可以轻松地运行该项目:

$ smf up

这将生成 Docker工件(docker-compose 和环境变量文件),构建映像并在本地运行容器:

1*he6NAqyFQFN-0sK1yukWRQ.png

如果在编辑器中打开项目,则会看到带有 main.ts 模块的自动生成的 demo 服务,该服务在上面的日志中生成了记录。其他的重要文件是 smf-stack.json(项目配置),smf-env.json(容器 env 变量),通用的 Dockerfile 和 smf-docker.yml(docker-compose):

1*xcHdUgoLZsa1jmyvfSYMiw.png

要停止项目,请运行

$ smf down

添加新服务

让我们添加一项服务,该服务可以通过消息代理发送和接收消息,并将某些内容保存到数据库中:

$ smf add service service1

选择 RabbitMQMongoDB ,然后输入 “0” 退出菜单:

1*xnzqpNqIxhtDijzLGn1SOg.png

这将在 main 模块中创建新的带有样板代码的 service 子文件夹:

1*zuwz7ggrJlCN447Je_RMvg.png

让我们再次运行该项目查看其运行情况:

$ smf up

现在我们有 4 个容器在运行:RabbitMQ、MongoDB、demo 和 service1。后者通过 RabbitMQ 发送接收消息,并将模拟数据保存到 MongoDB:

1*kQzySC8joql1Pwekm87IHA-20200305191604643.png

可以再次使用 smf down 命令停止该项目。

我们可以类似地添加更多服务,如果选择相同的消息代理服务,它们都会通过消息中心交换消息。

部署

将我们的项目部署到安装了 Docker 和 Docker-Compose 的远程服务器上很容易。如果你还没有,请按照以下简单说明在 Amazon AWS EC2 中创建它:

https://github.com/krawa76/sm...

还需要 Docker Hub 帐户。如果丢失,你可以在这里免费注册:

https://hub.docker.com/

在编辑器中打开 smf-deploy.json 文件,并填写 Docker Hub 登录名及密码、主机地址和远程计算机 SSH 凭据(ssh密钥路径)。

1*-B_LZVdkdw_rfyMEsMOwZA.png

运行以下命令部署项目:

$ smf deploy

当该过程结束时,我们可以 ssh 到远程机器,并查看在那里运行的微服务:

$ ssh -i "/Users/me/.ssh/aws-key.pem" ubuntu@ec2-x-x-x-x.compute1.amazonaws.com$ docker ps
(gives the list of services)$ docker logs -f test-stack-service1
(give the live log)

现在,我们在云中有了容器

这篇关于在 5 分钟内搭建 Node.js 微服务原型的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!