uwsgi的http和socket选项的区别

uwsgi配置文件中的http和socket的区别

配置HTTP

一般我们在配置python flask应用时都是使用http,让Nginx直接使用proxy_pass就把它从本地代理到前端服务器
当uwsgi配置http=127.0.0.1:5000时,我们可以如下设置Nginx进行代理

server{
	listen 80;
	location / {
		proxy_pass http://127.0.0.1:5000/ // 必须加http://
	}
}

此设定会将所有访问/的url映射到http://127.0.0.1:5000/,若将location改为/hello/那么所有访问/hello/的请求将会转发给http://127.0.0.1:5000/,这些可以理解为映射

配置socket

当uwsgi配置socket时,外部浏览器将无法直接访问,会提示类似于“缓存区(buffer)超过最大长度”类似的问题
此时使用nginx进行代理时,需要如下设置项:

server{
	litsen 80;
	location / {
		include uwsgi_param;
		uwsgi_pass 127.0.0.1:8081; #  socket对应的本地端口,注意socket不需要写http:// 因为socket不是HTTP的具体实现
	}
}

这样就可以直接将所有访问该服务器80端口的url转给uwsgi处理,例如访问http://*./hello就相当于访问了http://127.0.0.1:8081/hello,nginx和uwsgi就是通过这个socket进行通信

<< 确实,初次接触 Gunicorn uWSGI 可能会觉得它们设置起来有些复杂。不过一旦理解了基本概念配置流程,你会发现它们其实并不难掌握。这里简要介绍这两个工具以及如何简化它们的使用。 ### 简化 Gunicorn uWSGI 的使用 #### 1. Gunicorn (Green Unicorn) - **简介**: Gunicorn 是一个 Python WSGI HTTP Server,专门用于 Unix 平台上的 Web 应用程序。它是一个轻量级、易于使用的服务器解决方案。 - **安装**: ```bash pip install gunicorn ``` - **快速启动**: 对于大多数 Django 项目来说,可以通过一条简单的命令启动 Gunicorn: ```bash gunicorn myproject.wsgi:application ``` - **常用选项**: - `-b [IP]:[PORT]`: 绑定 IP 地址及端口号,默认绑定到 `127.0.0.1:8000`。 - `-w NUM_WORKERS`: 工作进程数,默认为 `(CPU 核心数量 + 1)`。 - `-k worker_class`: 设置工作模式(默认同步)。常用的异步模式有 `gevent`, `meinheld.gmeinheld.MeinheldWorker`等。 ##### 示例:带参数启动 Gunicorn ```bash gunicorn --bind 0.0.0.0:8000 --workers 3 myproject.wsgi:application ``` 这样就绑定了所有网络接口,并指定了三个工人进程。 #### 2. uWSGI - **简介**: uWSGI 是一个多协议应用程序容器服务器,支持多种语言的应用部署,包括 Python WSGI 应用。 - **安装**: 安装 uwsgi 最直接的方法也是通过 pip: ```bash pip install uwsgi ``` - **简易启动**: 类似于 Gunicorn,uWSGI 提供了一个非常方便的方式来进行即时测试或简单部署: ```bash uwsgi --http :8000 --module myproject.wsgi ``` 上述命令会在本地监听 8000 端口并通过 http 协议提供服务。 - **配置文件方式**: 更复杂的场景下推荐使用配置文件 (`ini`, `xml`, `yaml`) 来管理传递大量配置项给 uWSGI。下面是一个基础的 INI 配置示例: ```ini [uwsgi] chdir = /path/to/your/project/ module = myproject.wsgi:application master = true processes = 5 socket = 127.0.0.1:9001 vacuum = true ``` 然后可以用以下命令根据此配置运行: ```bash uwsgi --ini myproject_uwsgi.ini ``` ### 简化技巧 为了进一步简化 Gunicorn 或者 uWSGI 的使用,考虑以下几个小贴士: - **利用虚拟环境**:始终在一个隔离的环境中操作依赖库,避免全局包冲突的问题。 - **借助 Docker**:如果不想在主机上折腾太多配置,可以尝试把应用打包成 Docker 容器,在里面预设好所有的依赖服务配置。 - **自动化脚本**:编写 shell 脚本来自动处理常见的任务,例如初始化数据库、收集静态资源等。 - **阅读官方文档**:虽然看起来可能一开始会让人感到不知所措,但官方文档往往是最好的参考资料之一,通常包含了很多实用的例子技术细节。 总之,尽管刚开始时可能会觉得有点麻烦,但是掌握了正确的配置方法之后,Gunicorn uWSGI 实际上是非常强大而且稳定的生产级别的工具!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

妖怪喜欢风

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值