热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

Nginx高级应用--------性能优化,突破C100K

Nginx是一款高性能的HTTP和反向代理服务器,能够选择高效的epoll(linux2.6内核)、kqueue(freebsd)、eventport(solaris10)作为网络I/O模型,能够支持高达50000个并发连接数的响应,而内存、CPU等系统资源消耗却非常低、运行非常稳定。

Nginx高级应用--------性能优化,突破C100K

【引自asd1123509133的博客】1. 背景

介绍:

Nginx是一款高性能的HTTP和反向代理服务器,能够选择高效的epoll(linux2.6内核)、kqueue(freebsd)、eventport(solaris10)作为网络I/O模型,能够支持高达50000个并发连接数的响应,而内存、CPU等系统资源消耗却非常低、运行非常稳定。

选择的理由:

* 支持高并发连接:nginx使用高效的多路复用模型(epoll/linux, kqueue/freebsd, eventport/solaris)

* 内存消耗少:在服务器3W并发连接下,开启10个Nginx进程消耗150MB内存(15MB*10)

* 成本低廉:购买F5 BIG-IP、NetScaler等负载均衡交换机需要几十万RMB,而开源Nginx替代这些商业设备。

* 其他理由:网络配置简单;支持rewrite重写规则,能够根据域名、URL的不同、将HTTP请求分到不同的后端服务器群组;内置的健康检查功能;节省带宽,支持GZIP压缩,可以添加浏览器本地缓存的Header头;支持热部署,能够在不间断服务的情况下、对软件版本进行升级

2. 环境

  1. [root@nginx ~]$ uname -r  
  2. 2.6.32-642.13.1.el6.x86_64 
  3. [root@nginx ~]$ uname -m 
  4. x86_64 
  5. [root@nginx ~]$ cat /etc/redhat-release  
  6. CentOS release 6.8 (Final) 

3. 优化

* nginx配置文件优化

- nginx进程数,建议按照cpu数目来指定,一般为它的倍数:

- worker_processes 4;

- 为每个进程绑定cpu:

- worker_cpu_affinity 00000001 00000010 00000100 00001000;

- nginx进程打开的最多文件描述符数目:

- worker_rlimit_nofile 102400;

- 使用epoll的I/O复用模型:

- use epoll;

- 每个进程允许的最多连接数:

- worker_connections 102400;

- keepalive超时时间:

- keepalive_timeout 60;

- 客户端请求头部的缓冲区大小: (分页大小可以用命令getconf PAGESIZE取得):

- client_header_buffer_size 4k;

- 打开文件指定缓存,默认是没有启用的,max指定缓存数量,建议和打开文件数一致,inactive是指经过多长时间文件没被请求后删除缓存:

- open_file_cache max=102400 inactive=20s;

- 指定多长时间检查一次缓存的有效信息:

- open_file_cache_valid 30s;

- 设置最少使用次数,如果超过这个数字,文件描述符一直是在缓存中打开的:

- open_file_cache_min_uses 1;

* 系统优化

- timewait的数量,默认是180000。(Deven:因此如果想把timewait降下了就要把tcp_max_tw_buckets值减小):

- net.ipv4.tcp_max_tw_buckets = 6000

- 允许系统打开的端口范围:

- net.ipv4.ip_local_port_range = 1024 65000

- 启用timewait快速回收:

- net.ipv4.tcp_tw_recycle = 1

- 开启重用。允许将TIME-WAIT sockets重新用于新的TCP连接:

- net.ipv4.tcp_tw_reuse = 1

- 开启SYN COOKIEs,当出现SYN等待队列溢出时,启用COOKIEs来处理:

- net.ipv4.tcp_synCOOKIEs = 1

- web应用中listen函数的backlog默认会给我们内核参数的net.core.somaxconn限制到128,而nginx定义的NGX_LISTEN_BACKLOG默认为511:

- net.core.somaxcOnn= 262144

- 允许送到队列的数据包的最大数目:

- net.core.netdev_max_backlog = 262144

- 系统中最多有多少个TCP套接字不被关联到任何一个用户文件句柄上:

- net.ipv4.tcp_max_orphans = 262144

- 记录的那些尚未收到客户端确认信息的连接请求的最大值:

- net.ipv4.tcp_max_syn_backlog = 262144

- 时间戳可以避免序列号的卷绕:

- net.ipv4.tcp_timestamps = 0

- 内核放弃连接之前发送SYN+ACK包:

- net.ipv4.tcp_synack_retries = 1

- 内核放弃建立连接之前发送SYN包的数量:

- net.ipv4.tcp_syn_retries = 1

- 保持在FIN-WAIT-2状态的时间:

- net.ipv4.tcp_fin_timeout = 1

- 当keepalive起用的时候,TCP发送keepalive消息的频度。缺省是2小时:

- net.ipv4.tcp_keepalive_time = 30

4. 总结

以需求驱动技术,技术本身没有优略之分,只有业务之分。


推荐阅读
  • 本文将详细介绍如何在ThinkPHP6框架中实现多数据库的部署,包括读写分离的策略,以及如何通过负载均衡和MySQL同步技术优化数据库性能。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 本文将深入探讨PHP编程语言的基本概念,并解释PHP概念股的含义。通过详细解析,帮助读者理解PHP在Web开发和股票市场中的重要性。 ... [详细]
  • 本文探讨了如何在日常工作中通过优化效率和深入研究核心技术,将技术和知识转化为实际收益。文章结合个人经验,分享了提高工作效率、掌握高价值技能以及选择合适工作环境的方法,帮助读者更好地实现技术变现。 ... [详细]
  • 阿里云ecs怎么配置php环境,阿里云ecs配置选择 ... [详细]
  • Nginx 反向代理与负载均衡实验
    本实验旨在通过配置 Nginx 实现反向代理和负载均衡,确保从北京本地代理服务器访问上海的 Web 服务器时,能够依次显示红、黄、绿三种颜色页面以验证负载均衡效果。 ... [详细]
  • 本文详细介绍了如何在云服务器上配置Nginx、Tomcat、JDK和MySQL。涵盖从下载、安装到配置的完整步骤,帮助读者快速搭建Java Web开发环境。 ... [详细]
  • 全能终端工具推荐:高效、免费、易用
    介绍一款备受好评的全能型终端工具——MobaXterm,它不仅功能强大,而且完全免费,适合各类用户使用。 ... [详细]
  • Spring Cloud因其强大的功能和灵活性,被誉为开发分布式系统的‘一站式’解决方案。它不仅简化了分布式系统中的常见模式实现,还被广泛应用于企业级生产环境中。本书内容详实,覆盖了从微服务基础到Spring Cloud的高级应用,适合各层次的开发者。 ... [详细]
  • 免费获取:全面更新的Linux集群视频教程及配套资源
    本资源包含最新的Linux集群视频教程、详细的教学资料、实用的学习课件、完整的源代码及多种软件开发工具。百度网盘链接:https://pan.baidu.com/s/1roYoSM0jHqa3PrCfaaaqUQ,提取码:41py。关注我们的公众号,获取更多更新的技术教程。 ... [详细]
  • 一面问题:MySQLRedisKafka线程算法mysql知道哪些存储引擎,它们的区别mysql索引在什么情况下会失效mysql在项目中的优化场景&# ... [详细]
  • 掌握远程执行Linux脚本和命令的技巧
    本文将详细介绍如何利用Python的Paramiko库实现远程执行Linux脚本和命令,帮助读者快速掌握这一实用技能。通过具体的示例和详尽的解释,让初学者也能轻松上手。 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • 深入解析 Spring Security 用户认证机制
    本文将详细介绍 Spring Security 中用户登录认证的核心流程,重点分析 AbstractAuthenticationProcessingFilter 和 AuthenticationManager 的工作原理。通过理解这些组件的实现,读者可以更好地掌握 Spring Security 的认证机制。 ... [详细]
author-avatar
私受他
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有