I am running a Dancer (v1.3202) app with Starman (v0.4014) and ngynx as a front end proxy. I am noticing a huge latency spike in my load balancer every couple of hours and wonder if it's the workers reaching their request limit and restarting. The latency goes from 30ms average to 1000ms or more. I checked the MongoDB and there are no long running queries. What does the --max-requests actually do regarding the workers and what happens when a worker reaches this limit?
What is the optimal --max-requests setting for Starman?
743 Views Asked by MadHacker At
1
There are 1 best solutions below
Related Questions in PERL
- Give data access to Einstein Analytics Capture from several domains
- Integrate Einstein Bot with Google Cloud
- Salesforce Einstein Bot close and minimize button getting enlarged
- How do I deploy an R code model in Salesforce Einstein Analytics Plus? Or find another alternative to Shiny?
- How to connect to Salesforce Einstein using Azure Data Factory?
- How to show variable's value in Dialog Name (Einstein Bot)
- Integrate Salesforce Einstein chatbot in website built using Dot Net and Angular
- How to change the Field Label and format for the formuale field created in the step in dashboard in einstein analytic?
- Custom date in Einstein Analytics
- Salesforce Chatbot : use NLP when the bot ask Question
Related Questions in NGINX
- Give data access to Einstein Analytics Capture from several domains
- Integrate Einstein Bot with Google Cloud
- Salesforce Einstein Bot close and minimize button getting enlarged
- How do I deploy an R code model in Salesforce Einstein Analytics Plus? Or find another alternative to Shiny?
- How to connect to Salesforce Einstein using Azure Data Factory?
- How to show variable's value in Dialog Name (Einstein Bot)
- Integrate Salesforce Einstein chatbot in website built using Dot Net and Angular
- How to change the Field Label and format for the formuale field created in the step in dashboard in einstein analytic?
- Custom date in Einstein Analytics
- Salesforce Chatbot : use NLP when the bot ask Question
Related Questions in DANCER
- Give data access to Einstein Analytics Capture from several domains
- Integrate Einstein Bot with Google Cloud
- Salesforce Einstein Bot close and minimize button getting enlarged
- How do I deploy an R code model in Salesforce Einstein Analytics Plus? Or find another alternative to Shiny?
- How to connect to Salesforce Einstein using Azure Data Factory?
- How to show variable's value in Dialog Name (Einstein Bot)
- Integrate Salesforce Einstein chatbot in website built using Dot Net and Angular
- How to change the Field Label and format for the formuale field created in the step in dashboard in einstein analytic?
- Custom date in Einstein Analytics
- Salesforce Chatbot : use NLP when the bot ask Question
Related Questions in STARMAN
- Give data access to Einstein Analytics Capture from several domains
- Integrate Einstein Bot with Google Cloud
- Salesforce Einstein Bot close and minimize button getting enlarged
- How do I deploy an R code model in Salesforce Einstein Analytics Plus? Or find another alternative to Shiny?
- How to connect to Salesforce Einstein using Azure Data Factory?
- How to show variable's value in Dialog Name (Einstein Bot)
- Integrate Salesforce Einstein chatbot in website built using Dot Net and Angular
- How to change the Field Label and format for the formuale field created in the step in dashboard in einstein analytic?
- Custom date in Einstein Analytics
- Salesforce Chatbot : use NLP when the bot ask Question
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular # Hahtags
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
What does the
--max-requests
setting do?From
starman --help
:What this means is that each worker will exit after it processes that many requests. The master process will then launch a brand new worker for each worker that exits, maintaining the number of workers according to the
--workers
setting.Using
--max-requests
is usually a good thing, especially if your app isn't the only thing running on the box, becauseperl
(notoriously) does not give back memory that it uses. This recycling of worker processes is the waystarman
can give memory back for other processes to use. If your app actually leaks memory, this can also help keep your app running with good performance as opposed to your app eventually consuming all the memory and needing to be killed by the OS.What is the optimal value for the
--max-requests
setting?You should leave it at its default value of
1,000
unless you have a good reason to change it. If your app is the only thing running on the box and you're sure that it's not leaky, you could try using a higher value to recycle workers less often. If you know your app is leaky, you may want to use a lower value to recycle workers more often. However, generally this setting should actually have very little impact on performance.That said, recycling workers could be responsible for spurious slow requests if your workers cache stuff in memory because new workers would need to spend some time rebuilding those caches, but there could be many other possible explanations. You'll need to do some profiling to find out what's really causing the specific slowness you're seeing.