自从自己创业以后就很少写博客了,也许是太忙了。也许是无法静下心好好研究一个东西。今天把我们做的后台做了下压力测试。结果还可以,尤其是对于我这种从java转过来土人。

4年前看到一篇抨击java的文章 《名词王国之死》,当时很不屑,现在看来在很多场景,尤其是能真正给用户节省资源的地方,java真的差了不少。之前使用tomcat,一台4g内存的服务器,死活上不了1000并发,tomcat这东西的对硬件的利用率太低了。我们来看看ngx+nodejs


测试环境

机器型号:vmware 虚拟机,分配最大内存1G,分配cpu核数1核,单线程。(原始机器为办公电脑:i5-4690,4g内存,500G硬盘)

系统控制: pm2 设置: 内存< 256M ,production 模式。

测试工具: jmeter - 2.1.3

系统软件: nginx , yliyun-server, mysql , reids

压测接口: 文件列表[100个文件] ,用户列表[100用户],小文件上传(<500K)

测试步骤

循环次数:(10次)

线程数依次: 100, 500 ,1000, 1500, 2000, 2500, 3000,

测试结果展示【仅展示文件列表接口】

  • 100 线程(类似100并发)

线程数设置为100,启动时间为3秒,单个线程循环10次,出错继续(后续都是如此配置)

我们可以看到100并发,当然是毫无压力,继续。

  • 500线程

ok, error% 这一栏为0,用户列表是另外一个请求,这里也跟着跑了10次,无视即可。

  • 1000线程,过个小关

我们看到 error 一栏表明是1000是毫无压力的。这里将接口返回的数据量增加到了1215.3KB,列表中显示的数据为30列,算是更加符合我们正常习惯性使用。

还可以看到应用所占的内存从开始的(500线程)的189M上升到197M,有小幅度增加。平均数据返回为4s,这是能接受的极限了。

因此可以得出结论,这种配置(单核,512M内存)的机器,并发在1000左右是比较理想的。

但是我们压力测试不是正常使用,必须继续,压到出错,或者拥有崩溃为止。

  • 1500线程

看看error,无错通过。 看是平均延迟到了7.2s,内存使用上升到227M,这里我在pm2 脚本设置了最大内存为256M,"max_memory_restart": "256M",,为了更要的压内存,实际情况中不推荐设置。

使用 top指令 看到 最耗内存的就是应用和msyql 数据库了,我们没有数据库列表缓存起来,缓存起来测试就显得没有意义了,但是实际使用中是需要开启缓存的。

2000线程

这里我把线程创建时间修改为5s,免得自己的机器被卡死。没有错误,内存快满了,平均延迟到达10s,对于用户使用来说是要被吐槽的,没关系,傻瓜才这么用。

看看偏离,2888,看上去还不错。

到此目的已经达到,经过我们改造后的一粒云的后台(v1.1)处理能力相当优秀,当然这受益于nginx 与nodejs的异步机制。如果你有这方面的难题可以和我们交流。

我们的产品官网是 www.yliyun.com,欢迎大家试用,提供邀请码:[wymf008]。产品是免费的。客服妹子西瓜qq:2941390949。

  • 2500线程 我们还应该继续

出错了,5个请求出错,日志显示都是超时,我们可以看到max这一栏超过60s了,ngx配置keeplive 时间为60s。内存也接近250m。

  • 再试试3000线程

感觉上一把的0.02%的错误还有点小,再压压。

结果差不多,都是超时导致。如果还要提升的并发的话必须要加大内存才行了。

cpu 也一样,我一路监控下来都是在82%-95%,但是nodejs 必须再多开一个进程。

好了,技术是没有优劣没有尽头的,合适自己的才是最好。

单核 -512M内存-2000并发正常使用的更多相关文章

  1. Tomcat从内存、并发、缓存方面优化方法

    Tomcat有很多方面,从内存.并发.缓存四个方面介绍优化方法.   一.Tomcat内存优化 Tomcat内存优化主要是对 tomcat 启动参数优化,我们可以在 tomcat 的启动脚本 cata ...

  2. 如何优化tomcat配置(从内存、并发、缓存4个方面)优化

    Tomcat有很多方面,我从内存.并发.缓存四个方面介绍优化方法.  ** 一.Tomcat内存优化 ** Tomcat内存优化主要是对 tomcat 启动参数优化,我们可以在 tomcat 的启动脚 ...

  3. 512M内存机器如何用好Mysql

    购买阿里云512M内存ECS后,mysql有时候会自动关闭,停止运行 解决办法: a,优化mysql配置,因为自己安装的是mysql 5.6,而从5.6开始,mysql安装包中不再包含my-small ...

  4. Centos6_32位系统512M内存_如何安装gogs_Mysql_配置开机自启动

    因为有很多人的Linux版本比较低,内存配置也较低,X86 ,32位系统的:所以这里推荐采用二进制安装gogs,并且使用Mysql:这个是傻瓜式的安装方案,适合绝大多数人(提及了centos7的安装思 ...

  5. 优化tomcat配置(从内存、并发、缓存3个方面)优化

    Tomcat有很多方面,我从内存.并发.缓存三个方面介绍优化方法. 一.Tomcat内存优化 Tomcat内存优化主要是对 tomcat 启动参数优化,我们可以在 tomcat 的启动脚本 catal ...

  6. 三分钟掌握共享内存 & Actor并发模型

    吃点好的,很有必要.今天介绍常见的两种并发模型: 共享内存&Actor 共享内存 面向对象编程中,万物都是对象,数据+行为=对象: 多核时代,可并行多个线程,但是受限于资源对象,线程之间存在对 ...

  7. 优化tomcat配置(从内存、并发、缓存4个方面)优化

    Tomcat内存优化 Tomcat内存优化主要是对 tomcat 启动参数优化,我们可以在 tomcat 的启动脚本 catalina.sh 中设置 java_OPTS 参数. JAVA_OPTS参数 ...

  8. 【Java并发编程】6、volatile关键字解析&内存模型&并发编程中三概念

    volatile这个关键字可能很多朋友都听说过,或许也都用过.在Java 5之前,它是一个备受争议的关键字,因为在程序中使用它往往会导致出人意料的结果.在Java 5之后,volatile关键字才得以 ...

  9. 【Tomcat】Tomcat配置与优化(内存、并发、管理)【自己配置】

    一.JVM内存配置优化 主要通过以下的几个jvm参数来设置堆内存的: -Xmx512m 最大总堆内存,一般设置为物理内存的1/4 -Xms512m 初始总堆内存,一般将它设置的和最大堆内存一样大,这样 ...

随机推荐

  1. Java正则速成秘籍(三)之见招拆招篇

    导读 正则表达式是什么?有什么用? 正则表达式(Regular Expression)是一种文本规则,可以用来校验.查找.替换与规则匹配的文本. 又爱又恨的正则 正则表达式是一个强大的文本匹配工具,但 ...

  2. Scala化规则引擎

    1. 引言 什么是规则引擎 一个业务规则包含一组条件和在此条件下执行的操作,它们表示业务规则应用程序的一段业务逻辑.业务规则通常应该由业务分析人员和策略管理者开发和修改,但有些复杂的业务规则也可以由技 ...

  3. Debug Databinding Issues in WPF

    DataBinding is one of the most powerful features in WPF. But because it resolves the bindings at run ...

  4. 移动端API接口优化的术和结果

    最近一直在忙工作的事情,所以文章写得有些少. 有3-5篇文章都是写到一半然后被别的事情给打断了,所以,我得找个时间好好补补. 最近一直在关注移动端接口API的可用性问题,在移动时代这个做这个优化能产生 ...

  5. OS存储管理——FIFO,LRU,OPT命中率

    课程设计课题 存储管理程序设计 摘 要 虚拟存储器作为现代操作系统中存储管理的一项重要技术,实现了内存扩充功能.而分页请求分页系统正好可以完美的支持虚拟存储器功能,它具有请求调页功能和页面置换功能.在 ...

  6. Python (一) 简介、安装

    一.简介 Python:是著名的"龟叔"Guido van Rossum在1989年圣诞节期间,为了打发无聊的圣诞节而编写的一个编程语言. 那么Python 究竟是来做什么的? 首 ...

  7. 初识Spring框架实现IOC和DI(依赖注入)

    学习过Spring框架的人一定都会听过Spring的IoC(控制反转) .DI(依赖注入)这两个概念,对于初学Spring的人来说,总觉得IoC .DI这两个概念是模糊不清的,是很难理解的, IoC是 ...

  8. 几句话就能让你理解:this、闭包、原型链

    以下是个人对这三个老大难的总结(最近一直在学习原生JS,翻了不少书,不少文档,虽然还是新手,但我会继续坚持走我自己的路) 原型链 所有对象都是基于Object.prototype,Object.pro ...

  9. Amabri:如何删除或停止指定的服务

    原文地址:https://cwiki.apache.org/confluence/display/AMBARI/Using+APIs+to+delete+a+service+or+all+host+c ...

  10. [转]HttpModule的认识

    HttpModule是向实现类提供模块初始化和处置事件.当一个HTTP请求到达HttpModule时,整个ASP.NET Framework系统还并没有对这个HTTP请求做任何处理,也就是说此时对于H ...