本地运行微服务
这项工作正在进行中,我们将逐段添加其内容。欢迎您在 discuss.istio.io 网站上提供反馈。
在微服务架构出现之前,开发团队会将整个应用程序作为一个大型软件进行构建、部署和运行。想要测试模块中一个微小的改变, 开发人员不仅要通过单元测试,他们必须重新构建整个程序。因此,构建需要花费大量的时间。完成构建后, 开发人员将应用程序版本部署到测试服务器上。他们会把服务跑在远程或本地计算机中。在后一种情况下,开发者会在他们 的本地计算机上安装并管理一个相当复杂的环境。
在微服务架构时代,开发人员编写、构建、测试和运行小型的软件服务。构建是快速的。使用类似 Node.js 这样的现代框架, 由于服务是作为常规进程来运行的,就不需要安装并管理 复杂的服务环境来测试它了。您不再仅仅为了测试您的服务就得将它部署到某个环境了,您只需要构建您的服务并且直接在你本地机器上运行即可。
该模块涵盖了在本地机器上开发单个服务所涉及的不同方面。不过,您无需编写代码,只需要编译、运行和测试现有服务 rating
。
ratings
服务是用 Node.js 编写的一个可以单独运行的小型 web 应用程序。 它与其他 web 应用程序执行类似的操作:
- 监听它作为参数接受的端口。
- 接受在
/ratings/{productID}
路径上的HTTP GET
请求,并返回与客户端指定的productID
的值所匹配的产品的评级。 - 接受在
/ratings/{productID}
路径上的HTTP POST
请求,并更新与您指定的productID
的值所匹配的产品的评级。
请按照下列步骤下载应用程序的代码,安装其依赖项,然后在本地运行它:
将服务代码和 其 package 文件 下载到一个单独的目录中:
$ mkdir ratings
$ cd ratings
$ curl -s https://raw.githubusercontent.com/istio/istio/release-1.8/samples/bookinfo/src/ratings/ratings.js -o ratings.js
$ curl -s https://raw.githubusercontent.com/istio/istio/release-1.8/samples/bookinfo/src/ratings/package.json -o package.json
浏览服务的代码,并注意代码中以下元素:
- web 服务器的特征:
- 监听一个端口
- 处理请求和响应
- 与 HTTP 相关的方面:
- 请求头
- 路径
- 状态码
在 Node.js 中,web 服务器的功能嵌入在应用程序的代码中。一个 Node.js web 应用程序作为一个独立进程运行。
- web 服务器的特征:
Node.js 应用程序是用 JavaScript 编写的,这意味着没有显式编译步骤。相反,它们 使用 just-in-time 即时编译。要 构建 Node.js 应用程序,则意味着要安装其依赖库。将
rating
服务的依赖库安装在存储服务代码和 package 文件的同一目录下:$ npm install
npm notice created a lockfile as package-lock.json. You should commit this file.
npm WARN ratings No description
npm WARN ratings No repository field.
npm WARN ratings No license field.
added 24 packages in 2.094s
通过传递
9080
参数来运行服务,然后应用程序在 9080 端口上监听。$ npm start 9080
> @ start /tmp/ratings
> node ratings.js "9080"
Server listening on: http://0.0.0.0:9080
该 ratings
服务是一个 web 应用程序,您可以像访问其他 web 应用程序那样访问它。 您可以使用浏览器或者像 curl
或 Wget
的命令行 web 客户端。由于您在本地运行了 rating
服务,因此您也可以通过 localhost
主机名访问它。
在浏览器中打开 http://localhost:9080/ratings/7 或者使用
curl
命令来访问ratings
:$ curl localhost:9080/ratings/7
{"id":7,"ratings":{"Reviewer1":5,"Reviewer2":4}}
打开另一个终端 session,使用 curl 命令的 POST 方法将产品的评级设置为 1 :
$ curl -X POST localhost:9080/ratings/7 -d '{"Reviewer1":1,"Reviewer2":1}'
{"id":7,"ratings":{"Reviewer1":1,"Reviewer2":1}}
检查更新的评级:
$ curl localhost:9080/ratings/7
{"id":7,"ratings":{"Reviewer1":1,"Reviewer2":1}}
在服务运行的终端使用 Ctrl-C 停止它。
恭喜, 您现在可以在本地计算机上构建、测试和运行服务了!
您已经做好了如何打包服务到容器的准备了。