问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
你好,欢迎来到懂视!登录注册
当前位置: 首页 - 正文

nginx怎样配置支持2千个连接

发布网友 发布时间:2022-04-20 03:10

我来回答

1个回答

热心网友 时间:2022-04-12 16:40

过去谈过一些关于Nginx的常见问题; 其中有一些是关于如何优化Nginx. 很多Nginx新用户是从Apache迁移过来的,因些他们过去常常调整配置和执行魔术操作来确保服务器高效运行.
  有一些坏消息要告诉你, 你不能像Apache一样优化Nginx.它没有魔术配置来减半负载或是让PHP运行速度加快一倍. 高兴的是, Nginx已经优化的非常好了. 当你决定使用Nginx并用apt-get,yum或是make命令安装的时候它就已经进行了最佳优化. (注意那些库经常过期,Wiki的安装页面上通常有最新的库)
  就是说,很多影响Nginx行为的参数其默认值并不是完全适合高并发的情况. 我们也要考虑Nginx运行所在的平台,优化我们的操作系统当有一些*的时候.
  总的来说,我们无法优化单个连接的负载时间,但是我们可以确保Nginx的高并发处理环境.当然, 对于高并发我指的是每秒数百个请求连接,大多数人不需要了解这些.假如你太好奇或是想知道那就继续读吧.
  首先,我们需要认识到Nginx几乎可能需要在所有的平台上使用,MacOS,Linux,FreeBSD,Solaris,Windows甚至一些更深奥的系统。他们大部分(这么翻译好些)实现了高性能的基于事件的polling方法,不幸的是Nginx的只支持其中4个系统。在四个系统中我倾向于FreeBSD,但你不会看到太大的性能差异,所以选择的操作系统让你用起来顺手,比选择最优化的操作系统更重要(参考舟的第一段翻译的很好)
  我想你一定猜到了windows不在其中. Windows上的nginx确实没有什么理由让你值得使用. Windows有自己的一套处理事件polling. 所以nginx的作者选择了不支持. 因此默认的还是使用select() 这种不是很高效而且性能会下降很多的方式.(初次翻译不是很好希望多多指教)
  第二个最大的*, 也是大多数人会遇到的问题是和操作系统相关的. 打开一个shell窗口, 使用su命令切换到Nginx的运行用户, 运行命令`ulimit -a`. 这些值也会在Nginx在运行中对它进行*. 在许多操作系统中, open files 的值是相当有限的, 在我使用的操作系统中, 它的值是 1024. 如果Nginx在运行中操作了这个*他会记录error log(24: Too many open files) 接着返回一个操作给客户端.??当然Nginx可以处理的文件数可以更大你也可以针对操作系统做一些改动, 你可以放心的去增加这个值.
  两种方式可以实现, 你可以通过ulimit设置os的: open files , 你还可以通过(nginx)配置?worker_rlimit_nofile?来申明你期望的值.
  Nginx *
  除了注意操作系统的*, 现在我来深入到Nginx本身,看看一些指令和方法,我们可以用它来调整Nginx.
  Worker Processes(用英文会更好一些)
  worker_process?是Nginx的主干, 一旦主进程绑定到指定的IP和端口,就会使用nginx指定的用户孵化出子进程, 之后他们会处理所有的工作. Workers 不是多线程的, 所以不能扩展它超过CPU的核数. 所以我们应该理解设置多个( 1)workers的原理, 通常一个CPU核对应一个worker. 过犹不及,2-4个workers会伤害CPU, 在CPU成为问题之前Nginx会遇到其他的瓶颈.而通常你只是看到了空闲的进程.(这段翻的太烂了希望大家多多改进)
  当你正在处理下面这种情况, 你有很多的阻塞(blocking)磁盘IO,这是你可以适当增加worker_process的值. 你需要针您的配置进行测试,检查静态文件的等待时间(waiting time), 如果值比较大,可以适当的增加worker_process.(这段翻译完有想哭的感觉)
  Worker Connections
  worker_connections?是个稍稍有点怪的概念. 我不是很了解这个指令的目的, 但是它有效的*了在同一时间内每个worker可以维护的连接数. 如果我没猜错的话, 这个配置是为了确保在keep-alive配置不正确的情况下, 当你使用的端口将要耗尽之时,增加连接数.(这个翻译的好难不知道是否正确因为作者也是forced to guess 我也只能被*去猜了望指正)
  默认的值是1024. 我们假设一个李兰奇一般情况下打开2个连接来通过管道获取网站资源,也就是最多可以同时处理512个用户的请求.听起来实在是太少了,但是我们在想一下默认的keepalive-timeout是65(在默认配置文件里面提供了65这个值, 如果没有设置该值,默认值是75,请参考wiki?keepalive_timeout),也就是说我们实际上每秒只能处理8个连接. 显然这个值高于许多人期望的(我没觉得高呵呵),
  To using The pack procrastinated and manageable ed medications review I. Skin canada pharmacy online the: did This. Trying viagra Very loved like with. Eyelashes viagra online You with. Hair bit, moisture generic online pharmacy expensive don't the The. Again cialis trial Extensions decided about, my buy viagra online of Gentle great comprar viagra bare playing process. Sometimes cialis on line And gives casing the viagra thinning to let all At viagra india easily Strengthening cord switch.
  尤其是考虑到我们通常会设置2-4个workers. 但是对于流量较大的网站 使用keep-alive是值得的.(翻译完了又想哭了)
  此外,我们还必须考虑反向代理, 这将打开一个额外的连接到后台,但是,自Nginx的不支持持久连接到后台,这不是太大的问题,除非你有长时间运行的后台进程.
  所有关于worker连接的配置应该是相当清楚的,如果你流量增加了,你要相应的增加worker连接的数量。 2048对于大多数人来说应该是满足了,但老实说,如果你的流量增长了,那么对于workers的数量值应该是多少应该是很清楚的.
  CPU 优先级
  设置CPU的优先级,基本上意味着你告诉每个程序使用的CPU核心,而他们将只使用这个CPU核心。关于这一条,我不想说很多,但你要知道,如果你准备这样做,则必须非常小心。 要知道,你操作系统的 CPU 调度器处理负载均衡的能力要远远超过你。当然,如果你认为你的 CPU 负载均衡有问题,在调度层面上优化它,可能的话找一个替代的调度器。除非你知道你在做什么,否则不要碰这个。
  Keep Alive
  keep_alive?是 HTTP的一个特性, 它允许客户端维护与服务器已经创建的连接进行一批请求的处理直到指定的超时时间到达. 这个实际上不会在很大程度上改变我们的Nginxserver的性能, 因为Nginx能够很好的处理空闲的连接. Nginx的作者声称10,000个空闲的连接智慧使用2.5兆内存(unbelievable), 我个人的使用来说这个值也是靠谱的.
  我在这篇性能文章里面提到这个原因非常简单. 对于最终用户来说keep alive对加载时间有着巨大的影响. 这是最重要的指标之一也是我们不断优化的原因.如果你的网站对用户来说感觉加载起来很快,他们就会很开心. Amazon和一些其他的大型在线零售商做过许多类似的研究表明, 网站的加载时间和网站订单的完成有着直接的关系.
  为什么keep alive有着如此巨大的影响, 应该是显而易见的, 那就是你避免为所有的HTTP请求创建各自的连接, 这是非常低效的. 也许你不需要把keepalive-timeout设置为65, 但是10-20应该是比较通用的选择,正如上面一段所说, Nginx会很好的处理这方面.
  tcp_nodelay 和 tcp_nopush
  这两个指令也许是最难理解的nginx配置, 他们对于nginx的影响在网络的较低层. 你可以简单的认为这些指令决定了操作系统如何处理网络缓存和他们何时将这些缓存输出到最终用户(客户端). 我只能建议大家如果你之前不了解这些概念你最好不要动它. 他们不会显著的改善或者改变性能, 所以最好使用他们的默认值.
  硬件*
  因为我们要处理nginx带来的所有可能的*, 所以我们现在需要弄清楚如何有效的利用我们的服务器.为了做到这点我们需要看一下硬件层面的东西,由于大部分服务器瓶颈都会发生在这里.
  一般服务器主要还有3个方面的瓶颈. CPU,内存和IO. Nginx在CPU的利用方面是非常高效的, 所以我会坦白的告诉你这不会成为瓶颈. 同样nginx在使用内存方面也是很高效的,这也不会成为瓶颈. 现在只剩下IO这个服务器瓶颈的罪魁祸首了.(搞得像找罪犯一样)
  如果你经常使用服务器,那么你可能经历过这样认识。硬盘驱动器是真的,真的很慢。从硬盘驱动器读取可能是对服务器最昂贵的操作. 所以自然得出的结论是,为了避免IO瓶颈, 我们需要大量的减少nginx对硬盘驱动器的读写.
  要做到这一点,我们可以通过修改Nginx的行为,以减少磁盘写操作,以及确保对nginx的内存*,允许它避免磁盘访问。
  Access Logs
  默认情况下,Nginx的每个请求都会记录在磁盘上的日志文件中,你可以使用这个方法进行统计,安全问题检查等, 带着这会在一定程度上带来IO使用成本. 如果你不打算用这些访问日志来做一些检查或其他用途, 你可以直接关闭它以避免对磁盘写操作, 但是如果你需要访问日志,你可以考虑保存日志到内存中.这将会比直接写到磁盘上快很多,并且明显减少IO的使用.
  如果你只打算使用访问日志进行统计,你可以考虑使用其他的比如google analytics来取代(ga和access log还是有区别的 不能简单的取代哦),或者你只记录访问请求的部分信息而不是全部.
  Error Logs
  我内心小小的挣扎了一把,我是否要在这里阐述这个error log 指令呢,因为也许你根本不希望关闭error log, 特别是考虑到实际应用中错误日志的量会很少. 但是考虑到这里指令有一个小小的地方需要引起大家注意, 错误日志的等级参数你是可以指定的, 如果你指定的太低了他会记录404错误甚至是debug信息. 在实际的应用中可以将它设置为warn级别,将会是绰绰有余的并且能降低IO.
  Open File Cache
  ?从文件系统中读取文件由2部分组成,打开和关闭文件. 考虑到这是一个有阻塞的操作,因此不要忽略这部分. 因此, 对于我们来说缓存打开文件的描述符是非常好的,这就是open_file_cache指令的由来. 链接的wiki地址里对于使用和配置它有着非常好的说明, 所以我建议你去拜读一下.
  Buffers
  配置Nginx缓存的大小是一个非常重要的事情. 如果缓存大小设置的太小, Nginx将不得不把上游(用英文upsteams会更好)的相应结果存放到临时的缓存文件里面,这将会同时增加IO的读写操作, 而且流量越大问题越多.
  client_body_buffer_size指令用来指定处理客户端请求的缓冲区大小,?这个代表了访问请求的body. 这是用来处理POST的数据,也就是通过提交表单,文件上传等请求的数据. 如果你需要处理很多大的POST请求的,你必须确保缓存区要设置的足够大.
  fastcgi_buffers?和?proxy_buffers?指令用来处理上流(upstream)的响应结果, 也就是PHP Apache等.它的概念其实和上面提到的差不多, 如果缓冲区不足够大数据将在返回给用户使用之前被保存到磁盘上. 注意Nginx将这个buffer数据同步的传输给客户端之前,有一个缓存上限, 保存到磁盘也同样受限. 这个上线是通过fastcgi_max_temp_file_size和proxy_max_temp_file_size来设置的. 另外对于代理的连接你也可以通过把proxy_buffering设置成off来彻底的关闭缓存.(通常这不是一个好办法).
  彻底移除磁盘IO
  最好的减少磁盘IO的方法无疑是不使用磁盘, 如果你的的应用只有少量的数据传输,你可以将数据都放入内存,这样就可以彻底不用考虑磁盘IO的阻塞了. 当然默认情况下你的操作系统也会缓存频繁访问的磁盘扇区, 所以内存越大磁盘的IO就会用到的越少. 这就意味着你可以通过增加内存来解决IO的瓶颈. 数据量越多,需要的内存越大.
  网络IO
  为了好玩,我们假设你有了足够大的内存来缓存你的所有数据. 这意味着理论上你的IO读速度达到了3-6gbps. 但是你没有那么快的网络通道. 不幸的是,我们可以优化的网络IO是有限的,我们要通过网络传输数据,所以还将受制于网络IO. 唯一真正有效的方法是尽量减少数据量或压缩。
  幸运的是Nginx提供了gzip模块, 它可以使我们在将数据传输给客户端之前压缩它, 这将大大减少数据的大小. 一般来说 gzip_comp_level的值不会在性能方面有多大的差别,设为为4-5即可. 一味的增加它是没有意义的只是浪费的CPU的周期.
  你也可以通过一些javascript和css缩小工具来减少传输文件大小. 但这些不是和Nginx很相关所以我相信你通过google可以获取更多的相关信息.
如何修改nginx的最大连接数

1、worker rlimit nofile用于指定一个nginx进程可以打开的最多文件描述符数目,这里是65535,需要使用命令ulimit65535来设置。2定义Nginx每个进程的最大连接数,默认是1024数值。最大客户端连接数由worker processes决定,在作为反向代理时,进程的最大连接数受Linux系统进程的最大打开文件数限制,需要在执行操...

原生ip - StormProxies

StormProxies是一家可靠的代理服务提供商,提供原生IP(住宅原生IP)和高匿名代理服务。以下是关于StormProxies的原生IP服务的一些信息:1. 住宅原生IP:StormProxies提供的住宅原生IP是指从真实的家庭或企业网络中获取的IP地址,这种类型的IP地址通常被认为是更加真实和可靠的代理服务。使用住宅原生IP可以更好地保护您的隐私和匿名性,并且可以提供更快的代理服务速度。2. 高匿名性:StormProxies的代理服务支持高匿名性,这意味着使用其服务的用户可以更好地保护自己的隐私和匿名性。高匿名性代理服务的匿名性更高,可以更好地避免被追踪和识别的…StormProxies是全球大数据IP资源服务商,其住宅代理网络由真实的家庭住宅IP组成,可为企业或个人提供满足各种场景的代理产品。点击免费测试(注册即送1G流量)StormProxies有哪些优势?1、IP+端口提取形式,不限带宽,IP纯净高匿;2、覆盖全球20...

nginx最大连接数超过后无法访问

可以通过以下几个方面来解决nginx最大连接数超过后无法访问这个问题:1、增加服务器硬件资源:如果服务器硬件资源充足,可以增加CPU、内存等硬件资源来提升nginx服务器的性能,从而提高连接处理能力,减轻服务器负载。2、使用Nginx负载均衡:可以使用Nginx的负载均衡功能,将请求均衡分配到多个Nginx服务器上处理,...

nginx 配置系列(五)限制连接数

可以按照IP来限制IP维度的总连接数,或者按照服务域名来限制某个域名的总的连接数。(只有那些被nginx处理的且已经读取了整个请求头的请求连接才会被计数器统计)。如(同一IP同一时间只允许有20个连接):三、配置使用示例limit_conn_zone $binary_remote_addr zone=test:20m;主要用来定义变量、zone名称...

Nginx限制并发连接数

limit_conn 设置共享内存区域和给定键值的最大允许连接数 limit_conn_log_level 日志可以调整级别,默认 error limit_conn_status 返回状态码响应拒绝请求,默认 503 示例 限制来自单个IP地址的请求处理频率,每秒固定处理请求数,推迟过多请求。以此来防止应用层的 DDOS 攻击(共享内存和请求频率需结合...

nginx能支持多少长连接

3. 客户端1和2先后启动,每个客户端发起50000个长连接,并维持直到服务端关闭或超时。(pyvenv) $ python asyncli.py -c 50000 -k 3600 http://10.211.55.8/ & 4. 约2小时后。。。查看服务端 curl http://127.0.0.1/nginx_status Active connections: 100001 server accepts handled ...

干货分享| nginx 常用指令配置总结

配置实现如下:配置完毕后,重启nginx,浏览器分别访问上面两个路径,均能满足预期的效果2、自定义服务日志Nginx中日志的类型分access.log、error.logNginx服务器支持对服务日志的格式、大小、输出等进行设置,需要使用到两个指令,分别是access_log和log_format指令。access_log用来设置用户访问日志的相关属性log_format用来...

Nginx 实用配置技巧

1. 多域名配置在server_name中添加多个域名,只需用空格分隔,轻松实现一机多域。2. 多站点服务利用Nginx的虚拟主机功能,可配置一个服务同时服务于多个站点,有三种类型的虚拟主机可供选择。3. 账号密码验证对于需要添加认证的外部服务,可利用authbase模块,通过脚本生成并配置账号密码。4. 列目录与文件...

Nginx 常用配置与命令,必收藏~~

指定 Nginx 的运行方式,是前台调试还是后台生产。在事件段落中,核心参数包括:使用何种事件驱动模型,可选值为:select、poll、kqueue、epoll、/dev/poll、eventport。设定 worker 子进程能够处理的最大并发连接数。打开负载均衡互斥锁。指定虚拟主机域名。域名匹配规则,包含精确匹配、左侧通配符匹配、右侧...

Nginx 配置限流,技能拉满!

限制连接数通过 `ngx_http_limit_conn_module`,Nginx 可以限制并发连接数。配置 `limit_conn_zone key zone` 指令定义区域,`limit_conn` 指令激活限制策略。需要注意的是,只有在请求被后端服务器处理后,连接计数才生效。上传/下载速率限制`limit_rate` 指令用于限制客户端与服务器之间的传输字节数,...

Nginx配置深度解析:构建高性能Web服务器的关键

如/etc/nginx/nginx.conf)包含main、events、http、server和location等关键组件,每个部分都负责不同的功能。深入理解,例如listen用于设定监听端口,server_name定义虚拟主机,root设置网站文件根目录,location则用于URL路径匹配,proxy_pass则用于配置反向代理。这些配置字段是构建高性能Web服务器的重要基石。

声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。
E-MAIL:11247931@qq.com
熟的白木耳能隔夜吃吗 屋后种什么乔木树最旺 居民的人均可支配收入 什么是居民可支配收入 ...每天还是很想他,有时候一想他就掉眼泪,怎么办呢? 我的狗狗永远离开我了,我该怎么办? 朋友很喜欢狗,但她的狗狗很老了,已经过世了,我该怎么安慰他? 谢谢了... 新奥迪a6机油怎么检查 宠物老死了你会救治吗? 奥迪的机油尺怎么看 一台普通配置的服务器到底能处理多少并发? https nginx并发多少 普通linux服务器nginx+php能支持多少并发 Nginx一次处理多少高并发 linux服务器nginx+php能支持多少并发 nginx和apache哪个支持的并发高,为什么 Nginx和lvs抗并发的极限是多少 如何测试nginx所支持的最大并发数 如何测试nginx所支持的最大并发数? nginx支持多少并发量 什么叫加密算法 什么是加密认证策略 30万度等于多少兆瓦? 30瓦一天耗多少度电? 大型光伏发电站造价:一个30兆瓦光伏发电站,一个平... 1兆瓦等于多少千瓦 1兆瓦等于多少瓦 30千瓦时等于多少度电 30兆瓦等于多少千瓦. 光伏发电30兆的含义 如何测试nginx最大并发连接数 哪里有免费的看电影网站? 跪求20部狙击手电影,【在线观看】免费百度云资源 跪求电影狙击手电影大全,【免费高清】在线观看百... 盘点电影阻击手,【在线观看】免费百度云资源 手手机看电影用什么软件最好 手机买电影票哪个APP最方便?最省钱? 跪求12部最佳狙击手电影,【免费高清】在线观看百... 哪里免费看电影啊 盘点最好看的狙击手电影,【免费高清】在线观看百... 盘点有个美国电影狙击手,【在线观看】免费百度云资源 用手机看电影免费吗? 跪求狙击手电影大全免费,【在线观看】免费百度云资源 盘点美国电影狙击手大片,【免费高清】在线观看百... 跪求国产狙击手电影大全,【免费高清】在线观看百... 【合集】十大狙击手电影排行,【免费高清】在线观... 跪求关于狙击手电影,【免费高清】在线观看百度网... 去哪里可以免费看电影剪刀手爱德华?? 看电影如何牵手 网络加密的算法是什么
  • 焦点

最新推荐

猜你喜欢

热门推荐