 微服务已成为在 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 和环境变量文件),微服务原构建映像并在本地运行容器:  docker-compose 日志 如果在编辑器中打开项目,分钟则会看到带有 main.ts 模块的搭建自动生成的 demo 服务,该服务在上面的微服务原日志中生成了记录。其他的b2b供应网重要文件是 smf-stack.json (项目配置), smf-env.json (容器 env 变量),通用的 Dockerfile 和 smf-docker.yml (docker-compose):  演示服务,main 模块 要停止项目,请运行 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 帐户。如果丢失,你可以在这里免费注册: 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 ... 编码愉快! |