Nginx (二) Nginx的反向代理负载均衡以及日志切割
Nginx是一个高并发,高性能的服务器,可以进行反向代理以及网站的负载均衡。这些功能的运用都在配置文件中,也就是Nginx安装目录下的conf/nginx.conf。
nginx.conf
1. 先来看下Nginx默认的配置文件以及说明:
#user nobody;
#----------------------------------------------
# user用来配置使用的用户和组,默认是没有进行配置的:
# 如下配置表示配置aries这个用户以及aries这个用户组:
# user aries aries
#----------------------------------------------
worker_processes ;
#----------------------------------------------
# worker_processes 用来配置Nginx开启的进程数,
# 一般配置等于cpu的核数。
#----------------------------------------------
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#---------------------------------------------
# error_log 全局错误日志配置,后面跟生成的
# 志文件的位置,默认在Nginx的logs
# 文件夹中,以及日志级别。
# [ debug | info | notice | warn | error | crit ]
#---------------------------------------------
#pid logs/nginx.pid;
#---------------------------------------------
# pid 当Nginx启动时会生成一个nginx.pid的文件,
# 里面存放的是Nginx主线程的id号。
#---------------------------------------------
#工作模式与连接数上限
events {
use epoll;
worker_connections ; #配置Nginx单个进程允许的最大连接数。
} #设定http服务器
http {
include mime.types; #文件扩展名与文件类型映射表
default_type application/octet-stream; # 默认文件类型 #log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
#access_log logs/access.log main;
#-----------------------------------------------------------------------
# log_format 配置日志格式,后面跟日志格式的名称和配置的格式,参数是Nginx中
# 一些内置的属性。
# access_log 配置日志的存放位置,以及后面跟日志打印格式内容。
# ----------------------------------------------------------------------
sendfile on; # 开启高效文件传输模式,sendfile指令指定nginx是否调用sendfile函数来输出文件
#tcp_nopush on; # 防止网络阻塞 #keepalive_timeout 0;
keepalive_timeout ; #gzip on;
# 配置开启gzip压缩
#虚拟主机的配置
server {
listen ;
# 监听端口
server_name localhost;
# 监听主机名称或者ip
#charset koi8-r;
# 默认编码
#access_log logs/host.access.log main;
# 日志
location / {
root html;
index index.html index.htm;
}
#-------------------------------------------------
# 配置的访问位置,默认是html目录下的index.html文件,
# 如果不存在则找index.htm文件
#------------------------------------------------- #error_page 404 /404.html;
#错误页面配置
# redirect server error pages to the static page /50x.html
#
error_page /50x.html;
location = /50x.html {
root html;
}
}
“http”表示配置的http协议的请求,里面可以配置多台server(虚拟主机),基本的配置格式如下:
...... event{ ...... } http{ ..... server { ...... } server { ...... } }
2. 下面配置负载均衡:
#user nobody;
worker_processes ; events {
use epoll;
worker_connections ;
} http {
include mime.types;
default_type application/octet-stream;
keepalive_timeout ; log_format mystyle '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"'; upstream mycomputers {
#upstream的负载均衡,weight是权重,可以根据机器配置定义权重;weigth参数表示权值,权值越大被分配到的几率越大;down表示当前主机不可用。
server 192.168.137.111: weight=;
server 192.168.137.114: weight= ;
server 192.168.137.113: weight= down;
} server {
listen ;
server_name localhost; location / {
proxy_pass http://mycomputers; # 将请求按照权重分配给上面配置的服务器
proxy_set_header X-UserRealIP-For $remote_addr;
# 因为用户请求服务,先到Nginx所以在服务端如果在服务端直接过去请求IP得到的是Nginx的主机,所以在这里去出用户的真实IP,设置在请求头中,服务端才可以获取用户的真实IP。
} access_log logs/access.log mystyle;
}
}
3. 反向代理配置
server {
listen ;
server_name localhost; location / {
proxy_pass http://192.168.137.114:; #代理的内部IP服务器
proxy_redirect off;
proxy_set_header X-Real-IP $remote_addr;
}
access_log logs/access.log mystyle;
}
4. 动静分离配置
server{
listen ;
server_name localhost; #本地动静分离反向代理配置
#所有jsp的页面均交由tomcat或其他服务器处理
location ~ \.(jsp|jspx|do)?$ {
proxy_pass http://127.0.0.1:;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
} #所有静态文件由nginx直接读取不经过tomcat或resin
location ~ .*\.(htm|html|gif|jpg|jpeg|png|bmp|swf|ioc|rar|zip|txt|flv|mid|doc|ppt|pdf|xls|mp3|wma)${
expires 15d;
} location ~ .*\.(js|css)?${
expires 1h;
}
}
5. Nginx日志的切割
a 写如下脚本存放到 /usr/local/nginx/sbin目录下命名nginx_cut_log.sh, 作用是暂停nginx服务并备份日志文件,然后重启。
#!/bin/bash
BASE_PATH=/usr/local/nginx
LOGS_PATH=${BASE_PATH}/logs
LOGS_PATH_BAK=${LOGS_PATH}/logs_bak
BAK_TIME=`/bin/date -d yesterday +%Y%m%d` $BASE_PATH/sbin/nginx -s stop mv $LOGS_PATH/access.log $LOGS_PATH_BAK/access_$BAK_TIME.log $BASE_PATH/sbin/nginx
给所有用户添加执行权限: chmod a+x nginx_cut_log.sh
b 输入: crontab -e
插入如下代码: 00 00 * * * sh /usr/local/nginx/nginx_cut_log.sh
此操作是让linux系统每天晚上12点整执行nginx_cut_log.sh脚本进行日志切割备份。
测试配置: */1 * * * * sh /usr/local/nginx/sbin/nginx_cut_log.sh 每分钟执行一次
BAK_TIME=`/bin/date -d yesterday +%Y%m%d%H%M`
效果如下:
以上都只是最基本的配置,还有其他各种细致的配置属性,推荐《nginx 实战》进行系统的了解和学习。
Nginx (二) Nginx的反向代理负载均衡以及日志切割的更多相关文章
- 【05】Nginx:TCP / 正向 / 反向代理 / 负载均衡
写在前面的话 在我们日常的工作中,不可能所有的服务都是简单的 HTML 静态网页,nginx 作为轻量级的 WEB 服务器,其实我们将它用于更多的地方还是作为我们网站的入口.不管你是后端接口,还是前端 ...
- nginx之rewrite重写,反向代理,负载均衡
rewrite重写(伪静态): 在地址栏输入xx.com/user-xxx.html, 实际上访问的就是xxx.com/user.php?id=xxx rewrite就这么简单 附上ecshop re ...
- 如何使用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 ...
- Nginx特性验证-反向代理/负载均衡/页面缓存/URL重定向
原文发表于cu:2016-08-25 参考文档: Nginx 反向代理.负载均衡.页面缓存.URL重写等:http://freeloda.blog.51cto.com/2033581/1288553 ...
- 反向代理负载均衡-----nginx
一:集群 1.1:集群的概念 集群是一组相互独立的.通过高速网络互联的计算机,他们构成了一个组,并以单一系统的模式加以管理.一个客户与集群相互作用时,集群像是一个独立的服务器.集群配置是用于提高 ...
- 反向代理负载均衡之nginx
一.集群 1.1 什么是集群 集群是一组相互独立的.通过高速网络互联的计算机,它们构成了一个组,并以单一系统的模式加以管理.一个客户与集群相互作用时,集群像是一个独立的服务器.集群配置是用于提高可用性 ...
随机推荐
- Web Mining and Big Data 公开课学习笔记 ---lecture1
1.1 LOOK Finding "stuff" on the web or computer or room or hidden in data Finding documen ...
- C# 使用Task实现任务超时,多任务一起执行
简介:充分使用Task的异步功能代码实现:1.实现了任务超时 退出任务 2.多个任务一起执行 /// <summary> ///做事 需要 ms秒 才能完成 / ...
- Ansible - 简介和应用自动化基础实践
installAnsible简介和应用自动化基础实践 一.引入: 1.1 如官方定义,Ansible is The simplest way to automate apps and IT infr ...
- Android 7.1 屏幕旋转流程分析
Android 7.1 屏幕旋转流程分析 一.概述 Android屏幕的旋转在framework主要涉及到三个类,结构如图 PhoneWindowManager:为屏幕的横竖屏转换的管理类. Wi ...
- JavaWeb学习总结(三)——Tomcat服务器学习和使用(二)(转)
转载自 http://www.cnblogs.com/xdp-gacl/p/3744053.html 一.打包JavaWeb应用 在Java中,使用"jar"命令来对将JavaWe ...
- KafkaManager中Group下不显示对应Topic的解决方案
一.软件版本 Kafka:0.8.2.1 KafkaManager:1.2.9.10 二.问题现象 点击Consumer下某个组,显示如下图所示的异常,查看KafkaManager的Applicati ...
- 利用linux shell自己主动顶贴
在论坛上面发帖问个什么东西的话,一旦不顶.帖子就秒沉了,可是又实在不想每时每刻都去顶,怎么办?以下展示了怎样利用shell 的crontab实现自己主动顶贴. 闲话不多说了,以豆瓣为例-– 1: 用c ...
- hdu 5305 friends
每一次比赛的时候脑子都卡顿, 这次更离谱,我居然二进制枚举边,这么大的复杂度.而且剪不了枝 后来学长说着是道爆搜.搜每一条边.恍然大悟. 仅仅须要剪掉点的度数是奇数的时候,或者他的线上朋友或线下朋友大 ...
- oracle实现主键自增
首先,创建一张表: CREATE TABLE example( ID Number(4) NOT NULL PRIMARY KEY, NAME VARCHAR(25)); 然后,自定义一个序列(seq ...
- XMind常用快捷方式汇总
快捷键(Windows) 快捷键(Mac) 描述 Ctrl+N Command+N 建立新工作簿 Ctrl+O Command+O 开启工作簿 Ctrl+S Command+S 储存目前工作簿 Ctr ...