赛迪网 > IT技术 数据库 > 精彩更新
  IT资讯搜索
 
IT产品搜索

Linux平台下数据库资源使用情况分析 (1)

发布时间:2007.03.15 04:44     来源:赛迪网技术社区    作者:doorsir

在单一的应用环境或业务相对简单的系统下,系统性能问题 , 瓶颈所在往往是不言自明,解决问题的前提 -- 定位问题。定位问题是比较容易解决的 , 但在一个复杂的应用环境下,各应用系统对系统资源往往是一种共享和竞争的关系,而且应用系统之间也可能存在着共生或制约的关系,资源利益的均衡往往是此消彼长,而这种环境下的应用系统一旦出现资源竞争,系统的瓶颈往往难以断定,甚至会发生不同应用设计人员之间互相推诿责任的扯皮现象。本文仅就此问题对 Linux 平台下各应用系统对 Oracle 数据库的使用情况作一探讨,Oracle 数据库的 TUNING 不是一个可以一言以蔽的主题,本文无意概全,内容仅涉及问题的定位及各应用对数据库资源的共享与竞争问题。

本文试验及问题取证的环境 :

RedHat6.1 Web server(Apache1.3.9+PHP4.0)+Client/Server(Pro*C) 之 Server 端

RedHat6.2 + Oracle8.1.6.1.0

RedHat7.1 Web server(Apache1.3.20+PHP4.06) + Oracle8.1.7.0.0

为方便问题的讨论,应用系统已做简化,竞争方仅包括一个 Pro*C 的 daemon 程序作为 C/S 模式的服务端, 和由 Apache+PHP 所支持的 WEB 网站业务。

1. 单个 SQL 语句的处理

首先,最简单的情况莫过于单个 SQL 语句的分析 , SQL 语句的优化也是数据库优化的一个最直接最立竿见影的因素。SQL 语句的性能监控从监控工具来说大致可分为由高级语言提供和由Oracle 本身提供,高级语言以典型的应用 C 语言和 WEB 开发语言 PHP 为例 , C语言中可以用 gettimeofday 函数来在某一数据库操作之前和之后分别获取一个时间值,将两个时间值之差做为衡量该数据库操作的效率,在 PHP中,也可以用 gettimeofday, 操作方法当然与 C 语言中有所不同。当然,PHP中也有其它一些函数可以达到同样的时间精度 , 关于时间精度的考虑,不能简单以大小衡量微秒级的时间数值。因为时钟中断的时间间隔从根本上决定了时间计算所能达到的精度。此外,操作系统本身对进程的时间片分配 , 及进程切换的开销等因素也在一定程度上影响时间数据的意义。所以,以下时间的计算最理想的情况是对同一操作在尽可能避免缓存的情况下进行多次的循环操作,取总的时间值加以平均,从而得到比较接近真实情况的时间值。

C 语言的例子 :

#define TV_START 0 

#define TV_END 1 

int how_long(int cmd, char *res); 

struct CMD_TIME{ 

int times; 

/* times occured within specified package number */ 

struct timeval time; 

/* total time consumed by the cmd */ 

}; 

void foo() 

{ 

int id; 

how_long(TV_START, NULL); 

EXEC SQL WHENEVER SQLERROR CONTINUE; 

EXEC SQL WHENEVER NOT FOUND CONTINUE; 

EXEC SQL select user_id into :id from users where name='slimzhao';2; 

how_long(TV_END, time_consume); 

puts(time_consume); 

} 

int how_long(int cmd, char *res) 

/* return value: -1 error, 0 sucess , res: 20 bytes is enough */ 

{ 

static struct timeval before, after; 

if(cmd == TV_START) { 

gettimeofday(&before, NULL); 

return 0; 

} else if(cmd == TV_END) { 

gettimeofday(&after, NULL); 

if(res) { 

if(after.tv_usec > before.tv_usec) { 

sprintf(res, "%ld %ld", after.tv_sec - before.tv_sec, 

after.tv_usec - before.tv_usec); 

} else { 

sprintf(res, "%ld %ld", 

after.tv_sec - before.tv_sec - 1, 

1000000 + after.tv_usec - before.tv_usec); 

} 

} 

return 0; 

} else { 

return -1; 

} 

}

下面是一个 PHP 的例子( 为简化起见 , 程序的错误检查被忽略)

<? 

include "<path_to_file>/how_long.inc"; 

how_long(TV_START, $timestr); 

$conn = OCILogon("username", "password", "dblink"); 

$stmt = OCIParse($conn, "select ID from users where name='slimzhao'"); 

OCIDefineByName($stmt, ID, $id); 

OCIExecute($stmt); 

OCIFetch($stmt); 

OCIFreeStatement($stmt); 

OCILogoff($conn); 

how_long(TV_END, $timestr); 

echo " 用户 ID: $id , 该操作消耗时间 :$timestr<br>"; 

?> 

其中 how_long 函数的 PHP 版本如下 : 

<? 

# 作者 : slimzhao@21cn.com 

# 当前维护人 : slimzhao@21cn.com 

# 创建日期 : 2001.12.04 00:18:00 

# 目的 , 在一个操作之前或之后调用该函数的不同版本 , 将得到一个记载了该操作 

# 耗费时间的字符串 , 该函数本身的开销不计入其中 . 

define("TV_START", 0); 

define("TV_END", 1); 

function how_long($operation, &$str) 

# 返回值 : 0-- 成功 , -1-- 传递了非法的参数 . 

{ 

global $before_SQL, $after_SQL; 

if($operation == TV_START) { 

$before_SQL = gettimeofday(); 

return 0; 

} else if($operation == TV_END) { 

$after_SQL = gettimeofday(); 

if($before_SQL["usec"] > $after_SQL["usec"]) { 

$str = ($after_SQL["sec"] - $before_SQL["sec"] - 1)." 秒 ". 

($after_SQL["usec"] + 1000*1000 -$before_SQL["usec"])." 微秒 "; 

} else { 

$str = ($after_SQL["sec"] - $before_SQL["sec"])." 秒 ". 

($after_SQL["usec"]-$before_SQL["usec"])." 微秒 "; 

} 

} else { 

return -1; 

} 

} 

?>

1 2 3 4 下一页>>


[ 发表评论 ] 字体[  ] [ 打印 ] [ 进入博客 ] [ 进入论坛 ]  [ 推荐给朋友 ]
  相关文章
· 戴尔调查用户最喜欢什么Linux软件 (03-14) · 戴尔调查用户使用Linux偏好 为推新品做准备 (03-14)
· 数据库系统安全框架与其各层安全技术 (03-13) · 用ANSI SQL编写跨平台的数据库应用程序 (03-13)
· 用 Linux 系统防火墙功能抵御网络攻击 (03-12) · MySQL数据库中关于网络安全的解决方案 (03-12)
· 卫报:戴尔售预装Linux的电脑真容易吗? (03-12) · Red Hat将建立网络软件商店推销Linux产品 (03-11)
· 一山无二虎:数据库时代是否即将终结? (03-09) · 一山无二虎:数据库时代是否即将终结 (03-09)
  客户需求反馈表
* 姓  名:
更多资料  了解方案  认识厂商
* 单位名称:
* 联系电话:
* 电子邮件:
  赛迪推荐  
  手机·资费 ·新品·导购·评测·手机资费·宽带
手机搜索  诺基亚 N73 MOTO Z6
  IT产品 ·笔记本·台式机·服务器·打印·投影
IT产品搜索 
  IT技术 ·开发·网管·安全·数据库·操作系统
  博客·论坛 ·曾剑秋·项立刚·Java学习·网管