Welcome to my GitHub

Github.com/zq2599/blog…

Content: all original article classification summary and supporting source code, involving Java, Docker, Kubernetes, DevOPS, etc.;

Links to OpenFaaS Field series articles

  1. The deployment of
  2. Introduction to the function
  3. Java functions
  4. Template operation (Template)
  5. Big watchdog
  6. Of -watchdog(For performance)
  7. Java11 template parsing
  8. Maven +jdk8
  9. Maven +maven+jdk8

This paper gives an overview of

  • This article is the sixth in the OpenFaaS field series. We have learned about the principle of watchdog, and we have raised concerns about the potential performance problems of forking a process for each web request.
  • If every request is to create a process, as a Java programmer is not acceptable, the father of Java teacher Ma Junjun’s teaching in B still remember: thread pool, asynchronous response, NIO…
  • At the end of the previous article also revealed the plot, the above performance problems have been solved, and the specific solution is the main content of this article: of watchdog;

Revelation from the Ancient Esoterica

In the book “Deep And Simple Serverless” published in March 2020, Teacher Chen Geng mentioned that in order to optimize watchdog performance, OpenFasS is incubating a new watchdog implementation: of-watchdog, as shown below:

Don’t be too optimistic

  • At present, the official attitude of of-watchdog is optimistic and cautious. Therefore, the risk should be exposed in advance. Please take it as a reference when deciding whether to use it in production environment.
  • The first is to point out that of-watchdog is becoming popular:

  • The following is a template that supports of-watchdog, as shown in the red box below. It is only available for avilable for testing, but it is still not available in production environment.

A preliminary study

  • With the tips of Teacher Chen Geng, go to the official website of the watchdog for details, the address is: github.com/openfaas/of… The words in the red box below are the simplest explanation:

  • Although His English was poor, Chen understood the red box above: of-watchdog is a reverse proxy between functions and microservices
  • When a browser visits an e-commerce site, both the order service and the shopping cart service request are sent to the same Nginx. Nginx forwards the request to different Tomcat servers based on the request URL. The browser only knows about Nginx and does not know that Tomcat is actually executing the task. Nginx is a reverse proxy:

  • Of-watchdog is a reverse proxy between a function and a microservice, and here’s what I imagined on my side:

  • After all, martinfowler’s definition of microservices indicates that HTTP requests should be processed, as shown in the red box below:

  • It turns out that the actual situation of of-watchdog is more complicated than I imagined, because of the concept of of-watchdog (mode). Next, take a closer look at the various modes of of-watchdog is exactly what?

http mode

  • The default mode of of-watchdog is HTTP. During service deployment, of-watchdog forks A process (for example, process A). Process A listens to A port, and all requests received by of-Wahtchdog are forwarded to the port monitored by process A.

  • The code is executed in the child on the right. This child receives the external request forwarded by of-watchdog from port 3000, and then processes it internally. This is what Tomcat does.
  • The official description of the advantages of of-watchdog is as follows (forgive my poor translation) :
  • First, the concurrency performance and throughput are optimal.
  • Second, compared with watchdog, the use of memory is more efficient;
  • Third, the established database connection can be used over and over again;
  • Fourth, the container operating system’s temporary folder (/ TMP/directory) is shared by all requests, for example, can be used for temporary caching;
  • Fifth, it seems to be about Node and Python. I really can’t read it. Please read it yourself.
Does not require new/custom client libraries like afterburn but makes use of a long-running daemon such as Express.js for Node or Flask for Python
Copy the code
  • Although our question has been answered, in addition to HTTP mode, there are several other modes of of-watchdog that I recommend you to briefly understand, and some scenarios may be useful.

serializing mode

With this mode, of-watchdog is no different from the previous watchdog, is used to maintain compatibility with the watchdog;

streaming mode

  • In this mode, a process is forked each time a request is received.
  • This pattern can handle a request body larger than the container memory. For example, the container memory is only 512 megabytes, but it can handle a request body larger than G (such a large body is usually multimedia content, such as video).
  • Visible from the name streaming, a function that handles file streams, suitable for this mode;

static mode

  • , the static mode of – the role of watchdog and nginx similar: after receiving the request to the specified directory reading static file returns (such as XXX. HTML files), the official detailed demo reference address: www.openfaas.com/blog/server…

afterburn mode

The last one is Afterburn mode, which was officially announced to be obsolete when I was exhausted (see picture below).

  • Afterburn is a forked process that has HTTP channels between the parent process and the forked process, and the ofwatchdog can receive STDOUT from the child process via STDIN. Afterburn is a forked process that has HTTP channels between the parent process and the forked process. Because it was abandoned:

Looking forward to

  • After reading the design of OF-Watchdog, we already know that the code written in the previous field provides services in the form of microservices, which aroused my curiosity. In the next article, Hinchen will explore this secret as an ordinary Java developer: Why do Java classes run as microservices in OpenFaaS?
  • This is not to nitpick or nitpick, but to develop OpenFaaS functions more freely in the future;

You are not alone, Xinchen original accompany all the way

  1. Java series
  2. Spring series
  3. The Docker series
  4. Kubernetes series
  5. Database + middleware series
  6. The conversation series

You are not alone, Xinchen original accompany all the way

  1. Java series
  2. Spring series
  3. The Docker series
  4. Kubernetes series
  5. Database + middleware series
  6. The conversation series

Welcome to pay attention to the public number: programmer Xin Chen

Wechat search “programmer Xin Chen”, I am Xin Chen, looking forward to enjoying the Java world with you…

Github.com/zq2599/blog…