一. 安装nginx

  1.安装nginxz之前的依赖包

  1. yum install gcc patch libffi-devel python-devel zlib-devel
    bzip2-devel openssl-devel ncurses-devel sqlite-devel
    readline-devel tk-devel gdbm-devel db4-devel libpcap-devel
    xz-devel openssl openssl-devel -y

  2.源代码编译安装tenginx  (淘宝nginx)

  ①下载淘宝nginx的源代码包

  1. wget http://tengine.taobao.org/download/tengine-2.3.0.tar.gz

  

  ②解压缩源代码

  1. tar -zxvf tengine-2.3..tar.gz

  ③切换进入nginx 源代码目录,进行编译安装

  1. cd tengine-2.3.

  ④释放编译文件,指定编译安装

  1. ./configure --prefix=/opt/s18tngx/

  ⑤ 开始编译且安装

  1. make && make install

  ⑥若之前通过yum安装了 nginx ,进行卸载

  1. yum remove nginx -y

  ⑦查看nginx的安装目录

  1. conf 存放nginx的配置文件目录的
  2. html 存放前端文件的地儿
  3. logs 存放nginx日志文件的目录
  4. sbin 存放nginx的可执行命令

  ⑧ 配置环境变量

  1. 打开配置环境变量的文件:
  2.  
  3. vim /etc/profile
  4.  
  5. 进行配置添加:
  6.  
  7. /opt/s18tngx/sbin

  ⑨ 启动 nginx

  1. 直接输入 nginx 命令

  ⑩ 修改 nginx  的首页文件

  1. ①找到存放在nginx安装目录下的html文件夹中,
    名为index.html的文件
  2.  
  3. vim index.html
  4. 写入你想要的数据

二. nginx 配置文件

  https://www.cnblogs.com/wxbn/p/11764259.html

  1. 公祖房服务的nginx配置
  2.  
  3. upstream api{
  4. server 10.204.224.51:;
  5. }
  6. server {
  7. listen ;
  8. server_name _;
  9. #服务
  10. location / {
  11. client_max_body_size 100m;
  12. proxy_pass_header Server;
  13. proxy_set_header Host $http_host;
  14. proxy_redirect off;
  15. proxy_set_header X-Real-IP $remote_addr;
  16. proxy_set_header X-Scheme $scheme;
  17. proxy_pass http://api;
  18. }
  19. #静态文件
  20. location /static/img_p/imgUrl/ {
  21. alias /image/img_p/imgUrl/;
  22. autoindex on;
  23. autoindex_exact_size off;
  24. autoindex_localtime on;
  25. try_files $uri $uri/ =;
  26.  
  27. }
  28. location /static/img_p/idcardImgUrl/ {
  29. alias /image/img_p/idcardImgUrl/;
  30. autoindex on;
  31. autoindex_exact_size off;
  32. autoindex_localtime on;
  33. try_files $uri $uri/ =;
  34. }

  1.位置  

  1. conf 目录中 nginx.conf 文件

  2.文件解析

  1. ######Nginx配置文件nginx.conf中文详解#####
  2.  
  3. #定义Nginx运行的用户和用户组
  4. user www www;
  5.  
  6. #nginx进程数,建议设置为等于CPU总核心数。
  7. worker_processes ;
  8.  
  9. #全局错误日志定义类型,[ debug | info | notice | warn | error | crit ]
  10. error_log /usr/local/nginx/logs/error.log info;
  11.  
  12. #进程pid文件
  13. pid /usr/local/nginx/logs/nginx.pid;
  14.  
  15. #指定进程可以打开的最大描述符:数目
  16. #工作模式与连接数上限
  17. #这个指令是指当一个nginx进程打开的最多文件描述符数目,理论值应该是最多打开文件数
    ulimit -n)与nginx进程数相除,但是nginx分配请求并不是那么均匀,所以最好与ulimit -n
    的值保持一致。
  18. #现在在linux .6内核下开启文件打开数为65535,worker_rlimit_nofile
    就相应应该填写65535
  19. #这是因为nginx调度时分配请求到进程并不是那么的均衡,所以假如填写10240,
    总并发量达到3-4万时就有进程可能超过10240了,这时会返回502错误。
  20. worker_rlimit_nofile ;
  21.  
  22. events
  23. {
  24. #参考事件模型,use [ kqueue | rtsig | epoll | /dev/poll |
    select | poll ]; epoll模型
  25. #是Linux .6以上版本内核中的高性能网络I/O模型,linux建议epoll,
    如果跑在FreeBSD上面,就用kqueue模型。
  26. #补充说明:
  27. #与apache相类,nginx针对不同的操作系统,有不同的事件模型
  28. #A)标准事件模型
  29. #Select、poll属于标准事件模型,如果当前系统不存在更有效的方法,
    nginx会选择selectpoll
  30. #B)高效事件模型
  31. #Kqueue:使用于FreeBSD 4.1+, OpenBSD 2.9+, NetBSD 2.0 和 MacOS X.
    使用双处理器的MacOS X系统使用kqueue可能会造成内核崩溃。
  32. #Epoll:使用于Linux内核2.6版本及以后的系统。
  33. #/dev/poll:使用于Solaris /+,HP/UX 11.22+ (eventport),
    IRIX 6.5.+ Tru64 UNIX .1A+。
  34. #Eventport:使用于Solaris 。 为了防止出现内核崩溃的问题,
    有必要安装安全补丁。
  35. use epoll;
  36.  
  37. #单个进程最大连接数(最大连接数=连接数*进程数)
  38. #根据硬件调整,和前面工作进程配合起来用,尽量大,但是别把cpu跑到100%就行。
    每个进程允许的最多连接数,理论上每台nginx服务器的最大连接数为。
  39. worker_connections ;
  40.  
  41. #keepalive超时时间。
  42. keepalive_timeout ;
  43.  
  44. #客户端请求头部的缓冲区大小。这个可以根据你的系统分页大小来设置,
    一般一个请求头的大小不会超过1k,不过由于一般系统分页都要大于1k,所以这里设置为分页大小。
  45. #分页大小可以用命令getconf PAGESIZE 取得。
  46. #[root@web001 ~]# getconf PAGESIZE
  47. #
  48. #但也有client_header_buffer_size超过4k的情况,
    但是client_header_buffer_size该值必须设置为“系统分页大小”的整倍数。
  49. client_header_buffer_size 4k;
  50.  
  51. #这个将为打开文件指定缓存,默认是没有启用的,max指定缓存数量,建议和打开文件数一致,
    inactive是指经过多长时间文件没被请求后删除缓存。
  52. open_file_cache max= inactive=60s;
  53.  
  54. #这个是指多长时间检查一次缓存的有效信息。
  55. #语法:open_file_cache_valid time 默认值:open_file_cache_valid
    使用字段:http, server, location 这个指令指定了何时需要检查open_file_cache中缓存项目的有效信息.
  56. open_file_cache_valid 80s;
  57.  
  58. #open_file_cache指令中的inactive参数时间内文件的最少使用次数,如果超过这个数字,
    文件描述符一直是在缓存中打开的,如上例,如果有一个文件在inactive时间内一次没被使用,它将被移除。
  59. #语法:open_file_cache_min_uses number 默认值:open_file_cache_min_uses
    使用字段:http, server, location 这个指令指定了在open_file_cache指令无效的参数中
    一定的时间范围内可以使用的最小文件数,如果使用更大的值,文件描述符在cache中总是打开状态.
  60. open_file_cache_min_uses ;
  61.  
  62. #语法:open_file_cache_errors on | off 默认值:open_file_cache_errors off
    使用字段:http, server, location 这个指令指定是否在搜索一个文件是记录cache错误.
  63. open_file_cache_errors on;
  64. }
  65.  
  66. #设定http服务器,利用它的反向代理功能提供负载均衡支持
  67. http
  68. {
  69. #文件扩展名与文件类型映射表
  70. include mime.types;
  71.  
  72. #默认文件类型
  73. default_type application/octet-stream;
  74.  
  75. #默认编码
  76. #charset utf-;
  77.  
  78. #服务器名字的hash表大小
  79. #保存服务器名字的hash表是由指令server_names_hash_max_size
    server_names_hash_bucket_size所控制的。参数hash bucket size
    总是等于hash表的大小,并且是一路处理器缓存大小的倍数。在减少了在内存中的存取次数后,
    使在处理器中加速查找hash表键值成为可能。如果hash bucket size等于一路处理器缓存的大小,
    那么在查找键的时候,最坏的情况下在内存中查找的次数为2。第一次是确定存储单元的地址,
    第二次是在存储单元中查找键 值。因此,如果Nginx给出需要增大hash max size
    hash bucket size的提示,那么首要的是增大前一个参数的大小.
  80. server_names_hash_bucket_size ;
  81.  
  82. #客户端请求头部的缓冲区大小。这个可以根据你的系统分页大小来设置,
    一般一个请求的头部大小不会超过1k,不过由于一般系统分页都要大于1k
    所以这里设置为分页大小。分页大小可以用命令getconf PAGESIZE取得。
  83. client_header_buffer_size 32k;
  84.  
  85. #客户请求头缓冲大小。nginx默认会用client_header_buffer_size
    这个buffer来读取header值,如果header过大,
    它会使用large_client_header_buffers来读取。
  86. large_client_header_buffers 64k;
  87.  
  88. #设定通过nginx上传文件的大小
  89. client_max_body_size 8m;
  90.  
  91. #开启高效文件传输模式,sendfile指令指定nginx是否调用sendfile函数来输出文件,
    对于普通应用设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为off
    以平衡磁盘与网络I/O处理速度,降低系统的负载。注意:如果图片显示不正常把这个改成off
  92. #sendfile指令指定 nginx 是否调用sendfile 函数(zero copy 方式)来输出文件,
    对于普通应用,必须设为on。如果用来进行下载等应用磁盘IO重负载应用,可设置为off
    以平衡磁盘与网络IO处理速度,降低系统uptime
  93. sendfile on;
  94.  
  95. #开启目录列表访问,合适下载服务器,默认关闭。
  96. autoindex on;
  97.  
  98. #此选项允许或禁止使用socke的TCP_CORK的选项,此选项仅在使用sendfile的时候使用
  99. tcp_nopush on;
  100.  
  101. tcp_nodelay on;
  102.  
  103. #长连接超时时间,单位是秒
  104. keepalive_timeout ;
  105.  
  106. #FastCGI相关参数是为了改善网站的性能:减少资源占用,
    提高访问速度。下面参数看字面意思都能理解。
  107. fastcgi_connect_timeout ;
  108. fastcgi_send_timeout ;
  109. fastcgi_read_timeout ;
  110. fastcgi_buffer_size 64k;
  111. fastcgi_buffers 64k;
  112. fastcgi_busy_buffers_size 128k;
  113. fastcgi_temp_file_write_size 128k;
  114.  
  115. #gzip模块设置
  116. gzip on; #开启gzip压缩输出
  117. gzip_min_length 1k; #最小压缩文件大小
  118. gzip_buffers 16k; #压缩缓冲区
  119. gzip_http_version 1.0; #压缩版本(默认1.,
    前端如果是squid2.5请使用1.
  120. gzip_comp_level ; #压缩等级
  121. gzip_types text/plain application/x-javascript text/css application/xml;
    #压缩类型,默认就已经包含textml,所以下面就不用再写了,写上去也不会有问题,但是会有一个warn。
  122. gzip_vary on;
  123.  
  124. #开启限制IP连接数的时候需要使用
  125. #limit_zone crawler $binary_remote_addr 10m;
  126.  
  127. #负载均衡配置
  128. upstream jh.w3cschool.cn {
  129.  
  130. #upstream的负载均衡,weight是权重,可以根据机器配置定义权重。
    weigth参数表示权值,权值越高被分配到的几率越大。
  131. server 192.168.80.121: weight=;
  132. server 192.168.80.122: weight=;
  133. server 192.168.80.123: weight=;
  134.  
  135. #nginx的upstream目前支持4种方式的分配
  136. #、轮询(默认)
  137. #每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
  138. #、weight
  139. #指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。
  140. #例如:
  141. #upstream bakend {
  142. # server 192.168.0.14 weight=;
  143. # server 192.168.0.15 weight=;
  144. #}
  145. #、ip_hash
  146. #每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,
    可以解决session的问题。
  147. #例如:
  148. #upstream bakend {
  149. # ip_hash;
  150. # server 192.168.0.14:;
  151. # server 192.168.0.15:;
  152. #}
  153. #、fair(第三方)
  154. #按后端服务器的响应时间来分配请求,响应时间短的优先分配。
  155. #upstream backend {
  156. # server server1;
  157. # server server2;
  158. # fair;
  159. #}
  160. #、url_hash(第三方)
  161. #按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,
    后端服务器为缓存时比较有效。
  162. #例:在upstream中加入hash语句,server语句中不能写入weight等其他的参数,
    hash_method是使用的hash算法
  163. #upstream backend {
  164. # server squid1:;
  165. # server squid2:;
  166. # hash $request_uri;
  167. # hash_method crc32;
  168. #}
  169.  
  170. #tips:
  171. #upstream bakend{#定义负载均衡设备的Ip及设备状态}{
  172. # ip_hash;
  173. # server 127.0.0.1: down;
  174. # server 127.0.0.1: weight=;
  175. # server 127.0.0.1:;
  176. # server 127.0.0.1: backup;
  177. #}
  178. #在需要使用负载均衡的server中增加 proxy_pass http://bakend/;
  179.  
  180. #每个设备的状态设置为:
  181. #.down表示单前的server暂时不参与负载
  182. #.weight为weight越大,负载的权重就越大。
  183. #.max_fails:允许请求失败的次数默认为1.当超过最大次数时,
    返回proxy_next_upstream模块定义的错误
  184. #.fail_timeout:max_fails次失败后,暂停的时间。
  185. #.backup: 其它所有的非backup机器down或者忙的时候,
    请求backup机器。所以这台机器压力会最轻。
  186.  
  187. #nginx支持同时设置多组的负载均衡,用来给不用的server来使用。
  188. #client_body_in_file_only设置为On 可以讲client post过来
    的数据记录到文件中用来做debug
  189. #client_body_temp_path设置记录文件的目录 可以设置最多3层目录
  190. #location对URL进行匹配.可以进行重定向或者进行新的代理 负载均衡
  191. }
  192.  
  193. #虚拟主机的配置
  194. server
  195. {
  196. #监听端口
  197. listen ;
  198.  
  199. #域名可以有多个,用空格隔开
  200. server_name www.w3cschool.cn w3cschool.cn;
  201. index index.html index.htm index.php;
  202. root /data/www/w3cschool;
  203.  
  204. #对******进行负载均衡
  205. location ~ .*.(php|php5)?$
  206. {
  207. fastcgi_pass 127.0.0.1:;
  208. fastcgi_index index.php;
  209. include fastcgi.conf;
  210. }
  211.  
  212. #图片缓存时间设置
  213. location ~ .*.(gif|jpg|jpeg|png|bmp|swf)$
  214. {
  215. expires 10d;
  216. }
  217.  
  218. #JS和CSS缓存时间设置
  219. location ~ .*.(js|css)?$
  220. {
  221. expires 1h;
  222. }
  223.  
  224. #日志格式设定
  225. #$remote_addr与$http_x_forwarded_for用以记录客户端的ip地址;
  226. #$remote_user:用来记录客户端用户名称;
  227. #$time_local: 用来记录访问时间与时区;
  228. #$request: 用来记录请求的url与http协议;
  229. #$status: 用来记录请求状态;成功是200,
  230. #$body_bytes_sent :记录发送给客户端文件主体内容大小;
  231. #$http_referer:用来记录从那个页面链接访问过来的;
  232. #$http_user_agent:记录客户浏览器的相关信息;
  233. #通常web服务器放在反向代理的后面,这样就不能获取到客户的IP地址了,
    通过$remote_add拿到的IP地址是反向代理服务器的iP地址。反向代理服务器在转发请求的http头信息中,
    可以增加x_forwarded_for信息,用以记录原有客户端的IP地址和原来客户端的请求的服务器地址。
  234. log_format access '$remote_addr - $remote_user [$time_local] "$request" '
  235. '$status $body_bytes_sent "$http_referer" '
  236. '"$http_user_agent" $http_x_forwarded_for';
  237.  
  238. #定义本虚拟主机的访问日志
  239. access_log /usr/local/nginx/logs/host.access.log main;
  240. access_log /usr/local/nginx/logs/host.access..log log404;
  241.  
  242. #对 "/" 启用反向代理
  243. location / {
  244. proxy_pass http://127.0.0.1:88;
  245. proxy_redirect off;
  246. proxy_set_header X-Real-IP $remote_addr;
  247.  
  248. #后端的Web服务器可以通过X-Forwarded-For获取用户真实IP
  249. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  250.  
  251. #以下是一些反向代理的配置,可选。
  252. proxy_set_header Host $host;
  253.  
  254. #允许客户端请求的最大单文件字节数
  255. client_max_body_size 10m;
  256.  
  257. #缓冲区代理缓冲用户端请求的最大字节数,
  258. #如果把它设置为比较大的数值,例如256k,那么,无论使用firefox还是IE浏览器,
    来提交任意小于256k的图片,都很正常。如果注释该指令,使用默认的client_body_buffer_size设置,
    也就是操作系统页面大小的两倍,8k或者16k,问题就出现了。
  259. #无论使用firefox4.0还是IE8.,提交一个比较大,200k左右的图片,
    都返回500 Internal Server Error错误
  260. client_body_buffer_size 128k;
  261.  
  262. #表示使nginx阻止HTTP应答代码为400或者更高的应答。
  263. proxy_intercept_errors on;
  264.  
  265. #后端服务器连接的超时时间_发起握手等候响应超时时间
  266. #nginx跟后端服务器连接超时时间(代理连接超时)
  267. proxy_connect_timeout ;
  268.  
  269. #后端服务器数据回传时间(代理发送超时)
  270. #后端服务器数据回传时间_就是在规定时间之内后端服务器必须传完所有的数据
  271. proxy_send_timeout ;
  272.  
  273. #连接成功后,后端服务器响应时间(代理接收超时)
  274. #连接成功后_等候后端服务器响应时间_其实已经进入后端的排队之中等候处理
    (也可以说是后端服务器处理请求的时间)
  275. proxy_read_timeout ;
  276.  
  277. #设置代理服务器(nginx)保存用户头信息的缓冲区大小
  278. #设置从被代理服务器读取的第一部分应答的缓冲区大小,
    通常情况下这部分应答中包含一个小的应答头,默认情况下这个值的大小为指令proxy_buffers
    中指定的一个缓冲区的大小,不过可以将其设置为更小
  279. proxy_buffer_size 4k;
  280.  
  281. #proxy_buffers缓冲区,网页平均在32k以下的设置
  282. #设置用于读取应答(来自被代理服务器)的缓冲区数目和大小,
    默认情况也为分页大小,根据操作系统的不同可能是4k或者8k
  283. proxy_buffers 32k;
  284.  
  285. #高负荷下缓冲大小(proxy_buffers*)
  286. proxy_busy_buffers_size 64k;
  287.  
  288. #设置在写入proxy_temp_path时数据的大小,
    预防一个工作进程在传递文件时阻塞太长
  289. #设定缓存文件夹大小,大于这个值,将从upstream服务器传
  290. proxy_temp_file_write_size 64k;
  291. }
  292.  
  293. #设定查看Nginx状态的地址
  294. location /NginxStatus {
  295. stub_status on;
  296. access_log on;
  297. auth_basic "NginxStatus";
  298. auth_basic_user_file confpasswd;
  299. #htpasswd文件的内容可以用apache提供的htpasswd工具来产生。
  300. }
  301.  
  302. #本地动静分离反向代理配置
  303. #所有jsp的页面均交由tomcat或resin处理
  304. location ~ .(jsp|jspx|do)?$ {
  305. proxy_set_header Host $host;
  306. proxy_set_header X-Real-IP $remote_addr;
  307. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  308. proxy_pass http://127.0.0.1:8080;
  309. }
  310.  
  311. #所有静态文件由nginx直接读取不经过tomcat或resin
  312. location ~ .*.(htm|html|gif|jpg|jpeg|png|bmp|swf|ioc|rar|zip|txt|flv|mid|doc|ppt|
  313. pdf|xls|mp3|wma)$
  314. {
  315. expires 15d;
  316. }
  317.  
  318. location ~ .*.(js|css)?$
  319. {
  320. expires 1h;
  321. }
  322. }
  323. }
  324. ######Nginx配置文件nginx.conf中文详解#####
  325.  
  326. nginx.conf详解
  1. CoreModule核心模块
  2.  
  3. user www; #Nginx进程所使用的用户
  4. worker_processes ; #Nginx运行的work进程数量(建议与CPU数量一致或auto)
  5. error_log /log/nginx/error.log #Nginx错误日志存放路径
  6. pid /var/run/nginx.pid #Nginx服务运行后产生的pid进程号
  1. events事件模块
  2.  
  3. events {
  4. worker_connections //每个worker进程支持的最大连接数
  5. use epool; //事件驱动模型, epoll默认
  6. }
  1. http内核模块
  2.  
  3. //公共的配置定义在http{}
  4. http { //http层开始
  5. ...
  6. //使用Server配置网站, 每个Server{}代表一个网站(简称虚拟主机)
  7. 'server' {
  8. listen ; //监听端口, 默认80
  9. server_name localhost; //提供服务的域名或主机名
  10. access_log host.access.log //访问日志
  11. //控制网站访问路径
  12. 'location' / {
  13. root /usr/share/nginx/html; //存放网站代码路径
  14. index index.html index.htm; //服务器返回的默认页面文件
  15. }
  16. //指定错误代码, 统一定义错误页面, 错误代码重定向到新的Locaiton
  17. error_page /50x.html;
  18. }
  19. ...
  20. //第二个虚拟主机配置
  21. 'server' {
  22. ...
  23. }
  24.  
  25. include /etc/nginx/conf.d/*.conf; //包含/etc/nginx/conf.d/目录下所有以.conf结尾的文件
  26.  
  27. } //http层结束

三.配置  nginx 多虚拟主机

(使用不同的域名,访问同一个ip,返回不同页面)

  1. nginx多虚拟主机有俩概念
  2. .如果没有域名,写ip地址的话,虚拟主机是自上而下的加载顺序 ,
  3. .如果有域名,nginx会基于域名区分虚拟主机

  1.模仿域名

  ①配置Windows下的hosts文件

添加内容:

  2.修改配置文件  nginx.conf

  1. #第一个虚拟主机
    server {
  2. listen ;
  3. server_name www.s18dnf.com;    
  4. location / {
  5. root /opt/s18dnf/;   #存放的绝对路径
  6. index index.html index.htm;
  7. }
        }
  8. #第二个虚拟主机 韩剧网址
  9. server {
  10. listen ;
  11. server_name www.s18hanju.com;
  12. location / {
  13. root /opt/s18hanju/;
  14. index index.html;
  15. }
  16. }

  ③重新加载  nginx, (平滑重启)

  1. nginx -s reload

四.状态模块功能

  1.修改配置文件

  1. 找到要添加状态的server,添加如下配置
  2.  
  3. location /status {
  4. stub_status on;
  5. }

  2.重启nginx

  1. nginx -s reload

  3.通过  ab 压测命令.发起多个请求

  ①安装  ab 压测命令工具

  1. yum -y install httpd-tools

  ② 给 服务器,发起一万个请求

  1. ab -c -n http://106.13.49.215:6868/
  2. This is ApacheBench, Version 2.3 <$Revision: $>
  3. Copyright Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
  4. Licensed to The Apache Software Foundation, http://www.apache.org/
  5.  
  6. Benchmarking 106.13.49.215 (be patient)
  7. Completed requests
  8.  
  9. Server Software:
  10. Server Hostname: 106.13.49.215 #请求的URL主机名
  11. Server Port: #请求端口
  12.  
  13. Document Path: / #请求路径
  14. Document Length: bytes #HTTP响应数据的正文长度
  15.  
  16. Concurrency Level: #并发用户数,这是我们设置的参数之一
  17. Time taken for tests: 11.317 seconds #所有这些请求被处理完成所花费的总时间 单位秒
  18. Complete requests: #总请求数量,这是我们设置的参数之一
  19. Failed requests: #表示失败的请求数量
  20. (Connect: , Receive: , Length: , Exceptions: )
  21. Write errors:
  22. Total transferred: bytes #所有请求的响应数据长度总和。包括每个HTTP响应数据的头信息和正文数据的长度
  23. HTML transferred: bytes #所有请求的响应数据中正文数据的总和,也就是减去了Total transferred中HTTP响应数据中的头信息的长度
  24. Requests per second: 96.94 [#/sec] (mean) #吞吐量,计算公式:Complete requests/Time taken for tests 总请求数/处理完成这些请求数所花费的时间
  25. Time per request: 1031.611 [ms] (mean) #用户平均请求等待时间,计算公式:Time token for tests/(Complete requests/Concurrency Level)。处理完成所有请求数所花费的时间/(总请求数/并发用户数)
  26. Time per request: 10.316 [ms] (mean, across all concurrent requests) #服务器平均请求等待时间,计算公式:Time taken for tests/Complete requests,正好是吞吐率的倒数。也可以这么统计:Time per request/Concurrency Level
  27. Transfer rate: 489.68 [Kbytes/sec] received 表示这些请求在单位时间内从服务器获取的数据长度,计算公式:Total trnasferred/ Time taken for tests,这个统计很好的说明服务器的处理能力达到极限时,其出口宽带的需求量。
  28.  
  29. Connection Times (ms)
  30. min mean[+/-sd] median max
  31. Connect: 1148.7
  32. Processing: 415.3
  33. Waiting: 339.1
  34. Total: 1158.6
  35.  
  36. Percentage of the requests served within a certain time (ms)
  37. % #%的请求在88ms内返回
  38. %
  39. %
  40. %
  41. %
  42. %
  43. % #%的请求在4093ms内返回
  44. %
  45. % (longest request)

  1. ab -kc -n http://192.168.226.128/

  4.浏览器登录 

  1. www.xxxx.com/status

五.访问日志功能

  1.配置 nginx.conf 文件

  1. 打开如下注释
  2. log_format main '$remote_addr - $remote_user [$time_local] "$request" '
  3. '$status $body_bytes_sent "$http_referer" '
  4. '"$http_user_agent" "$http_x_forwarded_for"';
  5.  
  6. access_log logs/access.log main;
  7. access_log "pipe:rollback logs/access_log interval=1d baknum=7 maxsize=2G" main;

  2.重启

  1. nginx -s reload

  3.检测用户请求信息

  1. tail -f logs/access.log

六.修改 404页面

  1.配置 nginx.conf  文件

  1. 找到如下配置
  2. #当错误状态码是 40x系列就返回,nginx目录下的40x.html
  3. error_page /40x.html;

  2. 重启  nginx

  1. nginx -s reload

七.  限制 某个ip访问

  1.配置 nginx.conf 文件

  1. 找到nginx.conf修改如下代码
  2. location / {
  3. #禁止192.168.226./ 这个地址段所有的ip访问
  4. deny 192.168.226.1 ;
  5. root /opt/s18dnf;
  6. index index.html index.htm;
  7. }

  2.重启

  1. nginx -s reload

八. 反向代理

  1. 生活中见过什么代理?
  2. .租房的中介
  3.  
  4. .卖票的黄牛
  1. 准备2台机器
  2. 一个是真实资源文件 192.168.226.128 就理解为房东 ,提供dnf的资源界面
  3. 一个是反向代理服务器 192.168.226.129 理解为中介,当我们访问中介,就访问到dnf的网站资源
  4.  
  5. .分别在2台机器,安装nginx
  6.  
  7. .资源服务器已经配置好,返回dnf页面
  8.  
  9. .反向代理服务器配置如下
  10.  
  11. vim编辑nginx.conf 找到第一个server虚拟主机
  12. 修改配置如下
  13. location / {
  14. proxy_pass http://192.168.226.128;
  15. }
  16.  
  17. .重启nginx,查看反向代理效果

linux --- 5. nginx 初始的更多相关文章

  1. 【转】Linux下nginx配置https协议访问的方法

    一.配置nginx支持https协议访问,需要在编译安装nginx的时候添加相应的模块--with-http_ssl_module 查看nginx编译参数:/usr/local/nginx/sbin/ ...

  2. VMware Linux 下 Nginx

    负载   VMware Linux 下 Nginx 安装配置 - nginx.conf 配置 [负载两个 Tomcat] (三) Weiseditor 2014-11-26 23:42 阅读:1 评论 ...

  3. [Linux] PHP程序员玩转Linux系列-Nginx中的HTTPS

    1.PHP程序员玩转Linux系列-怎么安装使用CentOS 2.PHP程序员玩转Linux系列-lnmp环境的搭建 3.PHP程序员玩转Linux系列-搭建FTP代码开发环境 4.PHP程序员玩转L ...

  4. Linux+.NetCore+Nginx搭建集群

    本篇和大家分享的是Linux+NetCore+Nginx搭建负载集群,对于netcore2.0发布后,我一直在看官网的文档并学习,关注有哪些新增的东西,我,一个从1.0到2.0的跟随者这里只总结一句话 ...

  5. linux下Nginx配置文件(nginx.conf)配置设置详解(windows用phpstudy集成)

    linux备份nginx.conf文件举例: cp /usr/local/nginx/nginx.conf /usr/local/nginx/nginx.conf-20171111(日期) 在进程列表 ...

  6. 阿里云Linux服务器安装 nginx+mysql+php

    阿里云Linux服务器安装 nginx+mysql+php步骤1.登录服务器2.下载安装包3.将安装包上传到服务器的/home目录下 注:使用rz sz命令进行本地和服务器间的上传.下载,安装命令yu ...

  7. VMware Linux 下 Nginx 安装配置 - nginx.conf 配置 [负载两个 Tomcat] (三)

    首先启动Nginx 1. 相关浏览 两个 Tomcat 配置:  VMware Linux 下 Nginx 安装配置 - Tomcat 配置 (二) Nginx 安装配置启动: VMware Linu ...

  8. VMware Linux 下 Nginx 安装配置 - Tomcat 配置 (二)

    准备工作 相关浏览: VMware Linux 下 Nginx 安装配置 (一) 1. 选在 /usr/local/ 下创建 softs 文件夹,通过 ftp 命令 把 apache-tomcat-7 ...

  9. Linux中Nginx安装与配置详解

    转载自:http://www.linuxidc.com/Linux/2016-08/134110.htm Linux中Nginx安装与配置详解(CentOS-6.5:nginx-1.5.0). 1 N ...

随机推荐

  1. 浏览器调起Hbuilder的APP

           最近用Hbuilder来开发APP,测试各种功能,其中,最近测试到,要用这个浏览器调起APP的功能,我看官网有教程,但是有些可能刚工作没多久,所以,有些地方看不大明白,官方也没细说,所以 ...

  2. python爬虫工具

    一直都听说python写爬虫工具非常方便,为了获取数据,我也要写点爬虫,但是python太灵活了,不知道python爬虫要哪些框架,要了解,比如beatiful soup,scrapy, 爬虫的额主要 ...

  3. 发送消息-配置app_id

    $user_id = $curr_workitem["creater_id"]; $user_name = g('dao_user') -> get_by_id($user_ ...

  4. Laravel使用Form(转载)

    laravel到了5.1.*以上版本,便没有了illuminate/html类库的支持, 我试着把illuminate/html类库加入了laravel5.2,依然没有用, 但是laravelcoll ...

  5. cmder 常用配置(包括默认管理员运行和解决中文乱码)

    简介 cmder是一个增强型命令行工具,不仅可以使用windows下的所有命令,更爽的是可以使用linux的命令,shell命令. 下载 官网地址:http://cmder.net/ 下载的时候,会有 ...

  6. js设计模式(六)---组合模式

    组合模式将对象组合成树形结构,以表示“部分-整体”的层次结构.除了用来表示树形结构之外,组合模式的另一个好处是通过对象的多态性表现,使得用户对单个对象和组合对象的使用具有一致性.基本图例 1.组合模式 ...

  7. .NET Core 的 Span<T> 学习与使用笔记

    一.阅读材料 All About Span: Exploring a New .NET Mainstay Span<T> - byte to int conversions Span< ...

  8. rocketMQ安装部署详细解析

    近来研究了Apache开源项目rocketMQ(原为阿里项目),并在两台linux服务器上完成了部署,现在整理下,供大家参考学习. 一.简介rocketMQRocektMQ是阿里巴巴在2012年开源的 ...

  9. Java ee第一周的作业

    这学期目标:对Java ee 进行一定程度的学习,希望最后自己能尽可能掌握Java ee的知识 企业及应用的特点:企业级的应用通常比较庞大,而且其中的数据需要保密. Java ee 框架图

  10. python->读写excel

    from openpyxl import load_workbook#将一个excel文档中的数据存放内存中,即变量wb保存了该excel的所有信息wb = load_workbook(r" ...