Mercurial > zeropaste
comparison config/puma.rb @ 495:92929378413e
Update to latest rails
author | nanaya <me@nanaya.net> |
---|---|
date | Sun, 15 Dec 2024 22:18:06 +0900 |
parents | 68eb23b52864 |
children |
comparison
equal
deleted
inserted
replaced
494:e508d3226214 | 495:92929378413e |
---|---|
1 # Puma can serve each request in a thread from an internal thread pool. | 1 # This configuration file will be evaluated by Puma. The top-level methods that |
2 # The `threads` method setting takes two numbers a minimum and maximum. | 2 # are invoked here are part of Puma's configuration DSL. For more information |
3 # Any libraries that use thread pools should be configured to match | 3 # about methods provided by the DSL, see https://puma.io/puma/Puma/DSL.html. |
4 # the maximum value specified for Puma. Default is set to 5 threads for minimum | |
5 # and maximum, this matches the default thread size of Active Record. | |
6 # | 4 # |
7 threads_count = ENV.fetch("RAILS_MAX_THREADS") { 5 }.to_i | 5 # Puma starts a configurable number of processes (workers) and each process |
6 # serves each request in a thread from an internal thread pool. | |
7 # | |
8 # You can control the number of workers using ENV["WEB_CONCURRENCY"]. You | |
9 # should only set this value when you want to run 2 or more workers. The | |
10 # default is already 1. | |
11 # | |
12 # The ideal number of threads per worker depends both on how much time the | |
13 # application spends waiting for IO operations and on how much you wish to | |
14 # prioritize throughput over latency. | |
15 # | |
16 # As a rule of thumb, increasing the number of threads will increase how much | |
17 # traffic a given process can handle (throughput), but due to CRuby's | |
18 # Global VM Lock (GVL) it has diminishing returns and will degrade the | |
19 # response time (latency) of the application. | |
20 # | |
21 # The default is set to 3 threads as it's deemed a decent compromise between | |
22 # throughput and latency for the average Rails application. | |
23 # | |
24 # Any libraries that use a connection pool or another resource pool should | |
25 # be configured to provide at least as many connections as the number of | |
26 # threads. This includes Active Record's `pool` parameter in `database.yml`. | |
27 threads_count = ENV.fetch("RAILS_MAX_THREADS", 3) | |
8 threads threads_count, threads_count | 28 threads threads_count, threads_count |
9 | 29 |
10 # Specifies the `port` that Puma will listen on to receive requests, default is 3000. | 30 # Specifies the `port` that Puma will listen on to receive requests; default is 3000. |
11 # | 31 port ENV.fetch("PORT", 3000) |
12 port ENV.fetch("PORT") { 3000 } | |
13 | 32 |
14 # Specifies the `environment` that Puma will run in. | 33 # Allow puma to be restarted by `bin/rails restart` command. |
15 # | 34 plugin :tmp_restart |
16 environment ENV.fetch("RAILS_ENV") { "development" } | |
17 | 35 |
18 # Specifies the number of `workers` to boot in clustered mode. | 36 # Run the Solid Queue supervisor inside of Puma for single-server deployments |
19 # Workers are forked webserver processes. If using threads and workers together | 37 plugin :solid_queue if ENV["SOLID_QUEUE_IN_PUMA"] |
20 # the concurrency of the application would be max `threads` * `workers`. | |
21 # Workers do not work on JRuby or Windows (both of which do not support | |
22 # processes). | |
23 # | |
24 # workers ENV.fetch("WEB_CONCURRENCY") { 2 } | |
25 | 38 |
26 # Use the `preload_app!` method when specifying a `workers` number. | 39 # Specify the PID file. Defaults to tmp/pids/server.pid in development. |
27 # This directive tells Puma to first boot the application and load code | 40 # In other environments, only set the PID file if requested. |
28 # before forking the application. This takes advantage of Copy On Write | 41 pidfile ENV["PIDFILE"] if ENV["PIDFILE"] |
29 # process behavior so workers use less memory. If you use this option | |
30 # you need to make sure to reconnect any threads in the `on_worker_boot` | |
31 # block. | |
32 # | |
33 # preload_app! | |
34 | |
35 # The code in the `on_worker_boot` will be called if you are using | |
36 # clustered mode by specifying a number of `workers`. After each worker | |
37 # process is booted this block will be run, if you are using `preload_app!` | |
38 # option you will want to use this block to reconnect to any threads | |
39 # or connections that may have been created at application boot, Ruby | |
40 # cannot share connections between processes. | |
41 # | |
42 # on_worker_boot do | |
43 # ActiveRecord::Base.establish_connection if defined?(ActiveRecord) | |
44 # end | |
45 | |
46 # Allow puma to be restarted by `rails restart` command. | |
47 plugin :tmp_restart |