Help us understand the problem. What is going on with this article?

Apacheとnginxのリバースプロキシ挙動差(バッファリング)

More than 1 year has passed since last update.

Apacheとnginxでは,リバースプロキシのバッファリングにまつわる挙動差があります.

nginx

  • デフォルトでリクエストはバッファリングされる.
  • 転送先へのリクエストは,nginxがリクエストを受信し終えた後.
  • ただし,nginx 1.7.11以降はproxy_request_bufferingオプションで無効化できる.

Apache

  • リクエストはバッファリングされない.
  • 転送先へのリクエストは,Apacheのリクエスト受信途中から.

バッファリングによる利点・欠点

利点

  • 低速なクライアントの影響を受けない.
    • unicornのworkerがリクエスト受信待ちで占有… ということがなく,workerが効率良く捌けるようになる.
    • 転送先Webアプリケーションのセッション数(unicornのworker数)が限られる場合は効果的.

欠点

  • メモリやディスクを消費する.
    • リクエストが数百MBを超えたり,塵も積もればの大量リクエストがある場合は,ディスクI/Oがボトルネックになり得ます.
    • client_body_buffer_sizeでメモリへのバッファサイズをチューニングできますが,消費はします.
  • 転送先へのリクエスト送信がわずかに遅れる.
    • バッファリングなしで随時送信するよりは,わずかに遅くなります.わずかにですが.

せいぜい数百KBのアップロードだけど,低速なMVNO回線でしょっちゅう利用する(利用される)…
というWebアプリケーションなんかは,バッファリングの利点目当てに Debian+nginx+unicorn+Rails という構成をよくやっていました.

参考文献

no_clock
P2P地震情報とかも作ってます.
https://www.nyamikan.net/
m3dev
インターネット、最新IT技術を活用し日本・世界の医療を改善することを目指します
https://m3.recruitment.jp/engineer/
Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
Comments
No comments
Sign up for free and join this conversation.
If you already have a Qiita account
Why do not you register as a user and use Qiita more conveniently?
You need to log in to use this function. Qiita can be used more conveniently after logging in.
You seem to be reading articles frequently this month. Qiita can be used more conveniently after logging in.
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
ユーザーは見つかりませんでした