Finally, I figured out how to test the throughput difference of enabled/disabled proxy buffering. I think slowtest
isn't a good tool to test it. I used wrk
My new set up:
Slow client (10.2.0.7) \
\
Nginx (10.2.0.5) <===> PythonApp (10.2.0.4, port 8000)
/
/
Fast client (10.2.0.6)
You can reference this Digital Ocean guide to set up Flask app
Python App:
from flask import Flask
app = Flask(__name__)
@app.route("/")
def hello():
return "<h1 style='color:blue'>Hello There!</h1>"
@app.route("/big-file")
def big_file():
return "<h1 style='color:blue'>" + "Hello There!"*1000000 + "</h1>"
if __name__ == "__main__":
app.run(host='0.0.0.0')
Slow client:
# modprobe ifb
# ip link set dev ifb0 up
# tc qdisc add dev eth0 ingress
# tc filter add dev eth0 parent ffff: \
protocol ip u32 match u32 0 0 flowid 1:1 action mirred egress redirect dev ifb0
# tc qdisc add dev ifb0 root netem delay 750ms
Run wrk test on fast & slow client:
Slow client:
# wrk -t4 -c10 -d30 http://pythonapp.com/big-file
Fast client:
# wrk -t2 -c100 -d10 http://pythonapp.com
It's a must for slow client to access /big-file path, which will return a fairly large response. If the response is smaller than proxy_buffer_size, the connection between Nginx and proxied server will be closed very quickly, and you cannot simulate the blocking.
Connections occupied by slow clients under no proxy_buffering in Nginx & throughput of fast clients:
data:image/s3,"s3://crabby-images/cb7f2/cb7f2439d7af26d6eadca1877e550f195a5be16c" alt="Connections occupied by slow clients"
Throughput of fast clients when no proxy buffering
data:image/s3,"s3://crabby-images/f917c/f917c31aeb83951af8ed082eee9c7936e4af27bd" alt="Test Result of fast client for no proxy buffering"
If there is proxy_buffering, you shall not see connections occupied by slow clients. You can run the commands for slow clients to download slow response first, then check the connections in Nginx.
data:image/s3,"s3://crabby-images/f0dd8/f0dd841a3f8b6dafda8084fee1c2230efebb8c56" alt="No occupied connections by slow clients"
Throughput of fast clients when there is proxy buffering
data:image/s3,"s3://crabby-images/20d0d/20d0d7c6b1db4bea776edc3ab4860682893cffe0" alt="enter image description here"