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,如需转载请自行联系原作者
目录
相关文章
|
22天前
|
运维 前端开发 应用服务中间件
LNMP详解(八)——Nginx动静分离实战配置
LNMP详解(八)——Nginx动静分离实战配置
24 0
|
1月前
|
应用服务中间件 nginx
Nginx中如何配置中文域名?
Nginx中如何配置中文域名?
40 0
|
21天前
|
前端开发 应用服务中间件 nginx
Nginx配置详解Docker部署Nginx使用Nginx部署vue前端项目
Nginx配置详解Docker部署Nginx使用Nginx部署vue前端项目
85 0
|
1天前
|
安全 应用服务中间件 网络安全
SSL原理、生成SSL密钥对、Nginx配置SSL
现在,你的Nginx虚拟主机应该已经配置了SSL,可以通过HTTPS安全访问。确保在生产环境中使用有效的SSL证书来保护通信的安全性。
8 0
|
4天前
|
域名解析 缓存 负载均衡
Nginx正向代理域名的配置
Nginx正向代理域名的配置
|
4天前
|
前端开发 JavaScript 应用服务中间件
修改Jeecg-boot context-path(附加图片+Nginx配置)
修改Jeecg-boot context-path(附加图片+Nginx配置)
12 0
|
5天前
|
应用服务中间件 nginx
yum 安装报错 No package nginx available Error:Nothing to do
yum 安装报错 No package nginx available Error:Nothing to do
14 1
|
15天前
|
应用服务中间件 nginx
nginx进行反向代理的配置
在Nginx中设置反向代理的步骤:编辑`/etc/nginx/nginx.conf`,在http段加入配置,创建一个监听80端口、服务器名为example.com的虚拟主机。通过`location /`将请求代理到本地3000端口,并设置代理头。保存配置后,使用`sudo nginx -s reload`重载服务。完成配置,通过example.com访问代理服务器。
22 0
|
16天前
|
应用服务中间件 网络安全 nginx
nginx配置https访问
nginx配置https访问
26 0
|
25天前
|
应用服务中间件 nginx
nginx配置访问qicaitun.com强制跳转www.qicaitun.com
nginx配置访问qicaitun.com强制跳转www.qicaitun.com
9 0