(ng端口和目录的配置)
#Nginx用户及组:用户 组。window下不指定 在linux下可改为root
#user nobody;
#工作进程:数目。根据硬件调整,通常等于CPU数量或者2倍于CPU。
worker_processes 1;
#错误日志:存放路径。
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid(进程标识符):存放路径。
#pid logs/nginx.pid;
events {
#没个工作进程的最大连接数量。根据硬件调整,
#和前面工作进程配合起来用,尽量大,但是别把cpu跑到100%就行。
#每个进程允许的最多连接数,
#理论上每台nginx服务器的最大连接数为。worker_processes*worker_connections
worker_connections 1024;
}
#设定http服务器,利用它的反向代理功能提供负载均衡支持
http {
#设定mime类型,类型由mime.type文件定义
include mime.types;
default_type application/octet-stream;
#$remote_addr与$http_x_forwarded_for用以记录客户端的ip地址;
#$remote_user:用来记录客户端用户名称;
#$time_local: 用来记录访问时间与时区;
#$request: 用来记录请求的url与http协议;
#$status: 用来记录请求状态;成功是200,
#$body_bytes_sent :记录发送给客户端文件主体内容大小;
#$http_referer:用来记录从那个页面链接访问过来的;
#$http_user_agent:记录客户浏览器的相关信息;
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
#用了log_format指令设置了日志格式之后,需要用access_log指令指定日志文件的存放路径;
#access_log logs/access.log main;
#sendfile指令指定 nginx 是否调用sendfile 函数(zero copy 方式)来输出文件,
#对于普通应用,必须设为on。如果用来进行下载等应用磁盘IO重负载应用,可设置为off,
#以平衡磁盘与网络IO处理速度,降低系统uptime。
sendfile on;
#此选项允许或禁止使用socke的TCP_CORK的选项,此选项仅在使用sendfile的时候使用
#tcp_nopush on;
#keepalive超时时间
#keepalive_timeout 0;
keepalive_timeout 65;
#开启gzip压缩
#gzip on;
#配置虚拟机
server {
#配置监听端口
listen 80;
#配置访问域名
server_name localhost;
#charset koi8-r;
#设定本虚拟主机的访问日志
#access_log logs/host.access.log main;
#默认请求
location / {
##定义服务器的默认网站根目录位置
root html;
##定义首页索引文件的名称
index index.html index.htm;
}
#定义错误提示页面
#error_page 404 /404.html;
# redirect server error pages to the static page /50x.html
#
#定义错误提示页面
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
#禁止访问 .htxxx 文件
#location ~ /\.ht {
# deny all;
#}
}
# HTTPS 的配置
#
#server {
# listen 443 ssl;
# server_name localhost;
##ssl证书的pem文件路径
# ssl_certificate cert.pem;
#ssl证书的key文件路径
# ssl_certificate_key cert.key;
# ssl_session_cache shared:SSL:1m;
# ssl_session_timeout 5m;
#https默认请求
# location / {
# root html;
# index index.html index.htm;
# }
#}
(--------------------------------------------)
大致流程:
以页面输入云端项目访问地址开始,ng的配置文件里面
监听端口80的请求(http请求的默认端口是80)会自动指向虚拟机/usr目录下的用来解压的nginx文件夹下的html文件下的index.htmlx欢迎页面,因此,在浏览器输入以http地址的请求时会触发ng监听的端口,修改配置文件
location / {
root html;
index index.html index.htm;
}
root 指向的根目录文件(一般指向项目的根目录)
index 用来指向根目录下的index.html(项目首页html文件)
执行html文件后 html中的请求以.do结尾,会执行方向代理的被指向代理服务器
#配置反向代理
location ~ \.do$ {
//被代理服务器地址
proxy_pass http://tomcats;
}
指向这里
# 候选服务器
upstream tomcats {
//云端服务器IP地址:Tomcat默认端口
server 150.158.191.73:8080;
// 另一台云端服务器
server 101.34.42.47:8080;
// 通过ip地址值和服务器数量通过特殊的哈希算法得到哈希值,当一样的哈希值再次访问时会自动分配给已经执行过这个请求的服务器,避免session问题(例如 已经登录的请求发送数据请求,但是其他服务器没有进行第一次请求不能直接访问数据,会将请求驳回)
ip_hash;
}
nginx的主要作用 减少静态资源的重复请求和响应,反向代理,负载均衡
http服务器。Nginx是一个http服务可以独立提供http服务。可以做网页静态服务器。
2、 虚拟主机。可以实现在一台服务器虚拟出多个网站。例如个人网站使用的虚拟主机。
- 基于端口的,不同的端口
- 基于域名的,不同域名
3、 反向代理,负载均衡。当网站的访问量达到一定程度后,单台服务器不能满足用户的请求时,需要用多台服务器集群可以使用nginx做反向代理。并且多台服务器可以平均分担负载,不会因为某台服务器负载高宕机而某台服务器闲置的情况。
1)、轮询(默认)
每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
2)、weight
指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。
2)、ip_hash
每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。
请求被tomcat处理之后就可以正常运行了