疯狂的技术宅 前端先锋 前端
翻译:疯狂的技术宅
做者:Sergey Kravchenko
来源:medium
正文共:1099 字
预计阅读时间:5 分钟node
微服务已成为在 Node.js 中构建可扩展且强大的云应用的主流方法。同时也存在一些门槛,其中一些难点须要你在如下方面作出决策:git
https://github.com/krawa76/smfgithub
让咱们看看它如何帮你建立和部署微服务原型而无需编写任何代码。docker
安装框架,建立一个新项目并 cd 到项目目录:数据库
1$ npm install -g sokyra-microservice-factory 2$ smf new test-stack 3$ cd test-stack
带有演示服务的样板代码已生成,咱们能够轻松地运行该项目:npm
1$ smf up
这将生成 Docker工件(docker-compose 和环境变量文件),构建映像并在本地运行容器:json
docker-compose 日志
若是在编辑器中打开项目,则会看到带有 main.ts 模块的自动生成的 demo 服务,该服务在上面的日志中生成了记录。其余的重要文件是 smf-stack.json(项目配置),smf-env.json(容器 env 变量),通用的 Dockerfile 和 smf-docker.yml(docker-compose):bootstrap
演示服务,main 模块
要中止项目,请运行ubuntu
1$ smf down
让咱们添加一项服务,该服务能够经过消息代理发送和接收消息,并将某些内容保存到数据库中:
1$ smf add service service1
选择 RabbitMQ 和 MongoDB ,而后输入 “0” 退出菜单:
这将在 main 模块中建立新的带有样板代码的 service 子文件夹:
让咱们再次运行该项目查看其运行状况:
1$ smf up
如今咱们有 4 个容器在运行:RabbitMQ、MongoDB、demo 和 service1。后者经过 RabbitMQ 发送接收消息,并将模拟数据保存到 MongoDB:
docker-compose 日志
能够再次使用 smf down 命令中止该项目。
咱们能够相似地添加更多服务,若是选择相同的消息代理服务,它们都会经过消息中心交换消息。
将咱们的项目部署到安装了 Docker 和 Docker-Compose 的远程服务器上很容易。若是你尚未,请按照如下简单说明在 Amazon AWS EC2 中建立它:
https://github.com/krawa76/smf/blob/master/README-provisioner.md
还须要 Docker Hub 账户。若是丢失,你能够在这里免费注册:
在编辑器中打开 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