在开发和产品环境下,Puma是一个简单,快速,多线程,并高并发highly concurrent HTTP1.1server for Ruby/Rack程序。git
什么是多线程? multithreadinggithub
指从软件或者硬件上实现多个线程并发执行的技术。从而总体提高处理效能。 ruby
软件多线程:即便处理器只能运行一个线程,但操做系统能够经过快速在不一样线程之间进行切换,因为间隔时间很小,给用户形成一种多个线程同时运行的假象。这样的程序运行机制被称为软件多线程。服务器
多任务能够由多进程完成,也能够由一个进程内的多线程完成。多线程
进程是由若干线程组成的,一个进程至少有一个线程。并发
单进程单线程:一我的在一个桌子上吃菜;app
单进程多线程:多我的在一个桌子上吃菜;容易发生争抢,即资源共享就会发生冲突争抢。socket
多进程单线程:多我的在各自的桌子上吃菜; tcp
gem 'puma', '~> 3.11' svg
gem 'mina-puma', '~> 1.1.0', require: false
⚠️require: false的选项是什么用途?
把这个gem安装了,但不加载load。 你bundler时,不会调用require 'mina-puma'命令。何时须要用到这个library,手动加载这个命令。
通常是不但愿这个gem加载到全部进程中,只在特定的时候使用。能够节省主程序的内存和减小startup 时间。
Rails
Puma是Rails的默认server,已经安装在gemfile中了。
使用rails s会开启你的服务器:
可是用rails s不能进行额外的options的配置,可使用$ bundle exec puma 代替 :
具体配置选择看puma -h ,详细讲解见git
部分讲解见下:
Configuration
全部配置能够在config/puma.rb中设置。
例子,若是环境是产品环境则:配置以下信息:
Thread Pool
Puma 使用一个线程池子。你能够设置这个池子最小和最大的线程数。-t 或者 --threads标记。
默认是0:16 。例子: $puma -t 8:32
Clustered mode
Puma提供clustered mode. Clustered mode会fork workers 从一个主进程。 每一个子进程仍有它本身的thread pool。 你能够调节workers的数量,使用-w或者--workers标记。
一个worker就是一个进程。设置workers的数量就是开几个进程。
--preload标记
在配置文件puma.rb中设置preload_app!方法。
on_worker_boot 块
在配置文件puma.rb中设置这个块会在boot每一个worker时运行块中的代码。
做用是在boot这个程序前,用于创建这个进程,让你能够作一些Puma-specific的事情(不想插入到程序中的事),例如去掉一些worker启动时或发送信息的日志信息。这个块能够屡次调用。
若是你预加载 你的程序并使用ActiveRecord。推荐把你的链接池放到这个块中,见👆的代码实例。
before_fork块
用于在workers被fork前运行一些代码。见👆示例。
还有不少额外配置,现用现学把。