如何配置Apache服务器
1。怎么设置?
设置请求等待时间
在httpd.conf中设置:
超时
英语字母表的第14个字母
其中n是整数,单位是秒。
设置此超时适用于三种情况:
2.如何接收get请求的总时间
收到post和put请求的TCP数据包之间的时间
TCP数据包传输中的响应(ack)时间间隔
3.如何让apache监听特定的端口?
修改httpd.conf中关于Listen的选项,例如:
听
8000
就是让apache监听端口8000。
如果要指定监听端口和监听地址,可以使用:
听
192.170.2.1:80
听
192.170.2.5:8000
这使得apache可以同时监听192.170.2.1的80端口和192.170.2.5的8000端口。
当然,也可以在httpd.conf中设置:
港口
80
以便达到类似的效果。
4.如何设置apache中空空闲进程的最大数量?
修改httpd.conf并设置:
MaxSpareServers
英语字母表的第14个字母
其中n是整数。这样,当空空闲进程超过N个时,apache主进程就会杀死多余的空空闲进程,将空空闲进程保持在N个,节省系统资源。在一个非常繁忙的apache站点中调整这个参数是必要的,但是在任何时候将这个参数调整到一个较大的数字并不是一个好主意。
您还可以设置:
MinSpareServers
英语字母表的第14个字母
限制空空闲进程的最小数量,以加快反应速度。
5.apache如何在启动时设置子服务进程的数量?
在httpd.conf中设置:
启动服务器
5
这样,启动apache后有五个空空闲的子进程等待接受请求。
也可以参考MinSpareServers和MaxSpareServers设置。
tomcat7默认参数?
Socket参数选项:
1、TCP_NODELAY:表示立即发送数据。
2、SO_RESUSEADDR:表示允许重用Socket所绑定的本地地址
3、SO_TIMEOUT:表示接受数据时的超时时间。
4、SO_LINGER:表示当执行close();方法时候,是否理解关闭底层的socket。(Reset报文)
setSoLinger(true, 0): 执行该方法,那么执行Socket的close方法,该方法也会立即返回,但底层的Socket也会立即关闭,所有未发送完的剩余数据被丢弃
setSoLinger(true, 3600): 那么执行Socket的close方法,该方法不会立即返回,而进入阻塞状态,同时,底层的Socket也会尝试发送剩余的数据,只有满足下面的两个条件之一,close方法才会返回:
(1):底层的Socket已经发送完所有的剩余数据
(2): 尽管底层的Socket还没有发送完所有的剩余数据,但已经阻塞了3600秒,close()方法的阻塞时间超过3600秒,也会返回,剩余未发送的数据被丢弃。
net.ipv4.tcp_tw_reuse = 1 表示开启重用。允许将TIME-WAIT sockets重新用于新的TCP连接,默认为0,表示关闭;
net.ipv4.tcp_tw_recycle = 1 表示开启TCP连接中TIME-WAIT sockets的快速回收,默认为0,表示关闭。5、SO_SNFBUF:表示发送数据的缓冲大小
6、SO_RCVBUF:表示接受数据的缓冲区的大小
7、SO_KEEPALIVE:表示长时间处于空闲状态的SOCEKT,是否自动把他/她关闭
8、OOBINLINE:表示是否支持发送一个字节的TCP紧急数据
默认参数
注: Connector 通常在%HOME_TOMCAT%/conf/servser.xml 文件内
# 正常参数
<Connector port=”8080″ protocol=”HTTP/1.1″
connectionTimeout=”20000″
redirectPort=”8443″ />
配置参数调试
# 优化参数
<Connector port=”8080″
protocol=”HTTP/1.1″
maxThreads=”1000″
minSpareThreads=”100″
acceptCount=”1000″
maxConnections=”1000″
connectionTimeout=”20000″
maxHttpHeaderSize=”8192″
tcpNoDelay=”true”
compression=”on”
compressionMinSize=”2048″
disableUploadTimeout=”true”
redirectPort=”8443″
enableLookups=”false”
URIEncoding=”UTF-8″ />
参数详解
1)port
注:代表Tomcat端口号,默认8080。
2)protocol
注:协议类型,可选类型有4种,BIO(阻塞型IO),NIO,NIO2和APR。
# BIO
BIO(Blocking I/O) 阻塞式I/O操作,传统的Java I/O操作(即java.io包及其子包)。Tomcat在默认情况下,是以bio模式运行的,bio模式是三种运行模式中性能最低的一种。BIO配置采用默认即可。
BIO更适合处理简单流程,如程序处理较快可以立即返回结果。简单项目及应用可以采用BIO。
# NIO
NIO(New I/O)是Java SE 1.4及后续版本提供的一种新的I/O操作方式(即java.nio包及其子包)。Java nio是一个基于缓冲区、非阻塞I/O操作的Java API它拥有比传统I/O操作(bio)更好的并发运行性能。
NIO更适合后台需要耗时完成请求的操作,如程序接到了请求后需要比较耗时的处理这已请求,所以无法立即返回结果,这样如果采用BIO就会占用一个连接,而使用NIO后就可以将此连接转让给其他请求,直至程序处理完成返回为止。
# APR
APR(Apache Portable Runtime/Apache可移植运行时),是Apache HTTP服务器的支持库。你可以简单地理解为:Tomcat将以JNI的形式调用 Apache HTTP服务器的核心动态链接库来处理文件读取或网络传输操作,从而大大地提高 Tomcat对静态文件的处理性能。
APR可以大大提升Tomcat对静态文件的处理性能,同时如果你使用了HTTPS方式传输的话,也可以提升SSL的处理性能。
# 修改方式
//BIO
protocol=”HTTP/1.1″
//NIO
protocol=”org.apache.coyote.http11.Http11NioProtocol”
//NIO2
protocol=”org.apache.coyote.http11.Http11Nio2Protocol”
//APR
protocol=”org.apache.coyote.http11.Http11AprProtocol”
3)maxThreads (线程池的大小默认200)
注:连接器创建处理请求线程的最大数目,处理同事请求的最大数目,默认值为200。
如果一个执行器与此连接器关联,则忽略此属性,因为该属性将被忽略,所以该连接器将使用执行器而不是一个内部线程池来执行任务。maxThreads是一个重要的配置属性,maxThreads配置的合理直接影响了Tomcat的相关性能。maxThreads并不是配置的越大越好,事实上你即使配置成999999也是没有用的,因为这个最大值是受操作系统及相关硬件所制约的,并且最大值并不一定是最优值,所以我们追寻的应该是最优值而不是最大值。
QPS(Query Per Second):每秒查询率QPS是对一个特定的查询服务器在规定时间内所处理流量多少的衡量标准。我们常常使用 QPS值来衡量一个服务器的性能。
QPS = 并发数 / 平均响应时间
并发数 = QPS * 平均响应时间
一个系统吞吐量通常由QPS、并发数两个因素决定,每套系统的这两个值都有一个相对极限值,在应用场景访问压力下,只要某一项达到系统最高值,系统的吞吐量就上不去了,如果压力继续增大,系统的吞吐量反而会下降,原因是系统超负荷工作,上下文切换、内存等等其它消耗导致系统性能下降。所谓吞吐量这里可以理解为每秒能处理请求的次数。
所以选择一个合理的 maxThreads值,其实并不是那么容易的事。因为过多的线程只会造成,更多的内存开销,更多的CPU开销,但是对提升QPS确毫无帮助;找到最佳线程数后通过简单的设置,可以让web系统更加稳定,得到最高,最稳定的QPS输出。
# 获取最佳maxThreads的最佳值
(1)通过线上系统不断使用和用户的不断增长来进行性能测试,观察QPS,响应时间,这种方式会在爆发式增长时系统崩溃,如双12等。
(2)根据公式计算,服务器端最佳线程数量=((线程等待时间+线程cpu时间)/线程cpu时间) * cpu数量,这种方式有时会被误导,因为某些系统处理环节可能会耗时比较长,从而影响公式的结果。
(3)单、多用户压力测试,查看CPU的消耗,然后直接乘以百分比,再进行压测,一般这个值的附近应该就是最佳线程数量,这种方式理想场景比较适用,实际情况会比这个复杂的多。
(4)根据系统的自身情况调整,如硬件限制,系统限制,程序处理能力限制等。
(5)定期修改为不同的 maxThreads值,看服务器响应结果及用户反应。
# QPS和线程数的关系
(1)在最佳线程数量之前,QPS和线程是互相递增的关系,线程数量到了最佳线程之后,QPS持平,不在上升,甚至略有下降,同时相应时间持续上升。
(2)同一个系统而言,支持的线程数越多(最佳线程数越多而不是配置的线程数越多),QPS越高。
# QPS和响应时间的关系
(1)对于一般的web系统,响应时间一般有CPU执行时间+IO等待时间组成。
(2)CPU的执行时间减少,对QPS有实质的提升,IO时间的减少,对QPS提升不明显。如果要想明显提升QPS,优化系统的时候要着重优化CPU消耗大户。
4)minSpareThreads
注:线程的最小运行数目,这些始终保持运行。如果未指定,默认值为10。
5)acceptCount (默认为100,ServerSocket.accept队列,backlog:半队列的大小)
注:最大队列长度。一般与maxThreads相同,默认为100。
当所有可能的请求处理线程都在使用时传入连接请求的最大队列长度。如果未指定,默认值为100。一般是设置的跟 maxThreads一样或一半,此值设置的过大会导致排队的请求超时而未被处理。所以这个值应该是主要根据应用的访问峰值与平均值来权衡配置。
6)maxConnections (NIO与NIO2的默认值为10000,accept的Socket的大小)
注:在任何给定的时间内,服务器将接受和处理的最大连接数。当这个数字已经达到时,服务器将接受但不处理,等待进一步连接。NIO与NIO2的默认值为10000,APR默认值为8192。
7)connectionTimeout (设置到Socket.setSoTimeout(connectionTimeout ))
注:当请求已经被接受,但未被处理,也就是等待中的超时时间。单位为毫秒,默认值为60000。通常情况下设置为30000。
8)maxHttpHeaderSize
注:请求和响应的HTTP头的最大大小,以字节为单位指定。如果没有指定,这个属性被设置为8192(8 KB)。
9)tcpNoDelay
注:如果为true,服务器socket会设置TCP_NO_DELAY选项,在大多数情况下可以提高性能。缺省情况下设为true。
10)compression
注:是否启用gzip压缩,默认为关闭状态。这个参数的可接受值为“off”(不使用压缩),“on”(压缩文本数据),“force”(在所有的情况下强制压缩)。
11)compressionMinSize
注:如果compression=”on”,则启用此项。被压缩前数据的最小值,也就是超过这个值后才被压缩。如果没有指定,这个属性默认为“2048”(2K),单位为byte。
12)disableUploadTimeout
注:这个标志允许servlet Container在一个servlet执行的时候,使用一个不同的,更长的连接超时。最终的结果是给servlet更长的时间以便完成其执行,或者在数据上传的时候更长的超时时间。如果没有指定,设为false。
13)enableLookups
注:关闭DNS反向查询。
14)URIEncoding
注:URL编码字符集。