SCMLife.com

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 5386|回复: 1

[推荐] Rational System Architect (RSA)11.4 的可伸缩性

[复制链接]
发表于 2011-12-15 15:55:49 | 显示全部楼层 |阅读模式
本帖最后由 技术狂人 于 2011-12-15 17:35 编辑
% k+ j3 F6 w$ d, ~+ \7 a$ r: [
4 J! P3 Z0 j5 [7 r+ I引言
7 \! x# }( E0 F5 k* `本文报告了 IBM Rational System Architect 的可伸缩性测试结果。该结果展示了在 Windows Terminal Server 环境下部署时,IBM® Rational® System Architect 的可伸缩性。) e5 n$ Q6 }5 n# s$ F1 `
Rational System Architect 是一款多用户的基于储存库的企业结构建模工具。通过应用行业标准结构,注释和方法,业务分析员使用它来查看,分析,并交流所有方面的企业结构。所有项目信息都存储在一个名为 百科全书(encyclopedia) 的多用户储存库之中,它安装在 Microsoft SQL Server 或者 Oracle 数据库服务器。# {7 V. r+ u- d3 ~1 l5 X2 C
申明在本文中,我们会参考使用 Windows Terminal Server,用以运行 Rational System Architect 来作为程序服务器。
' l% k! C* p( {0 R; o' s# U# ~8 |" E
8 G/ @/ f! j8 q
终端服务(Terminal Services)是 Microsoft 公司对瘦客户端终端服务器计算的实现方式,使得远程客户端机器也可以访问 Rational System Architect 之类的 Windows 程序。用户能够从远程终端访问部署在终端服务器上的程序,这些终端包括 Windows 7、Windows Vista、Windows XP,或者任意安装有 Microsoft 远程桌面连接软件的电脑。当您在使用终端服务时,只有应用程序的用户界面会出现在客户端上。所有的用户输入会通过网络传输到终端服务器,应用程序在终端服务器上实际执行程序任务。# |/ z; F6 [" c
终端服务赋予了 IT 管理员灵活性实现对用户集中部署程序,而无需考虑用户所在的位置。这有助于降低成本,并解决由于频繁更新程序、安装繁琐,或者需要通过低带宽链接访问给维护桌面机器所带来的挑战。终端服务通过与 Windows 认证系统相集成,防止未授权用户访问程序或数据,以及允许用户加密终端用户和客户端之间转移的数据,从而提供了一种安全的环境。
$ n+ r' a% J  e$ X
/ H% t) [# A5 J9 M- z0 A
% v9 {: H- _9 L
目标; |; Z, E$ U5 X( s/ D
目标 1:决定可以有多少个并发用户可以有效地正常操作,并在给定的硬件配置条件下使用 Rational System Architect。
" G8 e: v2 [. T: B+ b目标 2:开发一个指南,以在并发 Rational System Architect 用户数量增长时,预计所需要的硬件条件。* y8 R5 s) r! M6 h

4 q9 ?& R; |* c8 p9 g7 G. L

, i; Q& `  R+ d2 n5 H性能指标
% m+ N/ x2 d- r% v0 D为了估计 Rational System Architect 的可伸缩性,您需要考虑一下程序和数据库服务器的性能,以及执行典型末端用户操作的响应性。
) i0 R+ _/ O/ J' ^0 ]服务器性能指标
0 n- C, L- I# Q% j) i  o) G; o; F) g接下来的性能指标用于评价给定的负载条件下,程序和数据库服务器的响应性。这些工具是由 Microsoft Windows Server 2003 中包含的 Performance Monitor 工具所收集的。这里使用的是 15 秒的范例速率。" s: z+ Y1 c! N5 N; a
CPU& R5 P$ T0 D( _  c
使用的计时器: \\Server\Processor(_Total)\%Processor Time
+ V# U( W4 P" p7 {8 w8 q) @描述: 处理器时间百分比(% Processor Time)就是处理器执行非空闲线程所花费时间的百分比。它是这样计算的:范例间隔内空闲线程活动的持续期,减去间隔持续期的时间(每个处理器都有一个空闲线程,在该线程内其他的线程不能运行)。该计时器就是处理器活动的主要指示器,并显示了范例间隔期内忙时的平均百分比。它是这样计算的:找到服务未激活状态下的时间,从 100% 起减去该值。4 x& y3 m! {5 a6 B, m: c: W
内存
) B0 x4 N" p: z4 U; s" N1 q0 A使用的计时器: \\Server\Memory\Committed Bytes, \\Server\Memory\%Committed Bytes In Use
; j6 W' r$ L. o+ M/ h6 H$ `' ~  y描述: 提交比特数就是提交的虚拟内存的数量,以比特计算。提交比特数是保存在硬盘页码文件中的空间。其中在每一个物理档案中,可以有一个或者多个页码文件。这些计时器只会显示最后一次观察到的值;它不是一个平均值。提交比特数的使用率(% Committed Bytes In Use)就是内存\\提交比特数与内存\\提交限制之间的比值。
! d; w# t: E: p: i1 L- e2 f硬盘2 i3 D5 H% u, z, g8 B( y/ f1 y
使用的计时器: \\Server\PhysicalDisk(_Total)\% Disk Time
& L1 F" p, K, Q0 m& I描述: 硬盘时间百分比(% Disk Time)就是选中硬盘驱动器花在阅读或者书写请求所花费时间的百分比。1 f8 b- h% Z. L) w9 J* b/ I% ^
网络适配器
; B6 ^0 r) w' z$ U9 [1 ^/ W使用的计时器: \\Server\Network Interface(*)\Bytes Total/sec
+ u) y  \$ g: g& t6 w: g) r6 Z1 h描述: 总比特/秒就是以什么速率发送比特,以及以什么速率通过网络适配器接受比特,包括框架字符。网络界面 \\接受比特/秒 就是网络界面 \\接受比特/秒以及网络界面 \\发送比特/秒的总和。: P1 X: Y5 F: f0 }
Rational System Architect 性能指标; y. ?4 y- \% W/ G
接下来的性能指标用于评价给定负载条件下,Rational System Architect 的响应性。这些工具是由 Loadgen 引擎收集的,这也包含在内(参见 Test Methodology 部分以得到关于 Loadgen 的其他信息)。, \( }* m; T1 ^& x& Q# S
图表打开平均时间 6 q$ L" C% a: n; a6 I2 I
打开图表的平均时间,以秒计算。
% B! {' K2 I$ f0 o8 w图表关闭平均时间 3 h% s8 L: i) p3 [( Y
关闭和保存图表的平均时间,以秒计算。- f8 d/ u/ ^6 p: C- d
定义打开平均时间
" N& N7 _! W7 @打开定义的平均时间,以秒计算。
4 W. {, l) v( j- e/ c定义关闭平均时间
8 A# T6 Z" G) F' E关闭和保存定义的平均时间,以秒计算。
# B' U0 M0 @, B  D; c定义添加平均时间 - |9 D, Q" m- B. v+ |
创建新定义的平均时间,以秒计算。7 F* c$ b( n% v8 e
定义删除平均时间
, s; w- g% ~# I" @# @) J删除已存在定义的平均时间,以秒计算。  I! P8 {- X1 J, |$ @# y: r9 J( }
浏览器刷新平均时间
) ]5 [: t  [# Q8 D4 B刷新浏览器窗口所花费的时间,以秒计算。$ s9 L0 t7 p. o1 D; L
浏览器打开平均时间 8 Q/ F! {% t) D
在浏览器窗口中展开一系列树形节点所花费的时间,以秒计算。
9 _* p9 O( o$ s: \, v7 l- e7 n# \平均操作时间 - B% E. ~: a1 H' w" f. M% u6 a/ }
执行所有操作的平均时间(以上工具的集合)。
1 E8 |$ r$ @' E& `% {; N- i3 x平均交易时间
: U" i. Z; p) w% N# a: M数据库交易的平均时间,以秒计算。0 E8 E( J( c  j7 M1 E. U) N5 Z
平均锁定时间 ' f: }- ~: P: u2 f$ V
数据库 applock 的平均时间,以秒计算。一个 applock 用于锁定数据库以便单个用户的外部性访问。通常来说,更长时间的 applock 意味着 Rational System Architect 对末端用户的响应性更差。; N+ Q* \; c% H7 A9 |
这些平均值是对测试中所有参与的用户计算的。例如,如果测试期间 20 个用户打开了 50 个图表,那么可以从打开执行操作的所有 1000 个图表中计算 Diag RAM Open Average。
* E( S$ ^4 F3 u1 w& C( C( Q2 @% ~

, O$ H- @) g/ e+ d" P/ t4 f
8 D5 ]: i- A4 p) T  g# i# _7 C" F测试环境
3 Q3 o4 v1 n* l' ]! V' T) f选择一个基线测试环境来反映硬件和软件成为末端用户的公共安排。您需要创建一个程序服务器来安装 Rational System Architect,并用作通过远程桌面连接用户的访问点。您需要创建一个单独的数据库服务器来安装测试期间使用到的 SQL 服务器以及 Rational System Architect 百科全书。下面列出的是使用硬件和软件配置的具体内容。! P1 C% J2 H1 k" b3 C
程序服务器
: h- w5 g/ k, I' ^; e
硬件:
  • CPU: Intel Xeon Dual Core 2.4 GHZ
  • RAM: 4 GB
  • 网络适配器: 1 Gbps 的连接速率,以及对数据库服务器 144 Mbps 的吞吐速率
    9 |0 p! R4 y1 E  O
软件:
  • Windows Server 2003 R2 SP2(启用终端服务)
  • Rational System Architect 11.4 版本+ f' u1 j: u" k
数据库服务器7 N8 O% T; ?2 O& V( ^
硬件:
  • CPU: Intel Xeon 2.4 GHZ
  • RAM: 4 GB
  • 网络适配器: 1 Gbps 的连接速率,以及与程序服务器 136Mbps 的吞吐速率
    8 j2 v3 R$ q/ L# X+ ]
软件:
  • Windows Server 2003 R2 SP2
  • Microsoft SQL Server 2008
    " `* I3 ]3 S/ D, ]9 k1 @5 |
测试百科全书
6 E4 \7 N' ]1 ~7 Z6 S) W. \' V, w
对象数量:
  • 图: 211
  • 符号:10,893
  • 定义: 123,741
  • 关系: 1,017,246
    - H# A6 T4 h0 [
配置:
  • 百科全书类型: Professional
  • 工作区: Disabled
  • 框架: None" q1 J: y! A  v  q4 L
主要方法:
  • 数据建模
  • BPMN(业务进程建模标记): s3 |3 A4 z) F; x

" i  P4 v5 ?( S' H* S& P* S+ u; w图 1. 典型 Rational System Architect 部署概览+ B1 `9 ^5 l1 w1 e8 X) ?
9 H0 j: f( _6 k/ N) \) |( j( W7 B

/ }9 l( F% Q& Q# q

+ k' P. y' |* }8 V3 }$ _8 Q$ H2 s" {' S
测试方法
) s" D, S( F! g! oRational System Architect Loadgen! z3 u* p9 d# @2 {
Loadgen 是构建至 Rational System Architect 以便用户模拟的属性工具。Loadgen 能够执行许多普通的任务,例如打开和关闭图及定义,或者创建新的定义,而不需要用户进行交流。它还能够提供所有操作的具体报告,以及完成这些报告所需要的时间。
$ p) {; {+ O/ x$ Q9 L2 uLoadgen 执行的操作基于一个配置文件,该文件识别了操作的数量,以及那些操作的“随机性”。下面描述了本文所有的配置:5 w5 N0 D& p; t1 x& ~
图表设置1 K; ?! s/ @" V0 h" a$ _
  • 一次能够打开图的最大数量:2
  • 打开图表所需要的时间,min/max:60 秒/240 秒
  • 图表打开与下一次打开所需要的时间,min/max:30 秒/90 秒
  • 打开图表时所更改符号的数量,min/max:10 / 20
    1 B& @5 b& d- i1 W
定义设置& Z) v$ v+ \) y1 i1 `- S6 T. I) k
  • 一次性打开定义的最大数量:4
  • 打开定义的时间,min/max:30 秒/90 秒
  • 定义打开与下一次打开之间的时间,min/max:60 秒/120 秒
  • 保存定义的百分比:75%
  • 取消更改定义的百分比:25%! `; \6 U: T! I6 ]  n
添加定义设置
. j9 C2 @  M' q) I. p
  • 一次性添加定义的最大数量:1
  • 定义添加的时间,min/max:30 秒/90 秒1 r0 M+ N( K" W5 `) Y
删除定义设置
/ J/ A# b) l( W
  • 一次性删除定义的最大数量:1
  • 删除定义的时间,min/max:90 秒/150 秒
  • 首次删除之前的等待时间:300 秒
    + E6 f  S% w' u/ c/ m6 G$ W
注意应用到每一个用户的设置,而不是测试的整体是很重要。例如,配置支持一次性打开 2 个图表,如果有 10 个用户参与到测试之中,那么这意味着测试时可以同时打开 20 个图表。% ?. F$ H# M& S/ }  S% g" s+ {
执行的测试步骤6 w( J9 U4 |+ D
您可以使用 Loadgen 来模拟任意数量虚拟 Rational System Architect 用户的操作。对于本文我们在增加虚拟用户数量的情况下重复 两个小时的测试(从 5 到 25 个并发用户)。, x' F) S9 b: Q2 S4 V
一次 Loadgen 测试运行由以下的步骤组成:
7 i" V/ b9 Q7 k; r+ a7 {
  • 从独立于程序和数据库服务器之外的 Windows 机器上,对程序服务器完成一个远程桌面链接,使用预定义用户 ID 进行登录。
  • 通过远程桌面链接,在程序服务器上启动 Rational System Architect 的实例,并打开测试百科全书。
  • 对于测试所需要的每一个虚拟用户重复第 1 步和第 2 步。
  • 在所有的虚拟用户都打开测试百科全书之后,可以激活 Loadgen,并启动自动化测试进程。
  • 测试能够运行 两个小时。随着测试的执行,Loadgen 与 Windows Performance Monitor 都会登录性能数据。
  • 两小时之后,Performance Monitor 就会被关闭掉,所有的虚拟用户都会从程序服务器上注销掉,而 Loadgen 和 Performance Monitor 数据都会被保存以便分析。/ `- j6 `3 ~' H- X7 F

2 w! @8 A9 u( k8 Q" t8 A; |8 x
! Y3 t. b  t$ x3 a' \0 C
测试结果! S+ D( i' ?4 H, ^0 {' Y: M. s
测试结果会分解为三个类别:" y  s+ O1 S3 K; A: T) }4 C
  • Rational System Architect
  • 程序服务器
  • 数据库服务器% J" L) y/ F9 ]/ ^* N+ B6 o$ ~
Rational System Architect 的性能8 X1 A! U" J4 n/ h! {8 A. \) v
表 1 列出了每次测试运行时所有用户执行操作的总体数量。数据给出了测试环境中的实际负载。例如,在 25 个用户的测试运行期间,单个用户平均打开 61.84 个图表。测试运行会持续 两个小时,这样单个用户每小时会打开 30.92 个图表,或者每 2 分钟大约打开 1 个操作。
9 S; ]  _' D3 b9 N( K* t1 T! P0 s
( x$ s3 Z1 J2 e1 `2 V' V' A  s表 1. 执行操作的总体数量
9 u7 A5 v" ?. ]0 [9 W3 R: t
" n0 B, M% F; {0 H
5 个用户10 个用户15 个用户20 个用户25 个用户
操作数量2948584186061078613477
交易数量1003219945292723681746257
AppLock 数量38037561110041384917420
浏览器刷新数量2364666958731091
浏览器打开数量135264384481609
图表打开数量338671100312451546
图表关闭数量33767299912391537
定义打开数量9521888276434814349
定义关闭数量9501880276134674345
定义添加数量6021191172621742746
定义关闭数量28957985110651354
表 2 列出了以秒表示的执行每次操作所需要的平均时间。例如,在 25 个用户测试运行期间,执行 1546 图打开的平均时间为 2.24 秒。
" J- h9 x$ S; c6 L. N/ E3 |
- p# p8 q+ |" l! ?$ N+ C表 2. 执行每次操作的平均时间
7 ]/ `- P7 n+ C2 j- W7 R8 C
' A7 b) f3 `4 Z+ O% v& p
5 个用户10 个用户15 个用户20 个用户25 个用户
平均 操作0.430.520.681.041.12
平均交易0.130.160.220.380.41
平均 Applock0.160.170.180.220.22
浏览器刷新平均时间0.270.290.280.350.37
浏览器打开平均时间0.270.290.260.330.37
图表打开平均时间1.181.401.721.972.24
图表关闭平均时间0.570.720.921.281.64
定义打开平均时间0.300.370.551.051.02
定义关闭平均时间0.300.370.490.870.92
定义添加平均时间0.190.280.501.131.31
定义删除平均时间0.290.370.691.541.76
程序服务器的性能
2 J3 K/ f; f9 pCPU 使用情况
( Y# N* P% m4 L6 F) l/ c表 3 显示了每次测试执行期间程序服务器上的负载。
. E4 `8 {' o4 B6 C- L
  • 平均处理器使用率(Average % processor use) = 测试运行期间平均 CPU 使用。
  • 总体更改百分比(Total % change) = 为了消除正常的 Windows 操作的处理器使用量,我们使用当前测试运行的平均处理器使用量减去以前测试运行的平均处理器使用量。因此,10 个用户和 15 个用户之间的总体更改百分比(Total % change)是 46.44 - 27.62 = 18.82。
  • 单个用户更改百分比(% Change per user) = 总体更改百分比(Total % change)除以 5(这一数字在测试运行期间随实际用户数增减)。6 {- A* i8 Z9 ]9 S+ z5 `1 I& S  w

8 Y' P. S) l) E: y表 3. 程序服务器 CPU 使用情况) Q% m: O# o+ S' W0 C
测试运行平均处理器使用率(%)总体更改百分比(%)单个用户更改百分比(%)
5 个用户13.35NANA
10 个用户27.6214.272.85
15 个用户46.4418.823.76
20 个用户62.8116.373.27
25 个用户73.7010.892.18
单个用户的平均更改百分比(Average % change per user) = 3.01%(每个内核*)
3 z- V! H. [( R5 \" O, A& v5 @. A* 该数值应用于每一个内核,因为这是一个双核系统。如果它是一个单核系统,那么该数值就是双倍的。
) }4 q" Q9 c8 l% f6 |% P
图 1. 两个小时测试运行期间程序服务器 CPU 的使用情况% v9 x; L/ a7 h8 y6 h
: Q! j; @& `1 ]' k3 c
3 A) |" z4 V( X! ]/ ~( n
内存使用情况
5 c# r( O' Q+ R0 W表 4 显示了每次测试运行期间程序服务器上的负载。
& k- F4 C) g' {7 E6 g( v2 Y  e& Q
  • 峰值 RAM 使用率(Peak % RAM use) = 最高报告的 RAM 使用,用于查看是否有异常情况发生。
  • 平均 RAM 使用率(Average % RAM use) = 所有报告 RAM 使用的平均值。
  • 峰值 MB RAM 使用量(Peak MB RAM use) = 最高报告的 RAM 使用,以兆比特计算。
  • 平均 MB RAM 使用量(Average MB RAM use) = 所有报告 RAM 使用的平均值,以兆比特计算。
  • 总体 MB RAM 更改(Total MB RAM change) = 为了消除正常的 Windows 操作所使用的内存,我们使用当前测试运行的平均内存使用量减去以前测试运行的平均内存使用量。因此,10 个用户和 15 个用户之间的 MB 总体更改百分比(Total % change)是 2586.51 - 1983.12 = 603.39。
  • 单个用户更改百分比(% Change per user) = 总体 MB RAM 更改除以 5(这一数字在测试运行期间随实际用户数增减)。: T) c- A1 x% P2 l; j9 p- V

+ q2 R0 J/ l% g  j; G; l: f表 4. 程序服务器内存使用情况. j* ]9 P" f9 T$ q4 s; G
测试运行峰值 RAM 使用率(%)平均 RAM 使用率(%)峰值 MB RAM 使用量平均 MB RAM 使用量总体 MB RAM 更改单个用户的 MB RAM 更改
5 个用户37.6132.401649.721427.04NANA
10 个用户46.5444.172089.571983.12556.08111
15 个用户61.1657.452753.452586.51603.39120
20 个用户77.7171.643498.583225.33638.82128
25 个用户88.9784.364005.313797.76572.43115
单个用户的平均 MB RAM 更改 = 118.5

1 {: X6 u# _" p9 i
( V. r0 v4 G& y' j% G5 @图 2. 两小时测试运行期间内程序服务器的内存使用率(Application server % of memory used)0 {9 D3 c( I8 b# c! }8 A1 O
8 v8 Z, P$ _, I7 f  I2 k

1 p# L5 W( W6 v4 E: v3 p* I& t& |# a2 h+ j' U& s
图 3. 两个小时测试运行期间使用的程序服务器内存
& Z5 X7 i: @) u9 d, h1 X / ?  I7 N- g7 G& I
! C. S, j, W% W! b$ S8 v
硬盘使用情况
( s  _5 f8 J: y/ c$ L表 5 显示了每次测试运行期间程序服务器硬件驱动器上的负载。5 c$ C. q* L1 \
  • 平均硬盘时间使用百分比(Average % disk time use) = 所有报告硬盘使用平均值。
  • 总体更改百分比(Total % change) = 为了消除正常的 Windows 操作的硬盘使用量,我们使用当前测试运行的平均硬盘使用量减去以前测试运行的平均硬盘使用量。因此,10 个用户与 15 个用户之间的总体更改百分比(Total % change)是 4.31 - 2.66 = 1.65。
  • 单个用户更改百分比(% Change per user) = 总体更改百分比(Total % change)除以 5(测试运行期间随实际用户数的增减)。( t5 ]% W0 i9 I

/ c  g& J. M5 j) J; i表 5. 程序服务器硬盘使用情况" P$ G: r; e0 G" ~! t
测试运行平均硬盘时间使用百分比(%)总体更改百分比(%)单个用户更改率百分比(%)
5 个用户2.13NANA
10 个用户2.660.53.11
15 个用户4.311.65.33
20 个用户5.280.97.19
25 个用户6.931.65.33
单个用户的平均更改率百分比(Average % change per user) = .24%
& N, i9 ~( c. m+ k$ g
图 4. 两小时测试运行期间程序服务器的硬盘使用率
3 v- C4 @# N) i1 H! U
2 k) I5 L* i" k( P
# W; w9 p5 c% v5 Y9 X* w4 ^网络使用情况
. P$ y7 b: x! `* \' R8 O表 6 显示了每次测试运行期间程序服务器网络界面上的负载。5 Z, `4 b7 L5 I2 O
  • 峰值网络 KB/sec = 最高报告的网络使用情况,用于查看是否有异常情况发生。
  • 平均网络 KB/sec = 所有报告网络使用的平均值。
  • 总体网络 KB/sec 更改 = 为了消除正常的 Windows 操作的网络使用量,我们使用当前测试运行的平均网络 KB/sec 使用量减去以前测试运行的平均网络 KB/sec 使用量。因此,10 个用户与 15 个用户之间的总体 KB/sec 更改是 266.48 – 161.32 = 105.16。
  • 单个用户的网络 KB/sec 更改 = 总体网络 KB/sec 更改除以 5(这一数字在测试运行期间随实际用户数增减)。: f/ a9 Z8 c/ R' n" q, M
6 _& D. a3 Q1 _; b  F; l
表 6. 程序服务器网络使用情况9 |( v* q& n. x% x+ _
测试运行峰值网络值 KB/秒平均网络值 KB/秒总体网络值 KB/秒 更改单个用户的网络 KB/sec 更改
5 个用户807.5978.78NANA
10 个用户810.98161.3282.5416.51
15 个用户9089.23266.48105.1621.03
20 个用户10063.78441.25174.7734.95
25 个用户11710.39513.7372.4814.50
单个用户的平均网络 KB/sec 更改 = 21.75

* l) L# I5 j1 |  l) P2 M图 5. 两小时测试运行期间程序服务器网络使用情况$ M. p- e8 G1 D2 A; x

0 O* P& W. v5 ^6 \
" k/ S/ X" j5 Y" q1 c8 [+ f数据库服务器性能
5 x. c* s% v! T( i7 m1 V$ E/ LCPU 使用情况
" E  ?0 H: S! L' g0 O图 7 显示了每次测试运行期间数据库服务器 CPU 上的负载。' Y$ c6 B4 ~0 g! x' X2 {, B
  • 处理器平均使用率(Average % processor use) = 测试运行期间 CPU 的平均使用率。
  • 总体更改百分比(Total % change) = 为了从 Windows 操作中消除所有的处理器使用,我们在计算时使用当前测试运行的平均处理器使用率减去以前测试运行的平均处理器使用率。10 个用户和 15 个用户之间的总体更改百分比(Total % change)是 17.58 – 13.24 = 4.34。
  • 单个用户更改百分比(% change per user) = 总体更改百分比(Total % change)除以 5(这一数字在测试运行期间随实际用户数增减)。
    ; L" O/ o1 h4 K- g: r* [

2 F* R. g, b! i表 7. 数据库服务器 CPU 使用情况
9 Y! r3 K: N0 h3 d' G9 b4 \
测试运行处理器的平均使用率(%)总体更改百分比(%)单个用户更改百分比(%)
5 个用户8.95NANA
10 个用户13.244.29.86
15 个用户17.584.34.87
20 个用户20.242.66.53
25 个用户23.032.79.56
单个用户的平均更改百分比(Average % change per user) = .71%
! m3 N8 L4 j5 F8 {% y
图 6. 两小时测试运行期间数据库服务器 CPU 使用量
/ S  C) j0 F) e + i% v7 G# G$ E. V# o
- ]. t5 Y1 S$ ]6 [! ]6 m! M
内存使用情况
; X8 u1 f8 R/ }9 s1 j表 8 显示了每次测试运行期间数据库服务器内存使用的负载。9 Q9 E, u& L$ T% s  B
  • 峰值 RAM 使用率(Peak % RAM use) = 最高报告的 RAM 使用情况,用于查看是否有异常情况。
  • 平均 RAM 使用率(Average % RAM use) = 所有报告 RAM 使用的平均值。
  • 峰值 MB RAM 使用量 = 最高报告的 RAM 使用量,以兆比特计算。
  • 平均 MB RAM 使用量 = 所有报告 RAM 使用量平均值,以兆比特计算。
  • 总体 MB RAM 更改 = 为了从 Windows 操作中消除所有的内存使用,我们在计算时使用当前测试运行的平均 RAM MB 使用量减去以前测试运行的平均 RAM MB 使用量。10 个用户和 15 个用户之间的总体 MB 更改是 2120.29 – 2117.33 = 2.96。
  • 单个用户更改百分比(% Change per user) = 总体 MB RAM 更改除以 5(这一数字在测试运行期间随实际用户数增减)。
    ( Y( P, T4 ^6 K# L( {5 t

6 l( r" C  _8 [! g( O7 d$ z3 R0 Z7 |& D表 8. 数据库服务器内存使用情况7 _- B  L* R- Q1 h! h' T
测试运行峰值 RAM 使用百分比(%)平均 RAM 使用百分比(%)峰值 MB RAM 使用平均 MB RAM 使用总体 MB RAM 更改单个用户的 MB RAM 更改
5 个用户50.3050.232119.572116.54NANA
10 个用户50.2950.252119.072117.330.79.16
15 个用户50.4850.322127.362120.292.96.59
20 个用户50.4050.332123.732120.680.39.08
25 个用户50.3550.252121.782117.49-3.19-.64
单个用户的平均 MB RAM 更改 = .05

% Q. }! `7 V  O: l* U图 7. 两个小时测试运行期间数据库服务器内存使用的百分比(Database server % of memory used)
4 I( d! I3 T7 D
# u$ w1 b% I2 ~! I* }& \: y& n# w: O* ?  `9 F5 U0 k
* Z  k/ d# {5 c. Y. q
图 8. 两个小时测试运行期间数据库服务器使用的内存9 r' c2 Q9 z$ m9 j' c! y+ X
$ f2 G9 V& w' `; l' a  ^
% K! [9 z% Z; h8 m& f& a
硬盘使用情况
/ @" ?  a3 i1 B3 a+ S4 I表 9 显示了每次测试运行期间数据库服务器硬盘之上的负载情况。, l; L4 `" t' @  C4 a+ c
  • 平均硬盘使用时间百分比(average % disk time use) = 所有报告硬盘使用的平均值。
  • 总体更改百分比(Total % change) = 为了消除正常的 Windows 操作的硬盘使用俩,我们计算使用当前测试运行的平均硬盘使用时间百分比(average % disk time use)减去以前测试运行的平均硬盘使用时间百分比(average % disk time use)。例如,10 到 15 个用户之间的总体更改百分比(Total % change)是 4.23 – 2.60 = 1.63。
  • 单个用户更改百分比(% Change per user) = 总体更改百分比(Total % change)除以 5(这一数字在测试运行期间随实际用户数增减)。8 m/ y" [) Z. |4 A6 X7 J0 Y0 O: `
4 h3 [2 k1 N; _" ]
表 9. 数据库服务器硬盘使用情况8 G2 n( J) n0 ?( U8 B5 o, A
测试运行平均硬盘时间使用百分比(%)总体更改百分比(%)单个用户更改百分比(%)
5 个用户2.30NANA
10 个用户2.600.30.06
15 个用户4.231.63.33
20 个用户5.210.98.20
25 个用户6.341.13.23
单个用户的平均硬盘使用更改百分比 = .21
& B. D  l% z8 R! X- g  k: x) `3 j
图 9. 两个小时测试运行期间的数据库服务器硬盘使用率(Database server % disk use)
! p0 S/ g3 D3 J5 |8 Q* d # F4 W/ ]5 b* k9 M, R& U; k" y
9 X8 ~5 b, Z) ~5 }7 J7 M% I9 \
网络使用情况0 l2 C' b' z" g7 N+ H
表 10 显示了每一次测试运行期间数据库服务器网络界面的负载情况。
( e, p+ O( U  ^* K& W- L) e
  • 网络峰值 KB/sec = 最高的报告网络使用量,用于查看是否有不正常的情况发生。
  • 网络平均值 KB/sec = 所有报告网络使用量的平均值。
  • 网络总值 KB/sec 更改 = 为了消除正常的 Windows 操作的网络使用量,我们计算使用当前测试运行的平均网络 KB/sec 使用量减去以前测试运行的平均网络 KB/sec 使用量(例如,10 到 15 个用户之间的总体 KB/sec 更改是 263.54 – 157.11 = 106.43)。
  • 单个用户网络 KB/sec 更改 = 总体网络 KB/sec 更改除以 5(这一数字在测试运行期间随实际用户数增减)。
    ( h& i" X, u' G

9 B+ f  B% f6 ~表 10. 数据库服务器网络使用情况! e5 d1 ~3 H8 ?  ?( c4 p
测试运行峰值网络 KB/sec平均网络 KB/sec总体网络 KB/sec 更改单个用户网络 KB/sec 更改
5 个用户802.2674.52NANA
10 个用户922.15157.1182.5916.52
15 个用户10095.64263.54106.4321.29
20 个用户11356.14435.65172.1134.42
25 个用户11755.05505.9170.2614.05
单个用户的平均网络 KB/sec = 21.57
8 C0 j5 D! j6 P5 V5 e6 X
图 10. 在 两个小时测试运行期间的数据库服务器网络使用情况
! m- t! U% p5 }# {: W! T. r$ U ) w( n7 |+ i, x3 q+ P+ v
; C! B8 V# X0 Y6 O+ k" W


& S0 j8 h7 j& K$ t1 _  J
& d" {- R$ \$ H: h1 X结论
* {# g# E. {2 ^% P6 b7 [- f% m9 G目标3 O2 N: z; d+ Q; }! h$ p+ N
目标 1. 在一个给定的硬件配置条件下,决定有多少个并发用户可以有效地发挥功能。
, F5 ~1 u+ p' D0 _考虑到本文中使用到的硬件配置情况,我们相信 25 个并发 Rational System Architect 用户能够有效地发挥功能。执行典型操作的响应时间是可接受的,打开一个图表平均的最长时间为 2.24 秒。3 e# t: ~8 O0 p+ O4 J$ A
限制测试环境可伸缩性的主要因素是程序服务器的 CPU 和内存使用情况。在 25 个并发用户的情况之下,CPU 和内存使用率分别是 74% 与 84%。其他的用户有可能导致资源过多使用,并造成显著的性能降级。3 t% g1 Y6 W& K2 _) I. _: e
目标 2. 开发一个指南,来帮助预计随着并发 Rational System Architect 用户数量的增长所需要的硬件。
0 P4 }+ j  B" ^  B# `8 \; s, Y; f表 11 显示了测试环境之中单个用户对资源的平均使用情况。: g" F7 K2 h; I* m
, X) P' m! j  Q
表 11. 单个用户的平均资源使用情况
$ t' {$ z, i( z0 J. X8 `
9 X) c* R; K6 |0 O; }4 N3 s
程序服务器数据库服务器
CPU3.01%0.71%
内存118.5 MB0.05 MB
硬盘0.24%0.21%
网络21.75 KB/s21.57 KB/s
通过查看单个用户对资源的平均使用情况,估计支持其他 Rational System Architect 用户所需要的硬件就成为可能的了。让我们考虑一下以下两种情况:50 个和 200 个并发用户。
* ]1 _9 z2 p$ M3 Y; h50 个用户
( \, H$ h$ i) x# W/ L
, {# F& U8 d6 E+ A+ Y程序服务器

9 v" k$ K; N* G" e- V; S从程序服务器开始,我们可以看到单个用户的硬盘和网络使用都非常低,而且不是限制性的因素。估计的硬盘使用率是 12%(.24 * 50),而网络使用将会是 8.7 Mbps(21.75 * 8 * 50)。
. B8 _7 q+ @! [! |- iCPU 使用率为单个用户 3.01%,用户负载为 50 时,本文所用到的双核 CPU 负担就会过重了(3.01 * 50 = 151%)。另外,内存使用为每用户 118.5 MB,用户负载为 50 位时,可以使用到的内存都会被使用到(118.5 * 50 = 5.9 GB)。为了消除这些限制性的因素,我们推荐将使用到的程序服务器升级到带有 8 GB RAM 的四核 CPU。
' W" a5 Q( B2 s+ v. V% P, P
# t. ~0 M$ k: Y) O9 N3 z数据库服务器

* `& f, q; ?0 f至于数据库服务器,我们看到 CPU,硬盘和单个用户的网络使用率都很低,并且不会成为限制性的因素。估计的 CPU 使用率会是 35.5%(.71 * 50),硬盘使用率是 10.5%(.21 * 50),而网络使用情况是 8.6 Mbps(21.57 * 8 * 50)。
0 Y% Q. q3 Y+ \; c. `当您在考虑数据库服务器上的内存使用情况时,查看数据库的大小,要比查看单个用户对内存的使用情况更加重要。一般来说,您需要足够多的内存,来承担使用到的最大数据库。本文中使用的数据库大小为 2.8 GB。考虑到现代的数据库随着时间的推移不断变大,所以将 RAM 配置为 4 GB 将会是合理的。$ t: Y. x# _, F
总而言之,本文中使用到的数据库服务器能够支持 50 个并发数据库。2 j; i3 B% J0 K. ^0 z* O/ @
200 个用户7 R/ Q/ E" t1 T7 V
& x: m7 r; E$ b7 m5 y  [
程序服务器
2 L+ h' l& X$ b) k5 I
从程序服务器开始,我们可以看到单个用户的硬盘和网络使用都非常低,而且不是限制性的因素。估计的硬盘使用率是 48%(.24 * 200),而网络使用将会是 34.8 Mbps(21.75 * 8 * 200)。
# h0 {5 x- a3 V, {CPU 使用率为每位用户 3.01% 时,在 200 个用户的负载下该研究所使用的双核 CPU 负担就变得过于严重了(3.01 * 200 = 602%)。另外,当内存使用率为每用户 118.5 MB 时,在 200 个用户的负载下所有可用的内存都会得到使用(118.5 * 200 = 23.7 GB)。您可以使用两种方法来转移这些限制性的因素:
% B, C, A5 C$ i$ F; L
  • 第一种方法是在一个单个的高性能服务器上部署 Rational System Architect,该服务器由拥有 32GB RAM 的 4 核 CPU 组成。
  • 另外一种更为实用的方法是在四个不同的程序服务器上部署 Rational System Architect。每个程序服务器拥有单个的四核 CPU 以及 8 GB 的 RAM,并且可以支持多达 50 个的并发用户。这种方法就是所谓的 服务器集群。其他的程序服务器可以根据需要添加至集群之中,支持日益增长的可伸缩性。数据库服务器, g, D6 Z% {0 m0 L  l
切换至数据库服务器,我们看到单个用户的硬盘和网络使用都非常低,而且不是限制性的因素。估计的硬盘使用率是 42%(.21 * 200),而网络使用将会是 34.8 Mbps(21.57 * 8 * 200)。6 i; q0 m& A8 F) G4 b' e% k+ [
就算单个用户的 CPU 使用率很低,当它为 .71% 时,在 200 个用户的负载之下数据库服务器的单个 CPU 负担将会非常严重(.71 * 200 = 142%)。为了移出该限制性因素,我们推荐您将数据库服务器升级为双核的 CPU。
  A7 @- f+ B5 K当您在考虑数据库服务器之上的内存使用情况时,查看数据库的大小,要比查看单个用户所使用数据库的情况更加重要。一般来说,您想拥有足够多的内存,来承担使用到的最大数据库。本文所使用的数据库大小为 2.8 GB。考虑到数据库的规模随着时间的增长不断扩大,所以配置一个 8 GB 的 RAM 将不失为一个明智的选择。. n# R- B% |: t
总而言之,为了支持本文中 200 位并发用户使用数据库服务器,您需要升级到带有 8 GB RAM 的双核 CPU。
* O0 m' t1 T: j8 C

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
 楼主| 发表于 2011-12-15 16:05:24 | 显示全部楼层
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

SCMLife推荐上一条 /4 下一条

QQ|小黑屋|手机版|无图版|SCMLife.com ( 京ICP备06056490号-1 )

GMT+8, 2018-6-21 01:14 , Processed in 0.147623 second(s), 6 queries , Gzip On, MemCache On.

Powered by SCMLife X3.4 Licensed

© 2001-2017 JoyShare.

快速回复 返回顶部 返回列表