nginx 反向代理 负载均衡
nginx反向代理
用户(浏览器) 请求网站资源 -> 直接定位到django后台(所有的请求压力,都直接给了后台)
django默认对并发性 很差,并且处理网页的静态资源,效率很差
10万个并发请求 -> 后台应用
用户 > nginx(天然并发性很高,并且处理静态资源css,js.jpg) ,静态资源,nginx直接从磁盘上返回 >
server{
listen 80;
server_name localhost.com;
location / {
root /opt/django_crm;
index index.html;
}
}
我们在/opt/django_crm中 ,放入一个图片 crm2.png
这是一个静态资源
localhost.com/crm.png ,如果找不到资源直接返回404
如果我发送了一个动态请求,(对数据库进行交互,必须有编程语言的支撑)
localhost.com/login/ -> django 后台,django这个编程语言框架,就可以对login请求处理
实现nginx反向代理的功能:
实验环境准备,2台机器
用户: 浏览器发起请求, 得到请求
192.168.15.71 nginx反向代理服务器(房屋中介代理)
192.168.15.73 真实资源服务器 (有房源的房东)
分别在 2 台机器上,安装nginx
先配置真实资源服务器,
192.168.15.73 打开这个机器的页面是吃鸡的网游页面
配置反向代理服务器
修改 **nginx.conf **
如下虚拟主机的加载,自上而下的加载,如果是访问的ip地址,永远访问第一个
#我们这个nginx服务器,不再是用作虚拟主机了
#而是直接转发别人的请求,是一个代理身份
server {
listen 80;
server_name s16chiji.com;
location / {
#root /opt/s16chiji;
#index index.html;
#当我的请求是 s16chiji.com的时候,这个nginx不做处理,直接转发请求给另一台机器
proxy_pass http://192.168.15.73;
}
#通过这个参数,定义错误页面的文件 ,当状态码是 404 400 401 时,返回40x.html页面
error_page 404 401 400 403 /40x.html;
}
nginx 脚本命令
nginx 直接输入是启动
nginx -s stop 停止
nginx -s reload 平滑重启,重新读取配置文件
.nginx.conf.swp 这个文件,是由于你在vim编辑文件的时候,异常退出,或者有其他人也想获取这个文件句柄,vim防止文件内容错乱,丢失,自动生成一个swp缓存文件,用于保护文件的
nginx负载均衡
负载 均衡 ,字面意思, 压力平摊
如何配置nginx,支持负载均衡
环境准备,准备3台机器
服务器1 nginx负载均衡器 192.168.15.71
服务器2 web应用资源1 192.168.15.73
服务器3 web应用资源2 39.96.68.102
配置负载军器 ,192.168.15.71 机器
nginx.conf,修改添加如下参数
这个参数,应该写在http{}内部,写在server{}以上
upstream s16backup {
server 192.168.15.75;
server 192.168.15.118;
}
第一个虚拟主机,修改配置如下
server {
listen 80;
server_name s16chiji.com;
location / {
#root /opt/s16chiji;
#index index.html;
#当我的请求是 s16chiji.com的时候,这个nginx不做处理,直接转发请求给另一台机器
#proxy_pass http://192.168.15.73;
#这个参数,转发给地址池
proxy_pass http://s16backup;
}
#通过这个参数,定义错误页面的文件 ,当状态码是
404 400 401 时,返回40x.html页面
error_page 404 401 400 403 /40x.html;
}
分别启动负载均衡器的nginx服务,以及两个资源服务器
nginx负载均衡算法
默认是轮训方式,你一次我一次
权重算法:
upstream django {
server 192.168.15.73 weight=2;
server 192.168.15.118 weight=8;
}
ip 哈希算法: ip哈希和权重不得公用
upstream django {
server 192.168.15.73 ;
server 192.168.15.118 ;
ip_hash;
}
nginx部署python程序
在进行项目部署的时候,如果报错
解决办法:
no application not found
就是因为你的uwsgi没找到django的wsgi.py应用文件为什么要用nginx uwsgi
因为用户只想访问 域名,不带有任何端口
通过nginx反向代理,用户直接访问 s16chiji.com ,但是nginx直接转发给了django,我们其实看到的页面是django
uwsgi是支持并发的 python web服务器,让你的django,并发性更高,但是uwsgi不支持静态文件的处理,静态文件会丢失用nginx处理静态文件,uwsgi处理动态请求
项目部署实验步骤
- nginx
- uwsgi+django
uwsgi 部署:
创建新的虚拟环境,且解决crm的环境依赖
在虚拟环境下安装uwsgi
pip3 install uwsgi
学习uwsgi命令,如何启动python应用
启动python web文件
创建一个test.py写入如下代码def application(env, start_response):
start_response('200 OK', [('Content-Type','text/html')])
return [b"Hello World"] # python3
用uwsgi启动一个python web文件
指定8000端口启动 http服务
指定wsgi文件
uwsgi --http :8000 --wsgi-file test.py
用uwsgi启动django项目
uwsgi --http :9000 --module Alibab_crm.wsgi
uwsgi加上热加载命令
uwsgi --http :8000 --module Alibab_crm.wsgi --py-autoreload=1
使用uwsgi配置文件去启动项目
- 手动创建uwsgi.ini 配置文件
(alicrm) [root@s16ds Alibab_crm]# cat uwsgi.ini mysite_uwsgi.ini file
# mysite_uwsgi.ini file
[uwsgi]
# Django-related settings
# the base directory (full path)
#指定django的项目目录,第一层
chdir = /opt/django_crm
# Django's wsgi file
#找到django的wsgi文件
#这里需要写项目的第二层目录Alibab_crm
module = django_crm.wsgi
# the virtualenv (full path)
#填写虚拟环境的绝对路径
home = /root/Envs/DjangoCRM
# process-related settings
# master
master = true
# maximum number of worker processes
processes = 5
# the socket (use the full path to be safe
#指定socket协议,运行django,只能与nginx结合时使用
#指定socket协议,运行django,只能与nginx结合时使用
#指定socket协议,运行django,只能与nginx结合时使用
socket = 0.0.0.0:8080
#如果你没用nginx,只想自己启动一个http界面,用这个
# http = 0.0.0.0:8000 # ... with appropriate permissions - may be needed
# chmod-socket = 664
# clear environment on exit
vacuum = true通过配置文件启动uwsgi
uwsgi --ini uwsgi.ini
收集django crm的静态文件
编辑crm的settings.py配置文件
写入如下代码定义django的静态资源根目录,便于用命令收集资源,存放的地儿
STATIC_ROOT="/opt/crm_static"
STATIC_URL = '/static/'
STATICFILES_DIRS = [
os.path.join(BASE_DIR, 'static')
]
用命令收集静态文件
python3 manage.py collectstatic
配置nginx,反响代理django服务器,且解析静态文件
proxy_pass 仅仅是请求转发的参数,与uwsgi结合,还有跟高级的协议参数
修改nginx配置文件如下
server {
listen 80;
server_name s16chiji.com;
location / {
root /opt/s16chiji;
index index.html;
# 使用uwsgi_pass 转发基于uwsgi协议的一个请求
uwsgi_pass 192.168.15.71:8000;
include /opt/nginx112/conf/uwsgi_params;
}
#配置一个url的入口,告诉django静态文件在哪里去找
#当请求url是 s16chiji.com/static/的时候
#就进行别名,nginx去/opt/crm_static下寻找js文件
location /static {
alias /opt/crm_static/;
}
#通过这个参数,定义错误页面的文件 ,当状态码是 404 400 401 时,返回40x.html页面
error_page 404 401 400 403 /40x.html;
error_page 500 502 503 504 /50x.html; }此时nginx结合uwsgi 已经完成
192.168.15.71
记住这里推出虚拟环境,使用物理环境去运行
nginx 反向代理 负载均衡的更多相关文章
- Nginx 反向代理 负载均衡 虚拟主机配置
Nginx 反向代理 负载均衡 虚拟主机配置 通过本章你将学会利用Nginx配置多台虚拟主机,清楚代理服务器的作用,区分正向代理和反向代理的区别,搭建使用Nginx反向搭理和负载均衡,了解Nginx常 ...
- Nginx 反向代理 负载均衡 虚拟主机
Nginx 反向代理 负载均衡 虚拟主机配置 通过本章你将学会利用Nginx配置多台虚拟主机,清楚代理服务器的作用,区分正向代理和反向代理的区别,搭建使用Nginx反向搭理和负载均衡,了解Nginx常 ...
- 十.nginx反向代理负载均衡服务实践部署
期中集群架构-第十章-nginx反向代理负载均衡章节章节====================================================================== 0 ...
- 【转】Nginx 反向代理 负载均衡 虚拟主机配置
原文:http://www.cnblogs.com/itdragon/p/8059000.html Nginx 反向代理 负载均衡 虚拟主机配置 通过本章你将学会利用Nginx配置多台虚拟主机,清楚代 ...
- Centos7.4 Nginx反向代理+负载均衡配置
Ningx是一款高性能的HTTP和反向代理服务器,配置起来也比较简单. 测试环境: 172.16.65.190 Nginx-反向代理 172.16.65.191 Ningx-Web 172.16.65 ...
- 如何使用Weave以及Docker搭建Nginx反向代理/负载均衡服务器
Hi, 今天我们将会学习如何使用 Weave 和 Docker 搭建 Nginx 的反向代理/负载均衡服务器.Weave 可以创建一个虚拟网络将 Docker 容器彼此连接在一起,支持跨主机部署及自动 ...
- 项目实战2.2—nginx 反向代理负载均衡、动静分离和缓存的实现
实验一:实现反向代理负载均衡且动静分离 1.环境准备: 机器名称 IP配置 服务角色 备注 nginx VIP:172.17.11.11 反向代理服务器 开启代理功能 设置监控,调度 rs01 RIP ...
- 项目实战2.1—nginx 反向代理负载均衡、动静分离和缓存的实现
总项目流程图,详见 http://www.cnblogs.com/along21/p/8000812.html 实验一:实现反向代理负载均衡且动静分离 1.环境准备: 机器名称 IP配置 服务角色 备 ...
- 项目实战02:nginx 反向代理负载均衡、动静分离和缓存的实现
目录 实验一:实现反向代理负载均衡且动静分离 1.环境准备: 2.下载编译安装tengine 3.设置代理服务器的配置文件 4.启动tengine服务 5.开启后端的web服务 6.测试 实验二:ng ...
- Centos 7.6配置nginx反向代理负载均衡集群
一,实验介绍 利用三台centos7虚拟机搭建简单的nginx反向代理负载集群, 三台虚拟机地址及功能介绍 192.168.2.76 nginx负载均衡器 192.168.2.82 web ...
随机推荐
- Linux服务器时间相关命令记录
前言 以往安装服务器时间都是正常,但是最近服务器的时间经常出现问题,所以在安装配置完成服务器之后需要对服务器的时间进行测试,如果服务器时间异常,那么当程序去取系统时间的时候就会出现问题. 时间相关命令 ...
- Java开发知识之Java编程基础
Java开发知识之Java编程基础 一丶Java的基础语法 每个语言都有自己的语法规范.例如C++ 入口点是main. 我们按照特定格式编写即可. Java也不例外. Java程序的语法规范就是 Ja ...
- Linux常用监控命令简介 – vmstat,ps,free,uptime 等
vmstat [-a] [-n] [delay [ count]]vmstat [-f] [-s] [-m]vmstat [-S unit]vmstat [-d]vmstat [-p disk par ...
- 微服务实战(二):使用API Gateway
微服务实战(一):微服务架构的优势与不足 微服务实战(二):使用API Gateway 微服务实战(三):深入微服务架构的进程间通信 微服务实战(四):服务发现的可行方案以及实践案例 微服务实践(五) ...
- [九]基础数据类型之Boolean详解
相对于其他的基础性 类型Boolean是很简单的 Boolean 基本数据类型boolean 的包装类 Boolean 类型的对象包含一个 boolean 类型的字段 属性简介 属性也比较 ...
- mac终端代理
终端代理,需要首先有自己的梯子,以下方式需要配合shadowsocks 终端FQ有很多好处,对于一个程序员来说,墙外有很多优秀的代码,走终端可以方便下载和使用- (编程思想强调复用,软件开发避免重复造 ...
- vue 双向数据绑定原理
博客地址: https://ainyi.com/8 采用defineProperty的两个方法get.set 示例 <!-- 表单 --> <input type="tex ...
- mongodb学习(入门。。。。。)
db.xs.insert({name:zhangsan}) db:当前数据库 xs:学生集合(没有的话自动创建) show collections 显示当前数据库的集合名字 show dbs ...
- sql 参数化查询问题
一.正确案例 string name=“梅”; string sql="select * from test where Name like @Name"; //包含 梅Sql ...
- 一种提升连接Dynamics 365性能的方法
关注本人微信和易信公众号: 微软动态CRM专家罗勇 ,回复256或者20170512可方便获取本文,同时可以在第一间得到我发布的最新的博文信息,follow me!我的网站是 www.luoyong. ...