网站性能压力测试是服务器网站性能调优过程中必不可缺少的一环。只有让服务器处在高压情况下,才能真正体现出软件、硬件等各种设置不当所暴露出的问题。
性能测试工具目前最常见的有以下几种:ab、http_load、webbench、siege。今天我们专门来介绍ab。
ab是apache自带的压力测试工具。ab非常实用,它不仅可以对apache服务器进行网站访问压力测试,也可以对或其它类型的服务器进行压力测试。比如nginx、tomcat、IIS等。 官方参数文档
一、ab的原理
ab是apachebench命令的缩写。
ab的原理:ab命令会创建多个并发访问线程,模拟多个访问者同时对某一URL地址进行访问。它的测试目标是基于URL的,因此,它既可以用来测试apache的负载压力,也可以测试nginx、lighthttp、tomcat、IIS等其它Web服务器的压力。
ab命令对发出负载的计算机要求很低,它既不会占用很高CPU,也不会占用很多内存。但却会给目标服务器造成巨大的负载,其原理类似CC攻击。自己测试使用也需要注意,否则一次上太多的负载。可能造成目标服务器资源耗完,严重时甚至导致死机。
二、ab的安装
ab的安装非常简单,如果是源码安装apache的话,那就更简单了。apache安装完毕后ab命令存放在apache安装目录的bin目录下。如下:
/usr/local /apache2/bin
如果apache 是通过yum的RPM包方式安装的话,ab命令默认存放在/usr/bin目录下。如下:
which ab
注意:如果不想安装apache但是又想使用ab命令的话,我们可以直接安装apache的工具包httpd-tools。如下:
yum -y install httpd-tools
查看ab是否安装成功,可以切换到上述目录下,使用ab –V命令进行检测。如下:
ab -V
如果ab安装成功,通过ab –V命令则会显示ab的相迎版本,如上图示。
注意以上是在linux平台下进行安装的,如果是windows平台下,我们也可以下载对应的apache版本进行安装。
目前apache最新版2.4.10,apache官网已经没有windows下载的版本。
三、ab参数说明
有关ab命令的使用,我们可以通过帮助命令进行查看。如下:
- -
下面我们对这些参数,进行相关说明。如下:
-n 在测试会话中所执行的请求个数。默认时,仅执行一个请求。
-c 一次产生的请求个数。默认是一次一个。
-t 测试所进行的最大秒数。其内部隐含值是-n 50000 ,它可以使对服务器的测试限制在一个固定的总时间以内。默认时,没有时间限制。
-p 包含了需要POST 的数据的文件。
-P 对一个中转代理提供BASIC 认证信任。用户名和密码由一个: 隔开,并以base64编码形式发送。无论服务器是否需要(即, 是否发送了401 认证需求代码),此字符串都会被发送。
-T POST 数据所使用的Content -type头信息。
-v 设置显示信息的详细程度-4 或更大值会显示头信息,3 或更大值可以显示响应代码(404 ,200 等),2 或更大值可以显示警告和其他信息。
-V 显示版本号并退出。
-w 以HTML 表的格式输出结果。默认时,它是白色背景的两列宽度的一张表。
-i 执行HEAD 请求,而不是GET 。
-x 设置属性的字符串。
-X 对请求使用代理服务器。
-y 设置属性的字符串。
-z 设置 属性的字符串。
-C 对请求附加一个Cookie : 行。其典型形式是name=value的一个参数对,此参数可以重复。
-H 对请求附加额外的头信息。此参数的典型形式是一个有效的头信息行,其中包含了以冒号分隔的字段和值的对(如,"Accept-Encoding:zip/zop;8bit" )。
-A 对服务器提供BASIC 认证信任。用户名和密码由一个: 隔开,并以base64编码形式发送。无论服务器是否需要(即,是否发送了401 认证需求代码),此字符串都会被发送。
-h 显示使用方法。
-d 不显示"percentage served within XX [ms] table" 的消息(为以前的版本提供支持)。
-e 产生一个以逗号分隔的(CSV )文件,其中包含了处理每个相应百分比的请求所需要(从1 %到100 %)的相应百分比的(以微妙为单位)时间。由于这种格式已经“二进制化”,所以比'gnuplot' 格式更有用。
-g 把所有测试结果写入一个'gnuplot' 或者TSV (以Tab 分隔的)文件。此文件可以方便地导入到Gnuplot ,IDL ,Mathematica ,Igor 甚至Excel 中。其中的第一行为标题。
-i 执行HEAD 请求,而不是GET 。
-k 启用HTTP KeepAlive 功能,即在一个HTTP 会话中执行多个请求。默认时,不启用KeepAlive 功能。
-q 如果处理的请求数大于150 ,ab每处理大约10 %或者100 个请求时,会在stderr输出一个进度计数。此-q标记可以抑制这些信息。
四、ab性能指标
在进行性能测试过程中有几个指标比较重要:
1、吞吐率(Requests per second)
服务器并发处理能力的量化描述,单位是reqs/s,指的是在某个并发用户数下单位时间内处理的请求数。某个并发用户数下单位时间内能处理的最大请求数,称之为最大吞吐率。
记住:吞吐率是基于并发用户数的。这句话代表了两个含义:
a、吞吐率和并发用户数相关
b、不同的并发用户数下,吞吐率一般是不同的
计算公式:总请求数/处理完成这些请求数所花费的时间,即
Request per second=Complete requests/Time taken for tests
必须要说明的是,这个数值表示当前机器的整体性能,值越大越好。
2、并发连接数(The number of concurrent connections)
并发连接数指的是某个时刻服务器所接受的请求数目,简单的讲,就是一个会话。
3、并发用户数(Concurrency Level)
要注意区分这个概念和并发连接数之间的区别,一个用户可能同时会产生多个会话,也即连接数。在HTTP/1.1下,IE7支持两个并发连接,IE8支持6个并发连接,FireFox3支持4个并发连接,所以相应的,我们的并发用户数就得除以这个基数。
4、用户平均请求等待时间(Time per request)
计算公式:处理完成所有请求数所花费的时间/(总请求数/并发用户数),即:
Time per request=Time taken for tests/(Complete requests/Concurrency Level)
5、服务器平均请求等待时间(Time per request:across all concurrent requests)
计算公式:处理完成所有请求数所花费的时间/总请求数,即:
Time taken for/testsComplete requests
可以看到,它是吞吐率的倒数。
同时,它也等于用户平均请求等待时间/并发用户数,即
Time per request/Concurrency Level
五、ab实际使用
[root@centos7 ~]#ab -c 10 -n 100 http://a.ilanni.com/index.php
-c 10 表示并发用户数为10
-n 100 表示请求总数为100
http://a.ilanni .com /index.php 表示请求的目标URL
这行表示同时处理100 个请求并运行10 次index.php 文件。
[root@centos7 ~]#ab -c 10 -n 100 http://a.ilanni.com/index.php
Benchmarking 47.93 .96 .25 (be patient).....done
Server Software: Apache/2.4 .29 ##apache版本
Server Hostname: ip地址 ##请求的机子
Server Port: 80 ##请求端口
Document Path: index.php
Document Length: 18483 bytes ##页面长度
Concurrency Level: 10 ##并发数
Time taken for tests: 25.343 seconds ##共使用了多少时间
Complete requests: 100 ##请求数
Failed requests: 11 ##失败请求
(Connect: 0 , Receive: 0 , Length: 11 , Exceptions: 0 )
Total transferred: 1873511 bytes ##总共传输字节数,包含http的头信息等
HTML transferred: 1848311 bytes ##html字节数,实际的页面传递字节数
Requests per second: 3.95 [#/sec] (mean) ##每秒多少请求,这个是非常重要的参数数值,服务器的吞吐量
Time per request: 2534.265 [ms] (mean) ##用户平均请求等待时间
Time per request: 253.426 [ms] (mean, across all concurrent requests) ##服务器平均处理时间,
Transfer rate: 72.19 [Kbytes/sec ] received ##每秒获取的数据长度
Connection Times (ms)
min mean[+/-sd] median max
Connect: 0 8 3.9 10 13
Processing: 1222 2453 322.6 2520 3436
Waiting: 1175 2385 320.4 2452 3372
Total: 1222 2461 322.5 2528 3444
Percentage of the requests served within a certain time (ms)
50 % 2528 ## 50%的请求在25ms内返回
66 % 2534 ## 60%的请求在26ms内返回
75 % 2538
80 % 2539
90 % 2545
95 % 2556
98 % 3395
99 % 3444
100 % 3444 (longest request)
apache的ab工具也算是一种ddos攻击工具 nginx吞吐率就是要比apache高。 根据前面我们提到的性能指标Requests per second吞吐率越高,服务器性能越好。
你可能感兴趣的:(linux命令)
Dify搭建私有知识库指南
挑战者666888
AI模型应用实战 人工智能 自然语言处理 机器学习
系列文章目录CentOS系统高效部署Dify全攻略文章目录系列文章目录Dify搭建私有知识库指南一、引言二、环境准备与基础配置(含Linux命令)1.硬件要求2.软件依赖安装(Linux命令)3.安装Dify(Docker-compose部署)4.初始化设置三、数据接入与知识库构建(含实战案例)1.数据源接入示例2.数据预处理3.向量化存储配置实战案例:企业产品手册知识库四、检索与增强功能实现1.
【Linux系统部分】在Linux命令行中写一个简单的shell外壳
12.在Linux命令行中写一个简单的shell外壳文章目录12.在Linux命令行中写一个简单的shell外壳一、介绍二、编写代码总体结构初步实现头文件、宏定义、全局变量PrintComLineGetComLineProcessComLineExcuteComLine改进内建命令环境变量改变新增其他内建命令总结一、介绍Shell是Linux操作系统的核心交互界面,作为用户与系统内核之间的桥梁,它
将RHEL/Rocky LINUX 9 KVM启用虚拟化的命令拆解为原子命令
openlabx.org.cn
linux 运维 KVM
RHEL/RockyLINUXKVM启用虚拟化的命令比较复杂,可能不是每个工程师都能够看懂。要将给定的命令拆解为原子的Linux命令,我们需要展开循环和花括号扩展。原命令如下:bashfordrvinqemunetworknodedevnwfiltersecretstorageinterface;dosystemctlstartvirt${drv}d{,-ro,-admin}.socketdone
python tab键自动补全_为python命令行添加Tab键自动补全功能
weixin_39692253
python tab键自动补全
在使用linux命令的时候我们习惯使用下Tab键,在python下我们也可以实现类似的功能。具体代码如下:$catstartup.py#!/usr/bin/python#pythonstartupfileimportsysimportreadlineimportrlcompleterimportatexitimportos#tabcompletionreadline.parse_and_bind(
基础的Linux命令和http状态码
lichenyang453
linux 运维 服务器
1.Linux基础命令速查1.cd-目录导航常用操作cd~返回用户主目录cd..返回上级目录cd-返回上一个所在目录cd/var/log进入绝对路径2.pwd路径定位直接查看当前工作目录,当目录结构迷失,快速确认当前位置。3.mkdir创造文件夹mkdirstore创造一个名为store的文件夹4.touchtouchstore创造一个文件(名为touch)2.HTTP状态码1.200OK表示请求
Java 程序员必备的 26 个 Linux 命令,常用 + 面试两手抓
库库林_沙琪马
Linux linux 面试 运维
有人问我:日常开发中最常用的Linux命令有哪些?我不假思索地就列出了26个,涵盖开发、调试、运维场景,每一个都值得收藏+实战。内容速览26个高频Linux命令详解面试官常问的重点命令实操建议&学习指引一、开发者高频使用的26个Linux命令1️⃣cd-切换目录cd/usr/local/bincd..cd~Tips:~表示当前用户主目录,..表示上级目录。2️⃣mkdir-创建目录mkdirmyd
Linux系统管理:服务器运维与安全防护
教IT的小王A
服务器 运维 linux web安全 安全 网络
Linux系统管理:服务器运维与安全防护Linux系统管理:服务器运维与安全防护一、Linux系统管理基础系统架构与组成是一种自由和开放源代码的类UNIX操作系统,它是基于POSIX和UNIX的多用户、多任务操作系统。Linux的核心是Linux内核,其基本组成部分包括Shell、文件系统、系统库等。常用Linux命令文件与目录管理在Linux系统中,文件和目录的管理是非常重要的,例如用户常用的l
使用linux命令上传、下载文件(使用sz与rz命令)
星梦客
Linux centos linux 运维
sz:弹出窗口,选择下载路径,下载到指定路径rz:弹出一个文件选择窗口,从本地选择文件上传到Linux服务器先安装:yuminstalllrzszsz用法:#可同时指定多个同级文件名sz文件夹下所有文件szdir/*rz用法:cd到指定目录输入rz回车后,弹出窗口,一次可指定多个文件
数据库搭建集群之主从复制
gardenia_a
初级程序猿
数据库搭建集群之主从复制安装数据库去官网https://www.mysql.com/在linux系统下修改配置my.conf(windows是my.ini)主服务加上server_id=1一台从服务器是server_id=2,一台从服务器server_id=3重启数据库linux命令servicemysqldstart在进行数据库配置主数据执行:让从库来找到GRANTREPLICATIONSLAV
ubuntu切换目录命令
Joel Jin
ubuntu ubuntu linux
UbuntuLinux命令查看目录信息1.切换目录命令的使用cd~效果:cd..效果:cd.效果cd-效果1.切换目录命令的使用命令说明cd目录切换到指定目录cd~切换到当前用户的主目录cd…两个点切换到上一级目录cd.切换到当前目录cd-切换到上一次目录cd~效果:root@root1:~#cd/etc/acpiroot@root1:/etc/acpi#cd~root@root1:~#cd…效果
Ansible——lookup,过滤器
凤凰战士芭比Q
Ansible ansible linux
文章目录Ansible——lookup,过滤器lookup读取文件lookup生成随机密码lookup读取环境变量lookup读取Linux命令的执行结果lookup读取template变量替换后的文件lookup读取配置文件lookup读取DNS解析的值过滤器过滤器使用的位置过滤器对普通变量的操作过滤器对文件路径的操作过滤器对字符串变量的操作过滤器对JSON的操作过滤器对数据结构的操作过滤器的链
Linux命令行基础:常用命令与技巧
m0_73843831
chrome 前端 Linux 命令行 常用命 文件操作 权限管理
1.Linux命令行概述Linux命令行(也称为终端或Shell)是Linux操作系统中与用户交互的文本界面。通过命令行,用户可以执行各种任务,如文件管理、进程控制、系统配置等。相比图形用户界面(GUI),命令行具有更高的效率和灵活性,尤其适用于服务器管理和自动化任务。本文将涵盖以下内容:常用命令文件与目录操作权限管理进程管理命令行技巧2.常用命令2.1文件与目录操作ls功能:列出当前目录下的文件
Linux命令行操作基础
EnigmaCoder
Linux linux 运维 服务器
目录前言目录结构✍️语法格式操作技巧Tab补全光标操作基础命令登录和电源管理命令⚙️login⚙️last⚙️exit⚙️shutdown⚙️halt⚙️reboot文件命令⚙️浏览目录类命令pwdcdls⚙️浏览文件类命令catmorelessheadtail⚙️目录操作类命令mkdirrmdir⚙️文件操作类命令mvrmtouchfindgziptar⚙️cp前言大家好!我是EnigmaCod
【Linux命令大全】Linux虚拟化技术终极指南:从KVM到容器的深度解析
全息架构师
Linux 前沿技术与应用 linux 运维 服务器
【Linux命令大全】Linux虚拟化技术终极指南:从KVM到容器的深度解析行业洞察:全球90%的云服务基于Linux虚拟化技术!掌握这些技能可提升500%的资源利用率!本文包含180+配置案例,40张架构图,企业级虚拟化方案全公开!前言:为什么虚拟化是云计算的基础?在现代数据中心中,我们面临的核心虚拟化挑战:硬件资源的高效分割近原生性能的追求安全隔离的保障混合负载的调度跨平台的兼容性惊人数据:A
paramiko 获取 linux 内存利用率
计算机辅助工程
linux python 机器学习
要使用paramiko模块在Python中获取Linux服务器的内存利用率,你需要首先通过SSH连接到服务器,然后执行Linux命令来获取内存使用情况。以下是一种常见的方法来获取和计算内存利用率。步骤1:安装Paramiko确保你的环境中已经安装了paramiko。如果未安装,可以通过pip安装:pipinstallparamiko步骤2:使用Paramiko连接到服务器接下来,使用paramik
用Linux命令排查Java问题
在Linux环境下,我们有诸多命令和工具来帮助我们解决Java应用的问题。这些问题可能包括性能瓶颈,内存泄漏,线程阻塞,垃圾回收问题等。下面将主要介绍一些实用的Linux命令和使用方法,来帮助我们排查Java问题。首先,我们要认识到的是,Java应用是运行在JVM上的。换句话说,对于Java应用的问题,我们往往需要通过理解JVM的运行状态来进行分析和诊断。(1)使用jps命令查看Java进程:jp
Linux 基础
1974年在东南亚
linux ubuntu 服务器
目录001操作系统简介01操作系统(OperationSystem,OS)002操作系统的发展史01操作系统的发展历史02Linux内核及发行版03Linux的应用领域003文件和目录(理解)01.单用户操作系统和多用户操作系统02.Windows和Linux文件系统区别004Ubuntu图形界面入门01.Ubuntu的任务栏02.窗口操作按钮03.窗口菜单条005常用Linux命令的基本使用01
Linux命令行实用工具与文件操作全解析
dax eursir
Linux命令行 文件查找 文件操作 软件安装卸载 命令使用指南
Linux命令行实用工具与文件操作全解析Linux系统因其强大的命令行工具和灵活性而受到许多用户的青睐。本文将探讨如何在Linux命令行中获取帮助、高效地查找和操作文件及目录,并介绍如何添加和移除软件包。获取帮助在Linux中,几乎每个命令、应用程序或工具都有一个帮助文件,可通过特定选项来访问。例如,aircrack-ng--help或nmap-h。熟悉这些帮助选项(如--help、-h、-?)对
Linux 中那些有趣又实用的命令:摸鱼
SAT小象
Linux linux 摸鱼
在Linux的世界里,命令行是强大的工具。除了常规的操作命令,还有许多有趣的命令,能给我们带来别样的体验,同时也能帮助我们更好地理解和使用Linux系统。接下来,就让我们一步步走进这些有趣的Linux命令。1.sl:火车驶过你的终端1.1基本介绍sl命令是一个趣味性十足的命令,当你在终端中输入这个命令,会惊喜地看到一列火车缓缓驶过的动画效果。这个命令的诞生其实很有意思,是因为很多用户经常会不小心把
Linux系统基本操作指令
雷 电法王
linux 运维 服务器
Linux系统基本操作指令文章目录Linux系统基本操作指令一、介绍二、基础设置2.1设置ubuntu与window的共享目录2.2ubuntu系统简单介绍三、Linux命令及工具介绍3.1目录管理命令(功能,格式,参数,系统参数)3.2文件操作命令四、网络命令4.1ifconfig:4.2ping:测试网络是否联通(DNS)4.3linux与window连接:五、语音录制和播放命令5.1arec
Linux命令学习和练习网站推介
入门级程序员小周
学习 linux命令 网站推荐
网站介绍这里我给大家推荐两个网站,这个有助于帮助大家学习Linux命令,适合初学者和小白学习和练习inux命令练习网站:https://cmdchallenge.conlinux命令学习网站https://www.linuxcool.comlinux命令学习网站该网站是一个linux命令学习网站,收录了许多我们能够用到的linux命令,我们只需要在搜索框中输入我们需要查找的命令,就能够查找出该命令
【操作系统】总结篇
mortalོ
我的漫漫求职路 linux c++
【计算机网络】总结篇【数据库】总结篇【设计模式】总结篇【C++语言】总结篇本文目录1.常用的Linux命令2.Linux中查看进程运行状态的指令、查看内存使用情况的指令、tar解压文件的参数3.文件权限怎么修改4.如何以root权限运行某个程序5.软链接和硬链接的区别6.静态库和动态库如何制作及使用、区别是什么7.GDB常见的调试命令,什么是条件断点,多进程下如何调试8.什么是大端小端、如何判断大
linux命令—ls
刘俊辉个人博客
linux bash 运维 服务器 centos ubuntu
命令简介ls(ListFiles)是Linux中最基础且高频使用的命令之一,用于列出目录内容。无论是查看文件、检查权限还是分析磁盘空间,ls都是不可或缺的工具。用法ls命令的语法格式如下ls[选项][目录/文件]#不添加参数时:默认列出当前目录的非隐藏文件#添加目录路径:显示目标目录内容#添加文件路径:显示该文件信息(若存在)ls命令的常用选项及说明如下选项说明-l,–format=long,--
Linux命令之-设备查看
ldwtxwh
linux linux 运维 服务器
一、块设备查看【lsblk】[root@localhost~]#lsblkNAMEMAJ:MINRMSIZEROTYPEMOUNTPOINTsda8:0040G0disk├─sda18:101G0part/boot└─sda28:2039G0part├─centos-root253:0035.1G0lvm/└─centos-swap253:103.9G0lvm[SWAP]sr011:01918M0
【Linux命令】less 与 more
晴雨日记
Linux linux
less和more是Linux/Unix系统中两个非常常用的分页查看器命令。它们的主要作用是让你能够逐屏或逐行地查看长文本文件的内容,而不是像cat命令那样一次性将所有内容输出到终端,导致内容快速滚动而过,难以阅读。核心目的:方便、可控地浏览大型文本文件。为什么需要它们?查看日志文件(如/var/log/syslog)。阅读长配置文件。查看命令输出(通过管道|传递给它们)。阅读手册页(man命令内
【Linux命令】sed(流式文本编辑器)
晴雨日记
Linux linux
sed(StreamEditor)是Linux/Unix中一个强大且灵活的流式文本编辑器。它逐行处理输入(文件或管道输入),根据指定的规则修改文本,并将结果输出(默认到标准输出)。sed的核心优势在于使用正则表达式进行模式匹配和文本转换,尤其擅长执行查找替换、删除行、插入/追加文本等批量操作。核心概念:流式处理:按行读取输入,应用命令,输出结果。模式空间:当前正在处理的行会被读入这个缓冲区。命令:
【Linux】shell 脚本-系统管理与任务自动化(语法使用介绍)
晴雨日记
Linux linux bash
Shell脚本是用于在Unix/Linux命令行解释器(Shell)中自动化执行一系列命令的文本文件。掌握其基础语法对于系统管理、任务自动化和开发运维至关重要。一、脚本基础结构Shebang行(必需):#!/bin/bash必须是脚本的第一行。#!告诉系统使用哪个解释器执行脚本。/bin/bash指定使用BashShell(最常见)。也可以是/bin/sh,/bin/zsh,/usr/bin/py
linux命令详解——which
m0_69254007
linux 服务器 运维
which是一个常用的Linux命令,用于查找并显示指定命令的绝对路径。它在环境变量$PATH中搜索指定的命令,并返回找到的第一个匹配项的完整路径。说白了就是查找执行文件的路径(位置)。以下是which命令的详细解释和用法:1.命令格式:which可执行文件名称which[OPTIONS]COMMAND2.命令功能:which指令会在PATH变量指定的路径中,搜索某个系统命令的位置,并且返回第一个
每天掌握一个Linux命令 - sqlite3
锅锅来了
每日一令:Linux 极简通关指南 linux sqlite 运维开发 数据库
Linux命令工具sqlite3使用指南一、工具概述sqlite3是SQLite数据库的命令行工具,用于在Linux系统中直接操作SQLite数据库(轻量级、无服务器、嵌入式关系型数据库)。核心特点:无需安装数据库服务,直接通过命令行操作.db文件。支持SQL92标准,语法简洁,适合快速开发和小型项目。数据存储在单一文件中,方便移植和备份。二、安装方式1.系统自带(多数Linux发行版)直接在终端
每天掌握一个Linux命令 - ab(Apache Benchmark)
锅锅来了
每日一令:Linux 极简通关指南 linux apache 运维 ab 性能测试
Linux命令工具ab使用指南一、工具概述ab(ApacheBenchmark)是Apache官方提供的开源压力测试工具,用于衡量Web服务器的性能。它通过模拟多并发请求,测试服务器在高负载下的响应速度、吞吐量和稳定性,常用于评估网站或API的性能表现。核心特点:轻量级:无需复杂安装,适合快速测试。高可配置性:支持自定义并发数、请求次数、请求头、超时时间等参数。结果清晰:输出包含请求总数、失败率、
算法 单链的创建与删除
换个号韩国红果果
c 算法
先创建结构体
struct student {
int data;
//int tag;//标记这是第几个
struct student *next;
};
// addone 用于将一个数插入已从小到大排好序的链中
struct student *addone(struct student *h,int x){
if(h==NULL) //??????
《大型网站系统与Java中间件实践》第2章读后感
白糖_
java中间件
断断续续花了两天时间试读了《大型网站系统与Java中间件实践》的第2章,这章总述了从一个小型单机构建的网站发展到大型网站的演化过程---整个过程会遇到很多困难,但每一个屏障都会有解决方案,最终就是依靠这些个解决方案汇聚到一起组成了一个健壮稳定高效的大型系统。
看完整章内容,
zeus持久层spring事务单元测试
deng520159
java DAO spring jdbc
今天把zeus事务单元测试放出来,让大家指出他的毛病,
1.ZeusTransactionTest.java 单元测试
package com.dengliang.zeus.webdemo.test;
import java.util.ArrayList;
import java.util.List;
import org.junit.Test;
import
Rss 订阅 开发
周凡杨
html xml 订阅 rss 规范
RSS是 Really Simple Syndication的缩写(对rss2.0而言,是这三个词的缩写,对rss1.0而言则是RDF Site Summary的缩写,1.0与2.0走的是两个体系)。
RSS
分页查询实现
g21121
分页查询
在查询列表时我们常常会用到分页,分页的好处就是减少数据交换,每次查询一定数量减少数据库压力等等。
按实现形式分前台分页和服务器分页:
前台分页就是一次查询出所有记录,在页面中用js进行虚拟分页,这种形式在数据量较小时优势比较明显,一次加载就不必再访问服务器了,但当数据量较大时会对页面造成压力,传输速度也会大幅下降。
服务器分页就是每次请求相同数量记录,按一定规则排序,每次取一定序号直接的数据
spring jms异步消息处理
510888780
jms
spring JMS对于异步消息处理基本上只需配置下就能进行高效的处理。其核心就是消息侦听器容器,常用的类就是DefaultMessageListenerContainer。该容器可配置侦听器的并发数量,以及配合MessageListenerAdapter使用消息驱动POJO进行消息处理。且消息驱动POJO是放入TaskExecutor中进行处理,进一步提高性能,减少侦听器的阻塞。具体配置如下:
highCharts柱状图
布衣凌宇
hightCharts 柱图
第一步:导入 exporting.js,grid.js,highcharts.js;第二步:写controller
@Controller@RequestMapping(value="${adminPath}/statistick")public class StatistickController { private UserServi
我的spring学习笔记2-IoC(反向控制 依赖注入)
aijuans
spring mvc Spring 教程 spring3 教程 Spring 入门
IoC(反向控制 依赖注入)这是Spring提出来了,这也是Spring一大特色。这里我不用多说,我们看Spring教程就可以了解。当然我们不用Spring也可以用IoC,下面我将介绍不用Spring的IoC。
IoC不是框架,她是java的技术,如今大多数轻量级的容器都会用到IoC技术。这里我就用一个例子来说明:
如:程序中有 Mysql.calss 、Oracle.class 、SqlSe
TLS java简单实现
antlove
java ssl keystore tls secure
1. SSLServer.java
package ssl;
import java.io.FileInputStream;
import java.io.InputStream;
import java.net.ServerSocket;
import java.net.Socket;
import java.security.KeyStore;
import
Zip解压压缩文件
百合不是茶
Zip格式解压 Zip流的使用 文件解压
ZIP文件的解压缩实质上就是从输入流中读取数据。Java.util.zip包提供了类ZipInputStream来读取ZIP文件,下面的代码段创建了一个输入流来读取ZIP格式的文件;
ZipInputStream in = new ZipInputStream(new FileInputStream(zipFileName));
&n
underscore.js 学习(一)
bijian1013
JavaScript underscore
工作中需要用到underscore.js,发现这是一个包括了很多基本功能函数的js库,里面有很多实用的函数。而且它没有扩展 javascript的原生对象。主要涉及对Collection、Object、Array、Function的操作。 学
java jvm常用命令工具——jstatd命令(Java Statistics Monitoring Daemon)
bijian1013
java jvm jstatd
1.介绍
jstatd是一个基于RMI(Remove Method Invocation)的服务程序,它用于监控基于HotSpot的JVM中资源的创建及销毁,并且提供了一个远程接口允许远程的监控工具连接到本地的JVM执行命令。
jstatd是基于RMI的,所以在运行jstatd的服务
【Spring框架三】Spring常用注解之Transactional
bit1129
transactional
Spring可以通过注解@Transactional来为业务逻辑层的方法(调用DAO完成持久化动作)添加事务能力,如下是@Transactional注解的定义:
/*
* Copyright 2002-2010 the original author or authors.
*
* Licensed under the Apache License, Version
我(程序员)的前进方向
bitray
程序员
作为一个普通的程序员,我一直游走在java语言中,java也确实让我有了很多的体会.不过随着学习的深入,java语言的新技术产生的越来越多,从最初期的javase,我逐渐开始转变到ssh,ssi,这种主流的码农,.过了几天为了解决新问题,webservice的大旗也被我祭出来了,又过了些日子jms架构的activemq也开始必须学习了.再后来开始了一系列技术学习,osgi,restful.....
nginx lua开发经验总结
ronin47
使用nginx lua已经两三个月了,项目接开发完毕了,这几天准备上线并且跟高德地图对接。回顾下来lua在项目中占得必中还是比较大的,跟PHP的占比差不多持平了,因此在开发中遇到一些问题备忘一下 1:content_by_lua中代码容量有限制,一般不要写太多代码,正常编写代码一般在100行左右(具体容量没有细心测哈哈,在4kb左右),如果超出了则重启nginx的时候会报 too long pa
java-66-用递归颠倒一个栈。例如输入栈{1,2,3,4,5},1在栈顶。颠倒之后的栈为{5,4,3,2,1},5处在栈顶
bylijinnan
java
import java.util.Stack;
public class ReverseStackRecursive {
/**
* Q 66.颠倒栈。
* 题目:用递归颠倒一个栈。例如输入栈{1,2,3,4,5},1在栈顶。
* 颠倒之后的栈为{5,4,3,2,1},5处在栈顶。
*1. Pop the top element
*2. Revers
正确理解Linux内存占用过高的问题
cfyme
linux
Linux开机后,使用top命令查看,4G物理内存发现已使用的多大3.2G,占用率高达80%以上:
Mem: 3889836k total, 3341868k used, 547968k free, 286044k buffers
Swap: 6127608k total,&nb
[JWFD开源工作流]当前流程引擎设计的一个急需解决的问题
comsci
工作流
当我们的流程引擎进入IRC阶段的时候,当循环反馈模型出现之后,每次循环都会导致一大堆节点内存数据残留在系统内存中,循环的次数越多,这些残留数据将导致系统内存溢出,并使得引擎崩溃。。。。。。
而解决办法就是利用汇编语言或者其它系统编程语言,在引擎运行时,把这些残留数据清除掉。
自定义类的equals函数
dai_lm
equals
仅作笔记使用
public class VectorQueue {
private final Vector<VectorItem> queue;
private class VectorItem {
private final Object item;
private final int quantity;
public VectorI
Linux下安装R语言
datageek
R语言 linux
命令如下:sudo gedit /etc/apt/sources.list1、deb http://mirrors.ustc.edu.cn/CRAN/bin/linux/ubuntu/ precise/ 2、deb http://dk.archive.ubuntu.com/ubuntu hardy universesudo apt-key adv --keyserver ke
如何修改mysql 并发数(连接数)最大值
dcj3sjt126com
mysql
MySQL的连接数最大值跟MySQL没关系,主要看系统和业务逻辑了
方法一:进入MYSQL安装目录 打开MYSQL配置文件 my.ini 或 my.cnf查找 max_connections=100 修改为 max_connections=1000 服务里重起MYSQL即可
方法二:MySQL的最大连接数默认是100客户端登录:mysql -uusername -ppass
单一功能原则
dcj3sjt126com
面向对象的程序设计 软件设计 编程原则
单一功能原则[
编辑]
SOLID 原则
单一功能原则
开闭原则
Liskov代换原则
接口隔离原则
依赖反转原则
查
论
编
在面向对象编程领域中,单一功能原则(Single responsibility principle)规定每个类都应该有
POJO、VO和JavaBean区别和联系
fanmingxing
VO POJO javabean
POJO和JavaBean是我们常见的两个关键字,一般容易混淆,POJO全称是Plain Ordinary Java Object / Plain Old Java Object,中文可以翻译成:普通Java类,具有一部分getter/setter方法的那种类就可以称作POJO,但是JavaBean则比POJO复杂很多,JavaBean是一种组件技术,就好像你做了一个扳子,而这个扳子会在很多地方被
SpringSecurity3.X--LDAP:AD配置
hanqunfeng
SpringSecurity
前面介绍过基于本地数据库验证的方式,参考http://hanqunfeng.iteye.com/blog/1155226,这里说一下如何修改为使用AD进行身份验证【只对用户名和密码进行验证,权限依旧存储在本地数据库中】。
将配置文件中的如下部分删除:
<!-- 认证管理器,使用自定义的UserDetailsService,并对密码采用md5加密-->
mac mysql 修改密码
IXHONG
mysql
$ sudo /usr/local/mysql/bin/mysqld_safe –user=root & //启动MySQL(也可以通过偏好设置面板来启动)$ sudo /usr/local/mysql/bin/mysqladmin -uroot password yourpassword //设置MySQL密码(注意,这是第一次MySQL密码为空的时候的设置命令,如果是修改密码,还需在-
设计模式--抽象工厂模式
kerryg
设计模式
抽象工厂模式:
工厂模式有一个问题就是,类的创建依赖于工厂类,也就是说,如果想要拓展程序,必须对工厂类进行修改,这违背了闭包原则。我们采用抽象工厂模式,创建多个工厂类,这样一旦需要增加新的功能,直接增加新的工厂类就可以了,不需要修改之前的代码。
总结:这个模式的好处就是,如果想增加一个功能,就需要做一个实现类,
评"高中女生军训期跳楼”
nannan408
首先,先抛出我的观点,各位看官少点砖头。那就是,中国的差异化教育必须做起来。
孔圣人有云:有教无类。不同类型的人,都应该有对应的教育方法。目前中国的一体化教育,不知道已经扼杀了多少创造性人才。我们出不了爱迪生,出不了爱因斯坦,很大原因,是我们的培养思路错了,我们是第一要“顺从”。如果不顺从,我们的学校,就会用各种方法,罚站,罚写作业,各种罚。军
scala如何读取和写入文件内容?
qindongliang1922
java jvm scala
直接看如下代码:
package file
import java.io.RandomAccessFile
import java.nio.charset.Charset
import scala.io.Source
import scala.reflect.io.{File, Path}
/**
* Created by qindongliang on 2015/
C语言算法之百元买百鸡
qiufeihu
c 算法
中国古代数学家张丘建在他的《算经》中提出了一个著名的“百钱买百鸡问题”,鸡翁一,值钱五,鸡母一,值钱三,鸡雏三,值钱一,百钱买百鸡,问翁,母,雏各几何?
代码如下:
#include <stdio.h>
int main()
{
int cock,hen,chick; /*定义变量为基本整型*/
for(coc
Hadoop集群安全性:Hadoop中Namenode单点故障的解决方案及详细介绍AvatarNode
wyz2009107220
NameNode
正如大家所知,NameNode在Hadoop系统中存在单点故障问题,这个对于标榜高可用性的Hadoop来说一直是个软肋。本文讨论一下为了解决这个问题而存在的几个solution。
1. Secondary NameNode
原理:Secondary NN会定期的从NN中读取editlog,与自己存储的Image进行合并形成新的metadata image
优点:Hadoop较早的版本都自带,