Nginx简要安装配置说明

简介:

           Nginx简要安装配置说明 

 

一. Nginx简介  

Nginx是一款高性能的HTTP和反向代理服务器软件,可以运行在UNIX、GNU/Linux、BSD、Mac OS X、 Solaris 以及 Microsoft Windows等操作系统中。其优点是占用系统资源少,支持大并发连接(官方声称最大支持5万并发连接响应而只占2.5M内存);因其部署简单,配置灵活、高效、稳定的特点已被广泛应用于各大型网站架构中。

  

二.安装  

1).安装所需环境 

1
gcc-c++ 、openssl-devel 、pcre-devel 、zlib-devel 、libtool

 

2).安装pcre,使Nginx支持rewrite模块  

1
2
3
  tar  zxvf pcre-8.30. tar .gz 
  cd  pcre-8.30 
  make  &&  make  install

3).安装Nginx 

1
2
  tar  zxvf nginx-1.2.3. tar .gz   cd  nginx-1.2.3 
  . /configure  --user=www --group=www --prefix= /usr/local/nginx  --with-http_gzip_static_module --with-http_ssl_module

编译时可根据实际需要进行编译所需要的模块,用./configure –help查看可编译的模块  

三.常用命令  

1).检查配置文件是否正确 

1
/usr/local/nginx/sbin/nginx  -t -c  /usr/local/nginx/conf/nginx .conf

2).启动 

1
/usr/local/nginx/sbin/nginx

3). 平滑重启 

1
/usr/local/nginx/sbin/nginx  -s reload

四.配置 

1).配置文件结构 

Nginx的配置文件是一个纯文本文件,它一般位于Nginx安装目录的conf目录下,整个配置文件是以block的形式组织的。每个block一般以一个大括号“{}”来表示,block可以分为几个层次,整个配置文件中main指令位于最高层,在main层下面可以有Events、HTTP等层级,而在HTTP层中又包含有server层,即server block,server block中又可分为location层,并且一个server block中可以包含多个location block。

如下图所示:

wKioL1nKBlrApgzVAAGunO6xiQU714.png


Nginx配置文件主要分为4部分:main(全局设置)、server(主机设置)、upstream(负载均衡服务器设置)和 location(URL匹配特定位置的设置)

main部分设置的指令将影响其他所有设置;

server部分的指令主要用于指定主机和端口;

upstream指令主要用于负载均衡,设置一系列的后端服务器;

location部分用于匹配网页位置。

这四者之间的关系如下:server继承main,location继承server,upstream既不会继承其他设置也不会被继承。 

在这4个部分当中,每个部分都包含若干指令,这些指令主要包含Nginx的主模块指令、事件模块指令、HTTP核心模块指令。同时每个部分还可以使用其他HTTP模块指令,例如Http SSL模块、Http Gzip Static模块和Http Addition模块等。  


2).配置实例

main部分(全局属性配置) 

user  www www;   #指定Nginx Worker进程运行用户以及用户组 

worker_processes 2; #指定了Nginx要开启的进程数,多核CPU指定和核数一样多的进程数 

pid     logs/nginx.pid; #指定进程id的存储文件位置 

worker_rlimit_nofile 65535; #指定单进程打开文件数,需与系统设定一致  

events {

     use epoll;   #指定nginx工作模式,nginx主要的工作模式有select、poll、kqueue、epoll 其中select、poll是标准工作模式,kqueue、epoll为高效工作模式,epoll 用在Linux系统中,而kqueue用在BSD系统中

     worker_connections  65535;#指定单进程的最大连接数 

}

HTTP部分  

http {

    include       mime.types;           #指定配置文件所包含的文件 

    default_type  application/octet-stream; #指定默认类型为二进制流,也就是当文件类型未

定义时使用这种方式,例如在没有配置PHP环境时,Nginx是不予解析的,此时,用浏览器访问PHP文件就会出现下载窗口 

 

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '#设定日志格式               '$status $body_bytes_sent "$http_referer" '

                  '"$http_user_agent" "$http_x_forwarded_for"';;        

    client_max_body_size  20m;     #设置允许客户端请求的最大的单个文件字节数 

    client_header_buffer_size  16k;  # 指定来自客户端请求头的headerbuffer大小,如果自

定义了消息头或有更大的cookie,可以在这里增加缓冲大小 

    large_client_header_buffers  4 32k;# 指定客户端请求中较大的消息头的缓存最大数量

和大小,4为个数,32k为大小,最大缓存为4个32kb 

 

    sendfile        on;#开启高效传输模式 

    tcp_nopush       on;  # tcp_nopush,tcp_nodelay设置on,防止网络阻塞             tcp_nodelay      on;

    keepalive_timeout  65; #指定客户端连接保持活动的超时时间 

    client_header_timeout  10;#指定客户端请求头读取超时时间,如果超过这个时间,客户

端还没有发送任何数据,Nginx将返回“Request time out(408)”错误 

    client_body_timeout   10;#指定客户端请求主体读取超时时间,如果超过这个时间,客

户端还没有发送任何数据,Nginx将返回“Request time out(408)”错误 

    send_timeout         10;# 指定响应客户端的超时时间。这个超时仅限于两个连接活

动之间的时间,如果超过这个时间,客户端没有任何活动,Nginx将会关闭连接 

  

    gzip  on;            #开启gzip压缩,实时压缩输出数据流 

    gzip_min_length  1k;    #设置允许压缩的页面最小字节数 

    gzip_buffers     4  16k; #指定内存空间来存贮压缩结果,这里指定4个单位为16k的

内存来存储压缩结果,即总大小为64k 

    gzip_http_version  1.1;   #指定识别HTTP协议版本,默认是1.1     

    gzip_comp_level  2;      # 指定gzip压缩比,1 压缩比最小,处理速度最快;9 压缩比最大,传输速度快,但处理最慢,也比较消耗CPU资源 

    gzip_types  text/plain application/x-javascript text/css application/xml;# 指定压缩的类型,无论是否指定,“text/html”类型总是会被压缩 

    gzip_vary  on;         #该选项开启可以让前端的缓存服务器缓存经过gzip压缩的页面,例如,用Varnish缓存经过Nginx压缩的数据 

 

   server_tokens off;         #隐藏Nginx版本号  

   server { 

        listen       8000; #指定Nginx监端口 

        server_name  localhost;#用来指定IP或者域名  

        charset utf-8;      #指定Nginx默认的字符集,只有utf-8支持中文字符              access_log  logs/host.access.log  main;#指定访问日志的名称及位置  

        location / { 

            index  index.html index.htm;#设定默认首页             

            root /tom/webapps/ROOT;     #指定网页根目录         

            }  

            location ~ (jsp|\?) {      #指定url中包含jsp或者?的全部转发到192.168.0.10的80端口即tomcat处理 

            proxy_pass   http://192.168.0.10:80;         

            }

}










本文转自 蓝叶子Sheep 51CTO博客,原文链接:http://blog.51cto.com/dellinger/1968878,如需转载请自行联系原作者
目录
相关文章
|
1月前
|
缓存 应用服务中间件 网络安全
Nginx中配置HTTP2协议的方法
Nginx中配置HTTP2协议的方法
79 7
|
2月前
|
应用服务中间件 BI nginx
Nginx的location配置详解
【10月更文挑战第16天】Nginx的location配置详解
|
2月前
|
缓存 负载均衡 安全
Nginx常用基本配置总结:从入门到实战的全方位指南
Nginx常用基本配置总结:从入门到实战的全方位指南
325 0
|
4天前
|
存储 应用服务中间件 nginx
nginx反向代理bucket目录配置
该配置实现通过Nginx代理访问阿里云OSS存储桶中的图片资源。当用户访问代理域名下的图片URL(如 `http://代理域名/123.png`)时,Nginx会将请求转发到指定的OSS存储桶地址,并重写路径为 `/prod/files/2024/12/12/123.png`。
32 5
|
28天前
|
缓存 负载均衡 算法
如何配置Nginx反向代理以实现负载均衡?
如何配置Nginx反向代理以实现负载均衡?
|
1月前
|
存储 负载均衡 中间件
Nginx反向代理配置详解,图文全面总结,建议收藏
Nginx 是大型架构必备中间件,也是大厂喜欢考察的内容,必知必会。本篇全面详解 Nginx 反向代理及配置,建议收藏。
Nginx反向代理配置详解,图文全面总结,建议收藏
|
19天前
|
负载均衡 前端开发 应用服务中间件
负载均衡指南:Nginx与HAProxy的配置与优化
负载均衡指南:Nginx与HAProxy的配置与优化
39 3
|
1月前
|
应用服务中间件 API nginx
nginx配置反向代理404问题
【10月更文挑战第18天】本文介绍了使用Nginx进行反向代理的配置方法,解决了404错误、跨域问题和302重定向问题。关键配置包括代理路径、请求头设置、跨域头添加以及端口转发设置。通过调整`proxy_set_header`和添加必要的HTTP头,实现了稳定的服务代理和跨域访问。
243 1
nginx配置反向代理404问题
|
28天前
|
负载均衡 监控 应用服务中间件
配置Nginx反向代理时如何指定后端服务器的权重?
配置Nginx反向代理时如何指定后端服务器的权重?
49 4
|
28天前
|
安全 应用服务中间件 网络安全
如何测试Nginx反向代理实现SSL加密访问的配置是否正确?
如何测试Nginx反向代理实现SSL加密访问的配置是否正确?
52 3
下一篇
DataWorks