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的反向代理负载均衡以及日志切割的更多相关文章

  1. 【05】Nginx:TCP / 正向 / 反向代理 / 负载均衡

    写在前面的话 在我们日常的工作中,不可能所有的服务都是简单的 HTML 静态网页,nginx 作为轻量级的 WEB 服务器,其实我们将它用于更多的地方还是作为我们网站的入口.不管你是后端接口,还是前端 ...

  2. nginx之rewrite重写,反向代理,负载均衡

    rewrite重写(伪静态): 在地址栏输入xx.com/user-xxx.html, 实际上访问的就是xxx.com/user.php?id=xxx rewrite就这么简单 附上ecshop re ...

  3. 如何使用Weave以及Docker搭建Nginx反向代理/负载均衡服务器

    Hi, 今天我们将会学习如何使用 Weave 和 Docker 搭建 Nginx 的反向代理/负载均衡服务器.Weave 可以创建一个虚拟网络将 Docker 容器彼此连接在一起,支持跨主机部署及自动 ...

  4. 项目实战2.2—nginx 反向代理负载均衡、动静分离和缓存的实现

    实验一:实现反向代理负载均衡且动静分离 1.环境准备: 机器名称 IP配置 服务角色 备注 nginx VIP:172.17.11.11 反向代理服务器 开启代理功能 设置监控,调度 rs01 RIP ...

  5. 项目实战2.1—nginx 反向代理负载均衡、动静分离和缓存的实现

    总项目流程图,详见 http://www.cnblogs.com/along21/p/8000812.html 实验一:实现反向代理负载均衡且动静分离 1.环境准备: 机器名称 IP配置 服务角色 备 ...

  6. 项目实战02:nginx 反向代理负载均衡、动静分离和缓存的实现

    目录 实验一:实现反向代理负载均衡且动静分离 1.环境准备: 2.下载编译安装tengine 3.设置代理服务器的配置文件 4.启动tengine服务 5.开启后端的web服务 6.测试 实验二:ng ...

  7. Nginx特性验证-反向代理/负载均衡/页面缓存/URL重定向

    原文发表于cu:2016-08-25 参考文档: Nginx 反向代理.负载均衡.页面缓存.URL重写等:http://freeloda.blog.51cto.com/2033581/1288553 ...

  8. 反向代理负载均衡-----nginx

    一:集群 1.1:集群的概念    集群是一组相互独立的.通过高速网络互联的计算机,他们构成了一个组,并以单一系统的模式加以管理.一个客户与集群相互作用时,集群像是一个独立的服务器.集群配置是用于提高 ...

  9. 反向代理负载均衡之nginx

    一.集群 1.1 什么是集群 集群是一组相互独立的.通过高速网络互联的计算机,它们构成了一个组,并以单一系统的模式加以管理.一个客户与集群相互作用时,集群像是一个独立的服务器.集群配置是用于提高可用性 ...

随机推荐

  1. Android Weekly Notes Issue #285

    November 26th, 2017 Android Weekly Issue #285 本周包含好几篇Kotlin的文章,如通过Property Delegate实现SharedPreferenc ...

  2. hdoj 4325 Flowers 线段树+离散化

    hdoj 4325 Flowers 题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4325 思路: 直接线段树,按照花的开放区间的大小建树,要注意虽然 ...

  3. JavaSE初步学习笔记

    PS:个人用来随时记录学习的过程,格式比较混乱,仅供个人参考与复习知识点 Dos命令行,课程中常见的命令 Dir:列出当前目录下包含的文件 Md:在当前目录下创建文件 Rd:在当前目录下删除指定文件夹 ...

  4. SketchMaster 隐私政策

    隐私政策 本应用尊重并保护所有使用服务用户的个人隐私权.为了给您提供更准确.更有个性化的服务,本应用会按照本隐私权政策的规定使用和披露您的个人信息.但本应用将以高度的勤勉.审慎义务对待这些信息.除本隐 ...

  5. Solr7.1---数据库导入并建立中文分词器

     这里只是告诉你如何导入,生产环境不要这样部署你的solr服务. 首先修改solrConfig.xml文件 备份_default文件夹 修改solrconfig.xml 加入如下内容 官方示例:< ...

  6. 异步编程Async/await关键字

    异步编程Async \await 关键字在各编程语言中的发展(出现)纪实. 时间 语言版本 2012.08.15 C#5.0(VS2012) 2015.09.13 Python 3.5 2016.03 ...

  7. Java爬虫——人人网模拟登录

    人人网登录地址:http://www.renren.com/ 此处登录没有考虑验证码验证码. 首先对登录方法进行分析 有两种方法. 一)在Elements中分析源码 发现登录点击后的事件是http:/ ...

  8. Linux网络编程--wireshark分析TCP包头的格式

    摘要:     本文简介了TCP面向连接理论知识,具体讲述了TCP报文各个字段含义.并从Wireshark俘获分组中选取TCP连接建立相关报文段进行分析. 一.概述     TCP是面向连接的可靠传输 ...

  9. HDU 5288 OO‘s sequence (技巧)

    题目链接:http://acm.hdu.edu.cn/showproblem.php? pid=5288 题面: OO's Sequence Time Limit: 4000/2000 MS (Jav ...

  10. ResourceBundle读取文件学习

    开发中,我们经常需要读取本地文件(properties文件),这样的好处是文件是动态的,可配置的.这时候我们就需要用到ResourceBundle这个类. 这个类属于java.util.*. 这个类的 ...