设为首页 收藏本站
查看: 820|回复: 0

[经验分享] Nginx简要安装配置说明

[复制链接]
YunVN网友  发表于 2018-11-16 10:27:01 |阅读模式
  Nginx简要安装配置说明
  一. Nginx简介  
  Nginx是一款高性能的HTTP和反向代理服务器软件,可以运行在UNIX、GNU/Linux、BSD、Mac OS X、 Solaris 以及 Microsoft Windows等操作系统中。其优点是占用系统资源少,支持大并发连接(官方声称最大支持5万并发连接响应而只占2.5M内存);因其部署简单,配置灵活、高效、稳定的特点已被广泛应用于各大型网站架构中。
  二.安装  
  1).安装所需环境
gcc-c++ 、openssl-devel 、pcre-devel 、zlib-devel 、libtool  2).安装pcre,使Nginx支持rewrite模块
tar zxvf pcre-8.30.tar.gz  
cd pcre-8.30
  
make && make install
  3).安装Nginx
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).检查配置文件是否正确
/usr/local/nginx/sbin/nginx -t -c /usr/local/nginx/conf/nginx.conf  2).启动
/usr/local/nginx/sbin/nginx  3). 平滑重启
/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。
  如下图所示:
DSC0000.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;
  }
  }



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-635708-1-1.html 上篇帖子: nginx配置参数说明 下篇帖子: (总结)Nginx配置文件nginx.conf中文详解
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表