node截图服务可用性报告

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

前言

服务器端截图可以做什么?

个人观点:省去跟报表有关的EDM开发,直接从系统上截图,然后发图片给用户就搞定。剩下的自己脑补。

既然这么好,为毛不赶紧弄。需要用到的工具坑太多,没有尝试,不敢拿上去用。

环境准备

如果是window环境就更简单了,大家自行处理,这里不做介绍。

  1. centos6.5(5.x版本来落后了,不要用,会出问题的。其他高级版本,自己掂量着用,公司提供给我的测试机只有6.5版本)
  2. phantomjs 2.x (1.9.x版本的各种bug,测试的时候并发一起来,进程各种crash,所以大家别脑残用1.9.x的)
  3. nodejs  0.12以上版本(因为4.x版本的gcc要求比较高,我又不会装,所以没法测4.x版本的。注意,一定要编译安装,不然会出很多问题。)
  4. 安装windows字体(按网上的说明来,安装完成要重启机器。不安装会出现中文字体不显示的问题)

安装步骤

 我知道很多人比较懒,也有很多人,这也不懂,那也不懂。所以为了不让大家浪费时间,给大家安装环境步骤,由于系统是64位,因此下面的步骤都是按64位来。windows环境下的安装,自己看文档。

安装phantomjs 2.x

  1.  到http://phantomjs.org/download.html页面下载相应的版本,https://bitbucket.org/ariya/phantomjs/downloads/phantomjs-2.1.1-linux-x86_64.tar.bz2
  2. 解压 tar -xvfz phantomjs-2.1.1-linux-x86_64.tar.bz2
  3. 创建软链,ln -s 相应phantomjs文件夹/phantomjs /usr/bin/phantomjs   ln -s 相应phantomjs文件夹/phantomjs /usr/local/bin/phantomjs
  4. 测试phantomjs命令能不能使用(如果不可以,大家自己看着办)

安装nodejs0.12.x

参考:http://www.laozuo.org/6421.html

  1. 到官网下载node-v0.12.9.tar.gz,特别注意,是源码,不是编译后的
  2. 解压node-v0.12.9.tar.gz
  3. 进入解压后的文件夹逐步执行两条命令1 ./configure  2 make && make install
  4. 验证node -v 看看版本号是不是跟我们安装的一样

安装windows下的字体

 这个直接参考http://www.tuicool.com/articles/VfiqqiA

启动服务

  1. 拷贝源码https://github.com/angrytoro/webshot
  2. 进到根目录后,执行cnpm install来安装相关的模块(因为npm在国内太慢了,经常慢到让你安装错误)
  3. 安装模块成功后,执行node index.js,端口是3000
  4. 在浏览器上浏览

界面介绍

 直接给图说明比较方便



截图效果

由于有200kb的图片上传限制,大家将就下,到百度云盘上看qq官网截图效果

http://pan.baidu.com/s/1qXquUkc

并发请求结果

ps(在另外一台服务器上用wrk测试)

介绍下截图服务机器的硬件配置:2核cpu,4g内存

由于我在程序中限定了开启3个phantomjs,每个phantomjs最多同时做5个页面的渲染和截图。因此我开启了15个线程,保持15个链接同时请求,持续1分钟的时间,效果如下图:


五组测试数据统计

 

序号 网址 持续时间(s) 并发链接 请求总数 成功 失败 崩溃
1 qq.com 60 15 47 47 0 0
2 qq.com 60 15 54 54 0 0
3 qq.com 60 15 45 45 0 0
4 qq.com 60 15 57 57 0 0
5 qq.com 60 15 49 49 0 0
平均
60 15 50.4 50.4 0 0

从中可以看出在截取qq.com的时候,大概平均每秒处理0.84个截图请求。

当然这是在有条件限制的情况下得出的数据,在测试的时候,查看了下cpu的峰值,大概是60%,也就是说这个还有提升的空间。而且我们是用qq.com做测试,如果是比较简单的页面,速度肯定还会提升。

不信请看,我请求http://alinode.aliyun.com/blog/23这个网址的测试


这里数据显示1分钟内总共处理了150个请求。平均每秒处理2.5个

稳定性

下图是跑了1小时的报告,蛮看看。


在一个小时之内连续的对qq.com首页做截图,总共是处理了562个请求,平均每秒0.16个,太忧伤了。大家有没有发现,其实出现了202个读错误,562个超时,平均网速才225.54kb,诶,这也太坑爹了。

不知道这是什么原因造成的,到底是网速慢了,还是qq官网首页服务器做了安全策略。面对如此惨淡的数据,自信心都没了。

其实在早些时候,有尝试跑一个晚上的并发,可惜好像是因为断网问题,导致测试没有完成。之后有进行了持续6个小时的并发测试,在跑到2个多小时的时候,出现了内存溢出,导致服务中断的情况。非常的忧伤,

我都不知道为毛内存溢出(当时跑去吃饭了),好歹也有3G多的内存可以用。在启动服务后,我有观测,内存从3G多,直接降到2G左右,不过一直在这个区间徘徊,不知道为毛会出现内存溢出。

有两种猜测:

  1. 由于是测试腾讯首页,不知道腾讯会不会出现防御,导致请求页面速度变慢,然后phantomjs一直在等待,各种尝试,导致内存溢出。一般情况下,我们在浏览某个页面的时候,也会出现很卡的情况,浏览器出现假死。
  2. 由于V8的内存限制机制,导致在同时渲染15个页面的时候出现内存溢出。

其实每次的并发测试都会出现超时的情况,这个问题不知道是什么原因造成的。

理论上要渲染一个页面,其实是得花不少时间的,加载页面就大概需要2~3秒的时间,加上渲染大概至少需要5秒左右的时间,有些垃圾网站更长,然后我们还要截图,加起来,这大概得花个6~8秒的时间吧。

总结

按照目前并发测试的结果来说是不适合用于生产环境的。如果要小范围的做生产测试,还需要解决下面几个问题

  1. 将某些计算扔给GPU,毕竟GPU在渲染方面还是比较好的。
  2. 提升v8引擎的内存限制
  3. 查找内存溢出的原因并且解决

后记

服务器端截图还是挺有意思的一件事情,如果稳定性提高了,相信可以用于很多地方。由于代码是写来做测试的,所以写得挺烂的,还有很多可以改进的地方。

如果大家觉得这个点子不错,可以继续开发下去,请到github上点个赞,并给点改进意见。

转载于:https://my.oschina.net/u/137634/blog/613484

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/398936.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++的extern关键字

extern是一个声明,不是一个定义,A模块想应用B模块的一个函数或者变量,A模块包含B模块的头文件,并且在变量或者头文件前,加 extern,虽然编译的时候,找不到模块的定义,但是在连接的时候…

Linux网站访问的电脑占CPU,详解Linux如何查看当前占用CPU或内存最多的几个进程...

命令ps -aux | sort -k4nr | head -N命令详解:1、head:-N可以指定显示的行数,默认显示10行。2、ps:参数a指代all——所有的进程,u指代userid——执行该进程的用户id,x指代显示所有程序,不以终端…

Hi,博客园

Hi,博客园! 这是我在博客园的第一篇博文,主要是为了测试发布。 在以后的日子里我会陆续介绍ArcGIS soft的使用及Flex和JS的开发,以及开源GIS的开发,敬请关注。转载于:https://www.cnblogs.com/unitgis/p/4028171.html

java反射快速入门(二)

上一遍博文 , 简单介绍java 反射的常用接口,本遍博文, 我会结合项目开发的实际例子讲解下 java反射的使用 现在有个需求, 要将一个对象转换成xml格式, 或者将一串xml转换一个对象, 这时我们循序渐进, 先从最简单的入手 一: 方案① 场景 : NBA球员信息描述…

Myecplise Tomcat 启动很慢

今天突然遇到一个问题,tomcat在Myecplse启动非常慢,直接用tomcat自带的start.bat启动很快,如果通过Myeclipse启动会发现项目一直在实例化,最后发现是因为加了断点调试,断点忘了去掉了,这个恰恰影响了spring…

C#QQ邮箱验证

注意: QQ邮箱的简单邮件传输协议(SMTP)使用了SSL加密,必须启用SSL加密、指定端口。 QQ邮箱POP3/SMTP服务默认是关闭的,需要开启服务(设置>账户>开启服务)。 QQ邮箱若有独立密码&#xff0…

linux 文件 重命名 缓存,linux – rename()原子性和NFS?

参考:Is rename() atomic?我问的是类似的东西,但不完全相同,因为我想知道的是在使用NFS时依赖于rename()的原子性是否安全?这是我正在处理的一个场景 – 我有一个必须始终存在的’索引’文件.所以:>客户端创建一个新文件>客户端通过“…

Win2008上.NET4.0部署出错HTTP 错误 500.21 - Internal Server Error的解决方法

原因:在安装Framework v4.0之后,再启用IIS,导致Framework没有完全安装 解决:开始->所有程序->附件->鼠标右键点击“命令提示符”->以管理员身份运行,输入以下命令: %windir%\\Microsoft.NET\\F…

ORACLE DATAGURARD配置手记

经过多次实践,参阅网上N多文章……最后还是配不成,可能本人悟性太低,无法体会高手的笔记。最终还是在前辈的帮助下完成。特用最平实的手法记录下来,以便如吾辈菜鸟能 看得懂。 运行Data Guard的条件 1、 在主库和从库的所有机器上…

浅谈ASP.NET框架

本篇文章更适合具有一定开发经验,一定功底,且对底层代码有所研究的朋友!!! 本篇文章稍微偏原理且底层,有一定难度和且比较晦涩,文章粒度稍微粗些,更细粒度的,会在后续的文…

C语言之冒泡排序

假设要对含有n个数的序列进行升序排列,冒泡排序算法步骤是: 1、从存放序列的数组中的第一个元素开始到最后一个元素,依次对相邻两数进行比较,若前者大后者小,则交换两数的位置; 2、第1趟结束后,…

eclipse常用的快捷键

2014年10月17日10:29:50 1.CtrlSpace 说明:内容助理。提供对方法,变量,参数,javadoc等得提示, 应运在多种场合,总之需要提示的时候可先按此快捷键。 注:避免输入法的切换设置与此设置冲突 2.Ctrl/ 说明:添加/消除//注释,在eclipse2.0中,消除注释为Ctrl\ 3.CtrlShift/ 说明:添加…

linux sar 历史负载,查看负载、vmstat、top、sar以及nload命令

使用w查看系统负载1.w命令,查看系统负载:单位时间内使用cpu的活动的进程有多少个[rootweix01 ~]# w #load average 后面三个数字表示1分钟,5分钟,15分钟的负载值,最合适的是逻辑cpu数量与1分钟负载一致21:10:21 up 8 m…

【HDOJ】4358 Boring counting

基本思路是将树形结构转线性结构,因为查询的是从任意结点到叶子结点的路径。从而将每个查询转换成区间,表示从该结点到叶子结点的路径。离线做,按照右边界升序排序。利用树状数组区间修改。树状数组表示有K个数据的数量,利用pos进…

linux系统编程:IO读写过程的原子性操作实验

所谓原子性操作指的是:内核保证某系统调用中的所有步骤(操作)作为独立操作而一次性加以执行,其间不会被其他进程或线程所中断。 举个通俗点的例子:你和女朋友OOXX的时候,突然来了个电话,势必会打…

Intent.createChooser文件选择

实现点击Button选择文件, 在TextView上显示Uri 1 <RelativeLayout xmlns:android"http://schemas.android.com/apk/res/android"2 xmlns:tools"http://schemas.android.com/tools"3 android:layout_width"match_parent"4 android…

c语言 数组扩容,数组的扩容

用数组模拟栈数组是固定大小的&#xff0c;不能改变长度&#xff0c;要想达到数组扩容的目的&#xff0c;就只能把当前数组复制到一个更长长度的数组中&#xff1b;使用Arrays.copyOf()方法源码如下&#xff1a;public static short[] copyOf(short[] original, int newLength)…

ubuntu修改固定ip

1.vi /etc/network/interfasces,添加红框内的内容&#xff1a; 2.配置DNS, vi /etc/resolv.conf, 再该文件下添加&#xff1a; nameserver 192.168.1.1 nameserver 220.170.64.68 3.改完上面&#xff0c;如果重启的话&#xff0c;还是会变为原来的样子&#xff0c;所以要让其永…

折半插入排序c语言 csdn,排序算法实大.doc

排序算法实现大全后面的例程&#xff0c;都是对数组的排序&#xff0c;使用静态链表的也适用于链表的排序。为简单起见&#xff0c;只对单关键码排序&#xff0c;并且最后的结果都是从头到尾按升序排列。下面是统一的测试程序&#xff1a;#include #include using namespace st…

嵌入式开发-lesson9-顺序结构程序设计

Lesson9-顺序程序设计 一、常量与变量 1、常量 在程序运行过程中&#xff0c;其值不能改变的量&#xff0c;叫做常量。 f(x) 2x 1 常用的常量有以下几种类型&#xff1a; 1&#xff09;整型常量&#xff0c; 100&#xff0c; 0&#xff0c; -234 2&#xff09;实型常量…