官术网_书友最值得收藏!

Thinking serverless

A serverless solution is entirely event-driven. Every time that a user requests some information, a trigger will notify your cloud vendor to pick your code and execute it to retrieve the answer. In contrast, a traditional solution also works to answer requests, but the code is always up and running, consuming machine resources that were reserved specifically for you, even when no one is using your system.

In a serverless architecture, it's not necessary to load the entire codebase into a running machine to process a single request. For a faster loading step, only the code that is necessary to answer the request is selected to run. This small piece of the solution is referenced as a function. So we only run functions on demand.

Although we call it simply as a function, it's usually a zipped package that contains a piece of code that runs as an entry point along with its dependencies.

In the following diagram, the serverless model is illustrated in a sequence of steps. It's an example of how a cloud provider could implement the concept, though it doesn't have to implement it in this way:

Let's understand the following steps shown in the preceding diagram:

  1. The user sends a request to an address handled by the cloud provider.
  2. Based on the message, the cloud service tries to locate which package must be used to answer the request.
  3. The package (or function) is selected and loaded into a Docker container.
  4. The container is executed and outputs an answer.
  5. The answer is sent to the original user.

What makes the serverless model so interesting is that you are only billed for the time that was needed to execute your function, usually measured in fractions of seconds, not hours of use. If no one is using your service, you pay nothing.

Also, if you have a sudden peak of users accessing your application, the cloud service will load different instances to handle all simultaneous requests. If one of those cloud machines fails, another one will be made available automatically, without needing to configure anything.

主站蜘蛛池模板: 天津市| 南充市| 宜都市| 邢台市| 和顺县| 顺平县| 台东县| 梓潼县| 普兰店市| 萨嘎县| 修水县| 青河县| 上蔡县| 望都县| 乌拉特中旗| 柳林县| 洛宁县| 资中县| 江津市| 塔河县| 康平县| 新疆| 南川市| 历史| 徐水县| 周宁县| 永修县| 东丰县| 乐都县| 视频| 麻阳| 彭山县| 湖南省| 固始县| 抚顺县| 水富县| 光泽县| 黑河市| 定西市| 英德市| 曲周县|