- 浏览: 1230956 次
- 性别:
- 来自: 上海
文章分类
最新评论
-
lankk:
lankk 写道事实上,在运行String s1=new St ...
理解String 及 String.intern() 在实际中的应用 -
lankk:
事实上,在运行String s1=new String(&qu ...
理解String 及 String.intern() 在实际中的应用 -
lankk:
同意1楼的说法http://docs.oracle.com/j ...
理解String 及 String.intern() 在实际中的应用 -
raoyutao:
...
jdk 线程池 ThreadPoolExecutor -
hongdanning:
理解了。之前困惑的一些明白了。谢谢分享。
理解String 及 String.intern() 在实际中的应用
通过查看Nginx的并发连接,我们可以更清除的知道网站的负载情况。Nginx并发查看有两种方法(之所以这么说,是因为笔者只知道两种),一种是通过
web界面,一种是通过命令,web查看要比命令查看显示的结果精确一些。下面介绍这两种查看方法
No1、通过浏览器查看
通过web界面查看时Nginx需要开启status模块,也就是安装Nginx时加上
--with-http_stub_status_module 然后配置Nginx.conf,在server点里面加入如下内容
stub_status on;
access_log /usr/local/nginx/logs/status.log;
auth_basic "NginxStatus"; }
配置完后重新启动Nginx后我们可以通过浏览器访问http://localhost/status 查看,如下图
解析:
Active connections //当前 Nginx
正处理的活动连接数。
server accepts handled
requests //总共处理了8 个连接 , 成功创建 8 次握手,总共处理了500个请求。
Reading //nginx
读取到客户端的 Header 信息数。
Writing //nginx 返回给客户端的 Header 信息数。
Waiting
//开启 keep-alive 的情况下,这个值等于 active - (reading + writing),意思就是 Nginx
已经处理完正在等候下一次请求指令的驻留连接
No2、通过命令查看
#netstat -n | awk '/^tcp/ {++S[$NF]} END
{for(a in S) print a, S[a]}'
ESTABLISHED 3254
LAST_ACK 236
FIN_WAIT_1 648
FIN_WAIT_2 581
CLOSING 7
CLOSE_WAIT 4916
解析:
CLOSED //无连接是活动的或正在进行
LISTEN //服务器在等待进入呼叫
SYN_RECV //一个连接请求已经到达,等待确认
SYN_SENT //应用已经开始,打开一个连接
ESTABLISHED //正常数据传输状态/当前并发连接数
FIN_WAIT1 //应用说它已经完成
FIN_WAIT2 //另一边已同意释放
ITMED_WAIT //等待所有分组死掉
CLOSING //两边同时尝试关闭
TIME_WAIT //另一边已初始化一个释放
LAST_ACK //等待所有分组死掉
============================================================
http://blog.s135.com/nginx_php_v5/
产品 网站数
Apache 84,309,103
IIS 60,987,087
Google GFE 10,465,178
Unknown 4,903,174
nginx 2,125,160
Oversee 1,953,848
lighttpd 1,532,952
关于这期调查报告的更详细信息请看下面链接:
2、 Nginx 本身只是一个 HTTP 和反向代理服务器,它无法像 Apache 一样通过安装各种模块来支持不同的页面脚本,例如 PHP、CGI 等;
3、Nginx 支持简单的负载均衡和容错;
4、支持作为基本 HTTP 服务器的功能,例如日志、压缩、Byte ranges、Chunked responses、SSL、虚拟主机等等,应有尽有。
在 Linux 下安装 Nginx
# tar zxvf pcre-7.7.tar.gz
# cd pcre-7.7
# ./configure
# make
# make install
接下来安装 Nginx,Nginx 一般有两个版本,分别是稳定版和开发版,您可以根据您的目的来选择这两个版本的其中一个,下面是把 Nginx 安装到 /opt/nginx 目录下的详细步骤:
# tar zxvf nginx-0.6.31.tar.gz
# cd nginx-0.6.31
# ./configure --with-http_stub_status_module –prefix=/opt/nginx
# make
# make install
其中参数 --with-http_stub_status_module 是为了启用 nginx 的 NginxStatus 功能,用来监控 Nginx 的当前状态。
通过信号对 Nginx 进行控制
TERM, INT 快速关闭程序,中止当前正在处理的请求
QUIT 处理完当前请求后,关闭程序
HUP 重新加载配置,并开启新的工作进程,关闭就的进程,此操作不会中断请求
USR1 重新打开日志文件,用于切换日志,例如每天生成一个新的日志文件
USR2 平滑升级可执行程序
WINCH 从容关闭工作进程
有两种方式来通过这些信号去控制 Nginx,第一是通过 logs 目录下的 nginx.pid 查看当前运行的 Nginx 的进程 ID,通过 kill – XXX <pid> 来控制 Nginx,其中 XXX 就是上表中列出的信号名。如果您的系统中只有一个 Nginx 进程,那您也可以通过 killall 命令来完成,例如运行 killall – s HUP nginx 来让 Nginx 重新加载配置。
worker_processes 4;# 工作进程数,一般与 CPU 核数等同
#error_log logs/error.log notice;
#error_log logs/error.log info;
use epoll;#Linux 下性能最好的 event 模式
worker_connections 2048;# 每个工作进程允许最大的同时连接数
}
include mime.types;
default_type application/octet-stream;
# '"$status" $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
access_log logs/access.log;# 日志文件名
#tcp_nopush on;
tcp_nodelay on;
# 集群中的所有后台服务器的配置信息
upstream tomcats {
server 192.168.0.11:8080 weight=10;
server 192.168.0.11:8081 weight=10;
server 192.168.0.12:8080 weight=10;
server 192.168.0.12:8081 weight=10;
server 192.168.0.13:8080 weight=10;
server 192.168.0.13:8081 weight=10;
}
listen 80;#HTTP 的端口
server_name localhost;
stub_status on; #Nginx 状态监控配置
access_log off;
}
deny all;
}
zip|java|jar|txt|flv|swf|mid|doc|ppt|xls|pdf|txt|mp3|wma)$ {
root /opt/webapp;
expires 24h;
}
#
error_page 502 503 /html/502.html;
error_page 500 504 /50x.html;
location = /50x.html {
root html;
}
}
}
Nginx 监控
server accepts handled requests
14553819 14553819 19239266
Reading: 0 Writing: 3 Waiting: 67
NginxStatus 显示的内容意思如下:
server accepts handled requests -- 总共处理了 14553819 个连接 , 成功创建 14553819 次握手 ( 证明中间没有失败的 ), 总共处理了 19239266 个请求 ( 平均每次握手处理了 1.3 个数据请求 )。
reading -- nginx 读取到客户端的 Header 信息数。
writing -- nginx 返回给客户端的 Header 信息数。
waiting -- 开启 keep-alive 的情况下,这个值等于 active - (reading + writing),意思就是 Nginx 已经处理完正在等候下一次请求指令的驻留连接。
静态文件处理
root /opt/webapp/images;
}
而下面的配置则定义了几种文件类型的请求处理方式。
root /opt/webapp;
expires 24h;
}
对于例如图片、静态 HTML 文件、js 脚本文件和 css 样式文件等,我们希望 Nginx 直接处理并返回给浏览器,这样可以大大的加快网页浏览时的速度。因此对于这类文件我们需要通过 root 指令来指定文件的存放路径,同时因为这类文件并不常修改,通过 expires 指令来控制其在浏览器的缓存,以减少不必要的请求。 expires 指令可以控制 HTTP 应答中的“ Expires ”和“ Cache-Control ”的头标(起到控制页面缓存的作用)。您可以使用例如以下的格式来书写 Expires:
expires 60s;
expires 30m;
expires 24h;
expires 1d;
expires max;
expires off;
动态页面请求处理
proxy_pass [url]http://localhost:8080[/url] ;
proxy_set_header X-Real-IP $remote_addr;
}
这里我们没有使用到集群,而是将请求直接送到运行在 8080 端口的 Tomcat 服务上来完成类似 JSP 和 Servlet 的请求处理。
在 Nginx 的集群配置中,Nginx 使用最简单的平均分配规则给集群中的每个节点分配请求。一旦某个节点失效时,或者重新起效时,Nginx 都会非常及时的处理状态的变化,以保证不会影响到用户的访问。
发表评论
-
shell 批量 复制文件 并 替换文件内容
2012-08-10 09:04 3219任务 找出文件夹下所有png的文件的文件名, 复制xxx ... -
shell编程 拿到标准输入
2012-01-05 13:54 2263在shell编程中我们可以通过$1拿到参数 如 ./ ... -
shell 脚本自动下载连续图片
2011-10-20 21:43 1707自动下载 000.jpg-199.jpg . ... -
(转)apache rewrite
2011-03-09 16:56 1469RewriteEngine on RewriteCond ... -
转: Linux中查看系统资源占用情况的命令
2010-12-06 16:47 1252用 'top -i' 看看有多少 ... -
如何查看MX记录是否生效 A CNAME MX
2010-12-02 21:06 2915如何查 看MX记录是 ... -
(转)测试网页响应时间的shell脚本[需要curl支持]
2010-10-12 17:31 5259用法及返回结果如下: lvyaozu@lvyaozu-des ... -
linux 删除目录下的N天前的文件
2010-10-08 10:12 2277find /var/log/xxx -daystart -ty ... -
linux 系统 校准时间
2010-09-27 16:56 2145/usr/sbin/ntpdate 210.72.145.4 ... -
nginx rewrite (转)
2010-09-26 14:57 8757rewrite "^/api/say/(?!se ... -
haproxy nginx tomcat
2010-09-25 17:38 4236拟机上搭了 haproxy nginx t ... -
nginx wordpress permalinks Month and name
2010-09-17 15:44 1807在nginx下搭建wordpress 并使用permalink ... -
nginx gzip duplicate MIME type “text/html”
2010-09-14 10:37 8775指令 [#gzip gzip] [#gzip_ ... -
nginx alias expires 禁止IP直接访问
2010-09-03 11:47 2416nginx貌似没有虚拟目录 ... -
服务器间 传送 文件
2010-08-27 15:41 1422scp -P 22 filename logUsernam ... -
linux 查看 系统版本信息 语言
2010-08-23 16:08 1374redhat, centos cat /etc/redha ... -
postfix 限制 及 BCC 查看版本号
2010-08-06 20:33 2862查看版本号 postconf mail_ve ... -
curl 登录表单 获取cookie
2010-07-26 11:55 3531登录表单 并保存cookie curl -c cook ... -
Ubuntu 定时任务 发邮件
2010-07-21 18:18 2271vi /etc/crontab 第一行 ... -
配置phpmyadmin munin htpasswd
2010-07-13 17:48 1257config <VirtualHost *:80> ...
相关推荐
以上就是Nginx限制IP、控制并发连接数和设置连接数上限的基本方法。在实际应用中,可能还需要根据服务器的性能、网络环境和业务需求进行更精细的调整。Nginx的强大之处在于其模块化设计和高度可配置性,可以根据需要...
Nginx高性能WEB 5万并发连接数秘笈
2. **设置TCP最大连接数(somaxconn)**:通过`echo 10000 > /proc/sys/net/core/somaxconn`命令调整,增加内核监听队列的大小,提高并发处理能力。 3. **开启TCP连接的快速回收和重用**:通过`echo 1 > /proc/sys/...
Nginx通过设置`limit_conn`和`limit_req`模块来限制每个IP地址的并发连接数和请求速率。这两个模块可以帮助我们有效地控制服务器的访问流量,避免DDoS攻击和其他滥用行为。 **2. limit_conn模块** `limit_conn`模块...
在Nginx中限制并发连接请求数和限制并发请求数是两种不同的...通过限制并发连接数和并发请求数,Nginx可以在保障服务稳定的同时,有效地抵御恶意攻击和过高负载。正确配置这些限制可以提高服务器的健壮性和用户体验。
如果想要获得更高的并发连接数,可以适当增大该值。 6. keepalive超时时间可以通过keepalive_timeout指令进行调整,它决定了一个TCP连接在多久之后会被Nginx关闭。 7. client_header_buffer_size定义了客户端请求...
优化方法论 我重点分享如下两个问题: 保持并发连接数,怎么样做到内存有效使用。 在高并发的同时保持高吞吐量的重要要点。 实现层面主要是三方面优化,主要聚焦在应用、框架、内核。 硬件限制可能有的...
Nginx限制访问频率、下载速率和并发连接数,旨在防止服务器过载,优化用户体验,以及阻止恶意行为。 在介绍限制方法之前,需要知道两个主要模块:ngx_http_limit_req_module和ngx_http_limit_conn_module。ngx_...
然而,随着并发连接数增加,过多的进程会导致CPU负载过高、内存消耗过大,影响服务器的稳定性和性能。 2. I/O多路复用模型 这是现代Web服务器,包括Nginx,所采用的方法。I/O多路复用通过将socket设置为非阻塞模式...
- **作用:** 指定每个工作进程能够同时处理的最大连接数。 - **建议值:** 根据服务器资源情况确定,一般设置较大值。 - **配置示例:** `worker_connections 65535;` **6. **`keepalive_timeout`**:** - **作用...
在Nginx服务器中,管理和优化并发连接数以及限制恶意请求是确保系统稳定性和资源有效利用的关键措施。本文将深入探讨如何使用Nginx的ngx_http_limit_conn_module和ngx_http_limit_req_module模块来实现这两个目标。 ...
这将模拟 100 个客户端并发请求服务器,测试限制 IP 连接数的效果。 四、总结 本文档介绍了如何使用 Nginx 和 Apache 限制 IP 连接数和带宽的方法。这些方法可以帮助管理员控制服务器的资源使用,避免因为大量恶意...
- 使用`worker_connections`指令限制每个工作进程的最大连接数,防止资源耗尽。 - 配合`multi_accept`指令自动忽略多余连接,减少不必要的资源消耗。 **3. 其他优化参数** - `accept_mutex`和`accept_mutex_delay`...
为了应对这些问题,我们可以利用 Nginx 的 ngx_http_limit_conn_module 模块来限制同一 IP 地址的并发连接数,从而保护服务器资源。 ### 1. ngx_http_limit_conn_module 模块介绍 ngx_http_limit_conn_module 是 ...
标题提及的“nginx 负载均衡for windows, 跨越 100万TCP连接”揭示了Nginx在Windows环境下处理海量并发连接的能力。** 在Windows系统上部署Nginx,可以利用其卓越的反向代理和负载均衡功能,将来自客户端的请求...
4. 负载均衡策略:Nginx提供了多种负载均衡策略,如轮询、随机、源地址哈希、加权轮询、加权随机和最小连接数。这些策略可以根据不同场景的需求选择,确保服务器性能得到充分利用。 5. 配网数据采集:在配电自动化...
Nginx 1.22.0 Linux 版本,解压安装。 Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理...能够支持高达 50,000 个并发连接数的响应,感谢Nginx为我们选择了 epoll and kqueue作为开发模型。
通过 Autobench,我们可以获取服务器可以承载的最大并发连接数与最佳并发数,帮助我们更好地优化服务器性能。 二、测试工具介绍 ### 1. Httperf Httperf 是一款高性能的 HTTP 测试工具,使用它我们可以准确定位...
Nginx 1.22.0 Windows版本,解压安装。 Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)...能够支持高达 50,000 个并发连接数的响应,感谢Nginx为我们选择了 epoll and kqueue作为开发模型。