为Tornado配置Nginx反向代理

简介:

Tornado的确很给力,知乎、Facebook一直在用。不过Tornado也有自己的局限性,比如它就没有实现完整的HTTP协议,甚至一些REST方法都不支持。不过这也难为它了,本来就是一个Web Framework顺便兼职干一点Web Server的事情而已,有就不错了。好在Tornado现在有了好伙伴Nginx,像HTTPS,负载均衡,静态文件这种破事都可以交给Nginx去处理了。

下载

从源代码编译安装Nginx需要处理一些依赖
Nginx官网
PCRE官网
ZLib官网
下载好之后解压至同一根目录下。

编译

 
  1. $ ./configure
  2. --sbin-path=/usr/local/nginx/nginx
  3. --conf-path=/usr/local/nginx/nginx.conf
  4. --pid-path=/usr/local/nginx/nginx.pid
  5. --with-http_ssl_module
  6. --with-pcre=../pcre-8.38
  7. --with-zlib=../zlib-1.2.8
  8. --with-openssl=../openssl-1.0.2g
  9. #上面只是为了好看....
  10. $ ./configure --sbin-path=/usr/local/nginx/nginx --conf-path=/usr/local/nginx/nginx.conf --pid-path=/usr/local/nginx/nginx.pid --with-http_ssl_module --with-pcre=../pcre-8.38 --with-zlib=../zlib-1.2.8 --with-openssl=../openssl-1.0.2g
  11. $ make -j8 && sudo make install

需要注意的是,Mac下和Linux下默认生成的目录是不一样的。
nginx运行一般要求root权限。
nginx命令行参数相当简单,因为功夫全在配置文件里了……。

 
  1. #启动Nginx实例
  2. $ nginx
  3. #使用指定的配置文件启动nginx
  4. $ nginx -c <conf_file>
  5. #向Nginx发出信号
  6. $ nginx -s [stop| quit| reopen| reload]

Mac下的Nginx配置

 
  1. user nobody nobody;
  2. worker_processes 1;
  3. error_log /var/log/nginx/error.log;
  4. pid /var/run/nginx.pid;
  5. events {
  6. worker_connections 1024;
  7. use kqueue;
  8. }
  9. http {
  10. # Enumerate all the Tornado servers here
  11. upstream frontends {
  12. server 127.0.0.1:8888;
  13. }
  14. include /usr/local/nginx/conf/mime.types;
  15. default_type application/octet-stream;
  16. access_log /var/log/nginx/access.log;
  17. keepalive_timeout 65;
  18. proxy_read_timeout 200;
  19. sendfile on;
  20. tcp_nopush on;
  21. tcp_nodelay on;
  22. gzip on;
  23. gzip_min_length 1000;
  24. gzip_proxied any;
  25. # Only retry if there was a communication error, not a timeout
  26. # on the Tornado server (to avoid propagating "queries of death"
  27. # to all frontends)
  28. proxy_next_upstream error;
  29. server {
  30. listen 80;
  31. # Allow file uploads
  32. client_max_body_size 50M;
  33. location ^~ /static/ {
  34. root /Volumes/Data/vserver;
  35. if ($query_string) {
  36. expires max;
  37. }
  38. }
  39. location ^~ /upload/ {
  40. root /Volumes/Data/vserver;
  41. if ($query_string) {
  42. expires max;
  43. }
  44. }
  45. location = /favicon.ico {
  46. access_log off;
  47. rewrite (.*) /static/other/favicon.ico;
  48. }
  49. location = /robots.txt {
  50. rewrite (.*) /static/other/robots.txt;
  51. }
  52. # Ali heartbeat dectection
  53. location = /status.taobao {
  54. access_log off;
  55. rewrite (.*) /static/other/status.taobao;
  56. }
  57. location / {
  58. proxy_pass_header Server;
  59. proxy_set_header Host $http_host;
  60. proxy_redirect off;
  61. proxy_set_header X-Real-IP $remote_addr;
  62. proxy_set_header X-Scheme $scheme;
  63. proxy_pass http://frontends;
  64. }
  65. }
  66. }

Linux下Nginx的配置

 
  1. # user nobody nobody;
  2. worker_processes 1;
  3. #error_log /var/log/nginx/error.log;
  4. #pid /var/run/nginx.pid;
  5. events {
  6. worker_connections 1024;
  7. }
  8. http {
  9. # Enumerate all the Tornado servers here
  10. upstream frontends {
  11. server 127.0.0.1:8888;
  12. }
  13. include /usr/local/nginx/mime.types;
  14. default_type application/octet-stream;
  15. #access_log /var/log/nginx/access.log;
  16. keepalive_timeout 65;
  17. proxy_read_timeout 200;
  18. sendfile on;
  19. tcp_nopush on;
  20. tcp_nodelay on;
  21. gzip on;
  22. gzip_min_length 1000;
  23. gzip_proxied any;
  24. # Only retry if there was a communication error, not a timeout
  25. # on the Tornado server (to avoid propagating "queries of death"
  26. # to all frontends)
  27. proxy_next_upstream error;
  28. server {
  29. listen 80;
  30. # Allow file uploads
  31. client_max_body_size 50M;
  32. location ^~ /static/ {
  33. root /home/vonng/vserver;
  34. if ($query_string) {
  35. expires max;
  36. }
  37. }
  38. location ^~ /upload/ {
  39. root /home/vonng/vserver;
  40. if ($query_string) {
  41. expires max;
  42. }
  43. }
  44. location = /favicon.ico {
  45. access_log off;
  46. rewrite (.*) /static/other/favicon.ico;
  47. }
  48. location = /robots.txt {
  49. rewrite (.*) /static/other/robots.txt;
  50. }
  51. # Ali heartbeat dectection
  52. location = /status.taobao {
  53. access_log off;
  54. rewrite (.*) /static/other/status.taobao;
  55. }
  56. location / {
  57. proxy_pass_header Server;
  58. proxy_set_header Host $http_host;
  59. proxy_redirect off;
  60. proxy_set_header X-Real-IP $remote_addr;
  61. proxy_set_header X-Scheme $scheme;
  62. proxy_pass http://frontends;
  63. }
  64. }
  65. }
目录
相关文章
|
24天前
|
编解码 应用服务中间件 Linux
centos配置nginx-rtmp实现ffmpeg转码rtsp为rtmp视频流
centos配置nginx-rtmp实现ffmpeg转码rtsp为rtmp视频流
100 1
|
4月前
|
应用服务中间件 Linux 网络安全
Centos 8.0中Nginx配置文件和https正书添加配置
这是一份Nginx配置文件,包含HTTP与HTTPS服务设置。主要功能如下:1) 将HTTP(80端口)请求重定向至HTTPS(443端口),增强安全性;2) 配置SSL证书,支持TLSv1.1至TLSv1.3协议;3) 使用uWSGI与后端应用通信(如Django);4) 静态文件托管路径设为`/root/code/static/`;5) 定制错误页面(404、50x)。适用于Web应用部署场景。
614 87
|
5天前
|
Ubuntu 安全 应用服务中间件
详细指南:配置Nginx服务器在Ubuntu平台上
以上步骤涵盖了基本流程:从软件包管理器获取 Ngnix, 设置系统服务, 调整UFW规则, 创建并激活服务器块(也称作虚拟主机), 并进行了初步优化与加固措施。这些操作都是建立在命令行界面上,并假设用户具有必要权限(通常是root用户)来执行这些命令。每个操作都有其特定原因:例如,设置开机启动确保了即使重启后也能自动运行 Ngnix;而编辑server block则定义了如何处理进入特定域名请求等等。
93 18
|
7天前
|
Ubuntu 安全 应用服务中间件
详细指南:配置Nginx服务器在Ubuntu平台上
以上步骤涵盖了基本流程:从软件包管理器获取 Ngnix, 设置系统服务, 调整UFW规则, 创建并激活服务器块(也称作虚拟主机), 并进行了初步优化与加固措施。这些操作都是建立在命令行界面上,并假设用户具有必要权限(通常是root用户)来执行这些命令。每个操作都有其特定原因:例如,设置开机启动确保了即使重启后也能自动运行 Ngnix;而编辑server block则定义了如何处理进入特定域名请求等等。
68 17
|
4月前
|
负载均衡 应用服务中间件 nginx
Nginx配置与命令
Nginx 是一款高性能的 HTTP 和反向代理服务器,其配置文件灵活且功能强大。本文介绍了 Nginx 配置的基础结构和常用指令,包括全局块、Events 块、HTTP 块及 Server 块的配置方法,以及静态资源服务、反向代理、负载均衡、HTTPS 和 URL 重写等功能实现。此外,还提供了常用的 Nginx 命令操作,如启动、停止、重载配置和日志管理等,帮助用户高效管理和优化服务器性能。
|
1月前
|
数据建模 应用服务中间件 PHP
配置nginx容器和php容器协同工作成功,使用ip加端口的方式进行通信
本示例演示如何通过Docker挂载同一宿主目录至Nginx与PHP容器,实现PHP项目运行环境配置。需注意PHP容器中监听地址修改为0.0.0.0:9000,并调整Nginx配置中fastcgi_pass指向正确的IP与端口。同时确保Nginx容器中/var/www/html权限正确,以避免访问问题。
配置nginx容器和php容器协同工作成功,使用ip加端口的方式进行通信
|
2月前
|
应用服务中间件 网络安全 nginx
配置Nginx以支持Websocket连接的方法。
通过上述配置,Nginx将能够理解WebSocket协议的特殊要求,代理Websocket流量到合适的后端服务器。注意,Websocket并不是HTTP,尽管它最初是通过HTTP请求启动的连接升级,因此保证Nginx了解并能够妥善处理这种升级流程是关键。
533 10
|
1月前
|
Ubuntu 应用服务中间件 Linux
在Ubuntu上配置Nginx实现开机自启功能
至此,Nginx应该已经被正确地设置为开机自启。在Ubuntu中利用 `systemd`对服务进行管理是一种高效的方式,为系统管理员提供了强大的服务管理能力,包括但不限于启动、停止、重启服务,以及配置服务的开机自启动。通过这些简洁的命令,即使是对Linux不太熟悉的用户也能轻松地进行配置。
101 0
|
3月前
|
安全 应用服务中间件 网络安全
Nginx SSL/TLS协议栈中配置深度解析与实践指南-优雅草卓伊凡
Nginx SSL/TLS协议栈中配置深度解析与实践指南-优雅草卓伊凡
251 0
Nginx SSL/TLS协议栈中配置深度解析与实践指南-优雅草卓伊凡
|
3月前
|
JSON 前端开发 应用服务中间件
配置Nginx根据IP地址进行流量限制以及返回JSON格式数据的方案
最后,记得在任何生产环境部署之前,进行透彻测试以确保一切运转如预期。遵循这些战术,守卫你的网络城堡不再是难题。
186 3