当前位置: 首页 > article >正文

每天掌握一个Linux命令 - ab(Apache Benchmark)

Linux 命令工具 ab 使用指南

一、工具概述

ab(Apache Benchmark) 是 Apache 官方提供的开源压力测试工具,用于衡量 Web 服务器的性能。它通过模拟多并发请求,测试服务器在高负载下的响应速度、吞吐量和稳定性,常用于评估网站或 API 的性能表现。

核心特点

  • 轻量级:无需复杂安装,适合快速测试。
  • 高可配置性:支持自定义并发数、请求次数、请求头、超时时间等参数。
  • 结果清晰:输出包含请求总数、失败率、吞吐量、平均响应时间等关键指标。

二、安装方式

1. Debian/Ubuntu 系统

sudo apt update
sudo apt install apache2-utils  # ab 包含在该软件包中

2. CentOS/RHEL 系统

sudo yum install httpd-tools

3. 源码编译安装(适用于其他 Linux 系统)

# 下载 Apache 源码包
wget https://downloads.apache.org/apr/apr-1.7.0.tar.gz
wget https://downloads.apache.org/apr/apr-util-1.6.1.tar.gz
wget https://downloads.apache.org/httpd/httpd-2.4.57.tar.gz# 编译安装 APR 和 APR-Util
tar -zxvf apr-1.7.0.tar.gz
cd apr-1.7.0
./configure
make && sudo make installcd ..
tar -zxvf apr-util-1.6.1.tar.gz
cd apr-util-1.6.1
./configure --with-apr=/usr/local/apr
make && sudo make install# 编译安装 httpd(含 ab 工具)
cd ..
tar -zxvf httpd-2.4.57.tar.gz
cd httpd-2.4.57
./configure --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util
make && sudo make install
# ab 工具路径:/usr/local/apache2/bin/ab

三、核心功能

功能分类说明
并发测试模拟多用户同时访问,测试服务器对并发连接的处理能力。
吞吐量统计计算服务器每秒处理的请求数(Requests per second)。
响应时间分析统计请求的平均响应时间、最大/最小响应时间及时间分布(如 50%/95% 耗时)。
自定义请求支持设置请求方法(GET/POST)、请求头、请求体、URL 参数等。
长连接测试支持保持 HTTP 连接(-k 参数),测试持久连接性能。

四、基础用法

基本语法

ab [选项] [目标 URL]

常用选项说明

选项描述
-n总请求次数(必填)。
-c并发用户数(必填)。
-t测试持续时间(秒),与 -n 二选一。
-k启用 HTTP 长连接(keep-alive)。
-H添加请求头,格式:-H "Header: Value"(可多次使用)。
-p指定 POST 请求的参数文件(文件内容为参数,如 key=value)。
-T设置 POST 请求的 Content-Type,如 -T "application/x-www-form-urlencoded"
-v输出详细信息,数值越大越详细(如 -v 4)。

示例:GET 请求基础测试

# 测试百度首页,100 个请求,5 个并发
ab -n 100 -c 5 http://www.baidu.com/

输出结果解读

Concurrency Level:      5        # 并发数
Time taken for tests:   0.323秒   # 总耗时
Complete requests:      100      # 完成请求数
Failed requests:        0        # 失败请求数(非 2xx/3xx 状态码)
Total transferred:      138700 bytes # 传输总数据量
HTML transferred:       131610 bytes # HTML 内容大小
Requests per second:    309.60 [#/sec] (mean) # 吞吐量(QPS)
Time per request:       16.150 [ms] (mean)   # 平均每个请求的耗时(所有并发)
Time per request:       3.230 [ms] (mean, across all concurrent requests) # 单个并发的平均耗时
Transfer rate:          417.57 [Kbytes/sec] received # 数据传输速率

五、进阶操作

1. POST 请求测试

# 通过 -p 指定参数文件(post_data.txt 内容:username=test&password=123)
ab -n 50 -c 10 -p post_data.txt -T "application/x-www-form-urlencoded" http://api.example.com/login

2. 自定义请求头

# 添加自定义认证头和 Content-Type
ab -n 100 -c 20 -H "Authorization: Bearer your_token" -H "Content-Type: application/json" http://api.example.com/data

3. 长连接测试(-k)

ab -n 500 -c 50 -k http://example.com/static-files

4. 限制测试时间(-t)

# 持续测试 30 秒,自动计算请求次数
ab -c 100 -t 30 http://video.example.com/stream

5. 输出详细调试信息(-v)

ab -v 4 -n 10 -c 2 http://localhost:8080/api # 显示请求头、响应状态码等细节

六、实战案例

案例:测试 Nginx 静态文件服务器性能

场景:模拟 200 个并发用户,持续请求 60 秒,测试 /images 目录下的图片文件。

ab -c 200 -t 60 -k http://nginx-server/images/

预期目标

  • 吞吐量(QPS)稳定在 5000+
  • 平均响应时间 < 50ms
  • 失败请求数为 0

优化方向

  • 若 QPS 不足,可调整 Nginx 的 worker_connections 或开启缓存(proxy_cache)。
  • 若响应时间过高,检查磁盘 I/O 或网络带宽瓶颈。

七、注意事项

1. 服务器安全

  • 避免对生产环境直接进行压测,建议先在预发布环境测试。
  • 控制并发数和请求频率,防止压测导致服务崩溃(可逐步增加 -c 参数)。

2. 测试局限性

  • ab 是单进程工具,无法完全模拟真实用户行为(如浏览器渲染、JS 执行)。
  • 高并发下可能受限于客户端机器性能(如 CPU/网络带宽),需确保客户端资源充足。

3. 参数调优

  • 若出现 connect() failed 错误,可能是客户端端口耗尽,可临时调整系统参数:
    sudo sysctl -w net.ipv4.ip_local_port_range="1024 65535"
    
  • 对于 HTTPS 测试,需使用 -S(SSL 证书)和 -P(客户端证书)参数,或改用其他工具(如 wrk)。

4. 结果解读

  • 关注 失败请求数(非 2xx/3xx 状态码)和 异常耗时分布(如 95% 耗时突然升高)。
  • 多次测试取平均值,避免单次结果受临时因素干扰。

通过以上指南,可快速掌握 ab 的核心用法,结合实际场景进行性能测试和优化。对于更复杂的负载场景,可考虑使用 wrkJMeter 等专业工具补充测试。

相关文章:

每天掌握一个Linux命令 - ab(Apache Benchmark)

Linux 命令工具 ab 使用指南 一、工具概述 ab&#xff08;Apache Benchmark&#xff09; 是 Apache 官方提供的开源压力测试工具&#xff0c;用于衡量 Web 服务器的性能。它通过模拟多并发请求&#xff0c;测试服务器在高负载下的响应速度、吞吐量和稳定性&#xff0c;常用于…...

与 PyCharm 官方沟通解决开发环境问题记录(进展:官方已推出2个新的修复版本)

​​​​​​主题&#xff1a;有关 PyCharm 中终端和环境激活问题的反馈&#xff1a;PY-81233 前言 目前进展&#xff1a; 官方已有2个修复版本推出测试。 更新方法&#xff1a; 使用JetBrains Toolbox App&#xff0c;如下图所示&#xff0c;从“其他版本”进入查看更新。…...

Python的分布式网络爬虫系统实现

1. 系统架构概述 一个典型的分布式网络爬虫系统通常包含以下几个核心组件&#xff1a; 1.主节点&#xff08;Master Node&#xff09;&#xff1a; 任务调度&#xff1a;负责将抓取任务分配给各个工作节点。URL 管理&#xff1a;维护待抓取的 URL 队列和已抓取的 URL 集合&a…...

Vue快速上手(业务、技术、报错)

Vue 技术业务报错 技术 业务 Vueelement-ui&#xff0c;实现表格渲染缩略图&#xff0c;鼠标悬浮缩略图放大&#xff0c;点击缩略图播放视频&#xff08;一&#xff09; 报错 vue修改配置文件.env.development不生效 vue前端downloadFile报错&#xff1a;Error parsing HT…...

taro + vue3 实现小程序sse长连接实时对话

前言 taro.request是可以实现sse长连接的&#xff0c;但是呢其中有俩大坑&#xff0c;找了许多资料也没解决&#xff0c;后续解决办法也与后端商量改用WebSocket来实现。 代码实现 SSEManager.js: import { getAccessToken } from "../xx/xx"; import { TextDecode…...

使用MATLAB求解微分方程:从基础到实践

使用MATLAB求解微分方程&#xff1a;从基础到实践 微分方程是描述自然界和工程领域中许多现象的重要数学工具。MATLAB提供了强大的工具来求解各种类型的微分方程。本文将介绍如何使用MATLAB求解常微分方程(ODE)。 1. 基本ODE求解器 MATLAB提供了多种ODE求解器&#xff0c;最…...

基于MATLAB的大规模MIMO信道仿真

1. 系统模型与参数设置 以下是一个单小区大规模MIMO系统的参数配置示例&#xff0c;适用于多发多收和单发单收场景。 % 参数配置 params.N_cell 1; % 小区数量&#xff08;单小区仿真&#xff09; params.cell_radius 500; % 小区半径&#xff08;米&#xff09…...

如何在 Windows 和 Mac 上擦拭和清洁希捷外置硬盘

希捷外置硬盘广泛用于存储目的&#xff0c;但有时您可能出于多种目的需要擦除或清洁希捷外置硬盘&#xff0c;例如转售、重复使用、捐赠等。为了释放硬盘上的存储空间或确保没有人可以从硬盘中恢复您的信息&#xff0c;擦除硬盘是必要的步骤。无论您使用的是 Windows 还是 Mac&…...

Vue 3.0 中状态管理Vuex 与 Pinia 的区别

在 Vue.js 应用开发中&#xff0c;状态管理是构建复杂应用的关键环节。随着 Vue 3 的普及和 Composition API 的引入&#xff0c;开发者面临着状态管理库的选择问题&#xff1a;是继续使用经典的 Vuex&#xff0c;还是转向新兴的 Pinia&#xff1f;本文将从设计理念、API 设计、…...

第三届黄河流域网安技能挑战赛复现

Web 奶龙牌图片处理器2.0 这题&#xff0c;之前只了解过 .user.ini 文件&#xff0c;并为遇到实操题 但赛前差点就做到下面这题了&#xff0c;不多说&#xff0c;复现之前先看看下面这题 靶场&#xff1a; 攻防世界 没错&#xff0c;又做上文件上传题了&#xff0c;别看…...

python 生成复杂表格,自动分页等功能

py&#xff54;&#xff48;&#xff4f;&#xff4e; 生成复杂表格&#xff0c;自动分页等功能 解决将Python中的树形目录数据转换为Word表格&#xff0c;并生成带有合并单元格的检测报告的问题。首先&#xff0c;要解决“tree目录数据”和“Word表格互换”&#xff0c;指将树…...

2025年高防IP与游戏盾深度对比:如何选择最佳防护方案?

2025年&#xff0c;随着DDoS攻击规模的指数级增长和混合攻击的常态化&#xff0c;高防IP与游戏盾成为企业网络安全的核心选择。然而&#xff0c;两者在功能定位、技术实现及适用场景上存在显著差异。本文结合最新行业实践与技术趋势&#xff0c;全面解析两者的优劣&#xff0c;…...

在 Vue + Vite 项目中,直接使用相对路径或绝对路径引用本地图片资源时,图片无法正确显示。

Vue 项目中静态资源引用问题 1.问题描述 在 Vue Vite 项目中&#xff0c;直接使用相对路径或绝对路径引用本地图片资源时&#xff0c;图片无法正确显示。 错误示例 javascript // 错误方式1&#xff1a;使用相对路径 const products [ { name: iPhone 14 Pro, image: .…...

判断手机屏幕上的横向滑动(左滑和右滑)

在JavaScript中&#xff0c;你可以通过监听触摸事件&#xff08;touch events&#xff09;来判断用户在手机屏幕上的横向滑动方向。以下是实现方法&#xff1a; 基本实现方案 let touchStartX 0; let touchEndX 0;function handleTouchStart(event) {touchStartX event.ch…...

用户有一个Django模型没有设置主键,现在需要设置主键。

用户有一个Django模型没有设置主键&#xff0c;现在需要设置主键。 from django.db import modelsclass CategoryAssistentModel(models.Model):second_level_category models.CharField(max_length100, nullTrue, blankTrue)third_level_category models.CharField(max_len…...

【文献阅读】EndoChat: Grounded Multimodal Large Language Model for Endoscopic Surgery

[2501.11347] EndoChat: Grounded Multimodal Large Language Model for Endoscopic Surgery 2025年1月 数据可用性 Surg-396K 数据集可在 GitHub - gkw0010/EndoChat 公开获取。 代码可用性 EndoChat 的代码可在 GitHub - gkw0010/EndoChat 下载。 摘要 近年来&#xff…...

React JSX语法介绍(JS XML)(一种JS语法扩展,允许在JS代码中编写类似HTML的标记语言)Babel编译

在线调试网站&#xff1a;https://zh-hans.react.dev/learn 文章目录 JSX&#xff1a;现代前端开发的声明式语法概述JSX的本质与工作原理什么是JSXJSX转换流程 JSX语法特性表达式嵌入&#xff08;JSX允许在大括号内嵌入任何有效的JavaScript表达式&#xff09;属性传递&#xf…...

【R语言编程绘图-箱线图】

基本箱线图绘制 使用ggplot2绘制箱线图的核心函数是geom_boxplot()。以下是一个基础示例&#xff0c;展示如何用iris数据集绘制不同物种&#xff08;Species&#xff09;的萼片长度&#xff08;Sepal.Length&#xff09;分布&#xff1a; library(ggplot2) ggplot(iris, aes(…...

【elasticsearch 7 或8 的安装及配置SSL 操作指引】

1.标题获取安装文件 cd /opt/tools wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-8.11.4-linux-x86_64.tar.gz tar -zxvf elasticsearch-8.11.4-linux-x86_64.tar.gz mv /opt/tools/elasticsearch-8.11.4 /opt/elasticsearch #配置vm.max_map_co…...

GitHub 趋势日报 (2025年05月23日)

本日报由 TrendForge 系统生成 https://trendforge.devlive.org/ &#x1f310; 本日报中的项目描述已自动翻译为中文 &#x1f4c8; 今日整体趋势 Top 10 排名项目名称项目描述今日获星总星数语言1All-Hands-AI/OpenHands&#x1f64c;开放式&#xff1a;少代码&#xff0c;做…...

MongoDB索引:原理、实践与优化指南

为什么索引对数据库如此重要&#xff1f; 在现代应用开发中&#xff0c;数据库性能往往是决定用户体验的关键因素。想象一下&#xff0c;当你在电商平台搜索商品时&#xff0c;如果每次搜索都需要等待5-10秒才能看到结果&#xff0c;这种体验是多么令人沮丧。MongoDB作为最流行…...

SQL实战之索引优化(单表、双表、三表、索引失效)

文章目录 单表优化双表优化三表优化结论索引失效 单表优化 总体原则&#xff1a;建立索引并合理使用&#xff0c;避免索引失效 案例说明&#xff1a;查询category_ id 为1且comments大于1的情况下,views最多的article_ id: 传统方案&#xff1a; explain select id, author_ id…...

[7-1] ADC模数转换器 江协科技学习笔记(14个知识点)

1 2 3 4 5 6 7 8 9 10 11 12 13 14 DMA&#xff08;Direct Memory Access&#xff0c;直接内存访问&#xff09;是一种硬件特性&#xff0c;它允许某些硬件子系统直接访问系统的内存&#xff0c;而无需CPU的介入。这样&#xff0c;CPU就可以处理其他任务&#xff0c;从而提高系…...

SSM整合:Spring+SpringMVC+MyBatis完美融合实战指南

前言 在Java企业级开发领域&#xff0c;SSM&#xff08;SpringSpringMVCMyBatis&#xff09;框架组合一直占据着重要地位。这三个轻量级框架各司其职又相互配合&#xff0c;为开发者提供了高效、灵活的开发体验。本文将深入探讨SSM框架的整合过程&#xff0c;揭示整合背后的原…...

Spring Boot分页查询进阶:整合Spring Data REST实现高效数据导航

目录&#xff1a; 引言分页查询基础回顾 2.1 Spring Data JPA分页接口 2.2 Pageable与Page的使用 2.3 常见分页参数设计Spring Data REST简介 3.1 HATEOAS与超媒体驱动API 3.2 Spring Data REST核心功能 3.3 自动暴露Repository接口整合Spring Boot与Spring Data REST 4.1 项目…...

阿里云 Serverless 助力海牙湾构建弹性、高效、智能的 AI 数字化平台

作者&#xff1a;赵世振、十眠、修省 “通过阿里云 Serverless 架构&#xff0c;我们成功解决了弹性能力不足、资源浪费与运维低效的痛点。SAE 的全托管特性大幅降低技术复杂度。未来&#xff0c;我们将进一步探索 Serverless 与 AI 的结合&#xff0c;为客户提供更智能的数字…...

升级node@22后运行npm install报错 distutils not found

从node20升级到node22后&#xff0c;在运行 npm install 的时候报了很多 gyp 错误&#xff0c;其中包括 npm error npm error ModuleNotFoundError: No module named distutils。 问题原因是我在使用 brew install node22 的过程中自动把 python 升级到了 3.13。而 distutils …...

一个开源的多播放源自动采集在线影视网站

这里写自定义目录标题 欢迎使用Markdown编辑器GoFilm简介项目部署1、前置环境准备1.2 redis 配置 film-api 后端服务配置将 GoFilm 项目根目录下的 film 文件夹上传到 linux 服务器的 /opt 目录下 2. 构建运行1. docker 部署1.1 安装 docker , docker compose 环境 注意事项: 2…...

【PhysUnits】10 减一操作(sub1.rs)

一、源码 代码实现了一个类型级别的减一操作(Sub1 trait)&#xff0c;通过Rust的类型系统在编译期完成数值减一的计算。 //! 减一操作特质实现 / Decrement operation trait implementation //! //! 提供类型级别的减一计算 / Provides type-level decrement operationuse su…...

深度检测与动态透明度控制 - 基于Babylon.js的遮挡检测实现解析

首先贴出实现代码&#xff1a; OcclusionFader.ts import { AbstractEngine, Material, type Behavior, type Mesh, type PBRMetallicRoughnessMaterial, type Scene } from "babylonjs/core"; import { OcclusionTester } from "../../OcclusionTester"…...