压力测试工具Siege介绍

简介: # Siege Overview ## What IS IT ? Siege是一个开源的压力测试和基准工具。它可以通过用户模拟多用户来压力测试一个单一URL或者它可以把多个URLs放置内存中,并且同时测试他们。

# Siege Overview

## What IS IT ?


Siege是一个开源的压力测试和基准工具。它可以通过用户模拟多用户来压力测试一个单一URL或者它可以把多个URLs放置内存中,并且同时测试他们。这个程序会生成一个关于the total number of hits recorded, bytes transferred, response time, concurrency, and return status的报告。Siege支持HTTP/1.0和1.1协议,GET和POST指令,cookies,transaction logging和基本的身份验证。它的功能对每一个基础用户来说都是可配置的。


大部分的功能是可以通过command line options进行配置,这些参数文件可都会有一个默认值来减少程序带调用的复杂性。Siege允许你通过n个用户进行t次测试,来对web服务器做压力测试。其中n,t这个变量用户可以定义。它会记录这个测试的持续时间和每一个事务的持续时间。它会生成一个number of transactions, elapsed time, bytes transferred, response time, transaction rate, concurrency和响应200状态的服务访问OK的状态的次数信息报告。


Siege是由Jeffrey Fulmer设计实现的,它在Lincoln Stein's torture.pl之后被设置为模块的一部分,它的数据报告也是一致的,但是torture.pl不能允许对多个URLS进行并发测试。而siege可以。


当一台HTTP服务被这个siege访问的时候,他会说"under siege."



## WHY DO I NEED IT ?


Siege是被web开发者和web系统管理员编码而成。它允许这些用户在压力下测试他们的程序和他们的系统。作为一个web专业人员,你有责任保证你的产品的完整性,同时你没法控制谁能登录它,因此吞吐峰值随时可能发生。你做好准备了吗?


Siege使你可以在压力下测试这些应用程序,让你知道他们可以忍受多大的负载。如果你的网站峰值当前是250,而你清楚地知道你的网站可以抵抗400并发事务,那你一定睡得很好。


一个事务可以被定义为一个客户端打开服务套接字,处理一个请求,数据通过网络传输然后完成后关闭套接字。最重要的是要考虑的是,人类互联网用户是要花费时间来消化吸收这些消息。因此,实践中,我发现400个并发用户需要至少5次来完成这个会话操作。这是为什么我会允许你设置一个delay参数。当设置后,每一个siege用户会在1和NUM秒钟睡眠后,再访问。通过服务器日志可以得到访问一个页面的平均花费的时间。当进行并发访问测试的时候建议使用delay参数。


## WHERE IS IT ?


最近的sige版本可以通过FTP获得:http://download.joedog.org/siege/siege-latest.tar.gz


在github上的源代码知识库:git clone https://github.com/JoeDog/siege.git


你可以通过浏览器访问: https://github.com/JoeDog/siege


更新和公告会在JoeBlog中发布: http://www.joedog.org/blog


## INSTALLATION


Siege是通过GNU autoconf构建。如果你熟悉GNU软件,你会非常方便的安装siege,更多细节请查看Install文件


## PREREQUISITES


如果您想支持HTTPS支持,你需要安装openssl到你的系统上面.http://www.openssl.org/。更多安装指导,可以看section 2 of INSTALL.


## DOCUMENTATION


Documentation is available in man pages siege(1) layingsiege(1) An html manual is included with this distribution: manual.html


关于siege完整的文档可以在 www.joedog.org 页面找到

相关文章
|
4月前
|
前端开发 测试技术 Python
【Selenium全攻略】掌握这一工具,实现自动化测试的所有梦想
本文分享了使用Selenium进行UI自动化测试的全过程,包括开发环境部署、代码实现、思路分析和难点解析。作者通过一个实际案例,讲述了如何利用Selenium处理前端生成报告失败的问题,以及在UI自动化中定位元素和处理元素不唯一的情况。同时,文章强调了解决问题思路的重要性,鼓励读者开拓思维,寻找不同的解决方案。
148 4
【Selenium全攻略】掌握这一工具,实现自动化测试的所有梦想
|
16天前
|
安全 前端开发 测试技术
如何选择合适的自动化安全测试工具
选择合适的自动化安全测试工具需考虑多个因素,包括项目需求、测试目标、系统类型和技术栈,工具的功能特性、市场评价、成本和许可,以及集成性、误报率、社区支持、易用性和安全性。综合评估这些因素,可确保所选工具满足项目需求和团队能力。
|
15天前
|
安全 网络协议 关系型数据库
最好用的17个渗透测试工具
渗透测试是安全人员为防止恶意黑客利用系统漏洞而进行的操作。本文介绍了17款业内常用的渗透测试工具,涵盖网络发现、无线评估、Web应用测试、SQL注入等多个领域,包括Nmap、Aircrack-ng、Burp Suite、OWASP ZAP等,既有免费开源工具,也有付费专业软件,适用于不同需求的安全专家。
28 2
|
15天前
|
监控 网络协议 Java
一些适合性能测试脚本编写和维护的工具
一些适合性能测试脚本编写和维护的工具
|
26天前
|
Web App开发 定位技术 iOS开发
Playwright 是一个强大的工具,用于在各种浏览器上测试应用,并模拟真实设备如手机和平板。通过配置 `playwright.devices`,可以轻松模拟不同设备的用户代理、屏幕尺寸、视口等特性。此外,Playwright 还支持模拟地理位置、区域设置、时区、权限(如通知)和配色方案,使测试更加全面和真实。例如,可以在配置文件中设置全局的区域设置和时区,然后在特定测试中进行覆盖。同时,还可以动态更改地理位置和媒体类型,以适应不同的测试需求。
Playwright 是一个强大的工具,用于在各种浏览器上测试应用,并模拟真实设备如手机和平板。通过配置 `playwright.devices`,可以轻松模拟不同设备的用户代理、屏幕尺寸、视口等特性。此外,Playwright 还支持模拟地理位置、区域设置、时区、权限(如通知)和配色方案,使测试更加全面和真实。例如,可以在配置文件中设置全局的区域设置和时区,然后在特定测试中进行覆盖。同时,还可以动态更改地理位置和媒体类型,以适应不同的测试需求。
27 1
|
2月前
|
Java 流计算
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
43 1
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
|
2月前
|
jenkins 测试技术 持续交付
提升软件测试效率的实用技巧与工具
【10月更文挑战第12天】 本文将深入探讨如何通过优化测试流程、引入自动化工具和持续集成等策略,来显著提高软件测试的效率。我们将分享一些实用的技巧和工具,帮助测试人员更高效地发现和定位问题,确保软件质量。
53 2
|
2月前
|
测试技术
黑盒功能测试工具UFT的使用
黑盒功能测试工具UFT的使用
38 0
黑盒功能测试工具UFT的使用
|
2月前
|
XML 网络安全 数据格式
Kali渗透测试:Windows事件管理工具wevtutil的使用方法(一)
Kali渗透测试:Windows事件管理工具wevtutil的使用方法(一)
|
3月前
|
测试技术
基于LangChain手工测试用例转App自动化测试生成工具
在传统App自动化测试中,测试工程师需手动将功能测试用例转化为自动化用例。市面上多数产品通过录制操作生成测试用例,但可维护性差。本文探讨了利用大模型直接生成自动化测试用例的可能性,介绍了如何使用LangChain将功能测试用例转换为App自动化测试用例,大幅节省人力与资源。通过封装App底层工具并与大模型结合,记录执行步骤并生成自动化测试代码,最终实现高效自动化的测试流程。