Sybase数据库中tempdb满问题的分析方法
1. 用dbuser登陆数据库如果当前用户是root,则执行以下命令切换到dbuser。
# su - dbuser
2. 配置分析环境
配置分析环境,需要执行以下命令:
$ . ./SYBASE.sh
$ dataserver -X
在提示输入口令时,输入quine(固定的口令),然后回车
Enter password:
在以下">"提示符处输入"cat /opt/sybase/ASE-15_0",命令执行后会显示数据库实例信息。
> cat /opt/sybase/ASE-15_0
根据显示的数据库实例信息,执行以下命令(注意,attach后输入的实例名根据实际显示为准,本文的举例假设为SYB)
> attach SYB
如果加载成功,则会显示如下信息:
Attaching to server SYB, using shared memory id: 83886112
SYB:active>
随后就可以在"SYB:active>"提示符后执行命令,获取需要的定位信息。
3. 分析问题
以下重点说明对于分析tempdb空间满有帮助的几个命令和输出信息。
1) who
该命令可以不带参数执行,显示当前数据库中所有在运行的数据库连接信息。也可以带上具体的spid号,显示指定spid的数据库连接的信息。
重点关注各个数据库连接的spid,以及占用tempdb的页数(ptempdb_pages)。
举例说明:
SYB:active> who
以下这段显示的是spid为2的数据库连接的信息,可以看出这条连接使用的tempdb空间为0(ptempdb_pages: 0),这条连接是数据库内部系统进程(P_SYSTEMPROC)。
********Active PSS Structures********
spid: 2, kpid: 327685, pss: 0x10047ba6fc0, proc: 0x1004cdb9850
pmemusage: 0, ptempdb_pages: 0
Command: 0 DEADLOCK TUNE
Status: (0x00000200 (P_SYSTEMPROC))
*****************************************
... ...
以下这段显示的是spid为13的数据库连接的信息,可以看出这条连接使用的tempdb空间为26455页(ptempdb_pages: 26455)。如果数据库的页面大小为8K,则这条连接占用了26455*8K=207M的tempdb空间。这条连接是应用库的进程(P_USERPROC)。
*****************************************
spid: 13, kpid: 1070138198, pss: 0x10047ca23e8, proc: 0x1004cedf058
pmemusage: 17, ptempdb_pages: 26455
User: sa, Command: 326 UPDATE STATISTICS
Status: (0x20000000 (P_LOGSUSPEND), 0x00010000 (P_USERPROC))
*****************************************
2) sqltext
显示spid对应的连接执行的具体sql语句信息。
输出举例,以下语句显示spid为13的连接正在执行更新性能结果表统计信息的操作。
SYB:active> sqltext 13
*************** SPID: 13 ******************
SQL Text:update statistics tbl_Result_1157628012_2(ObjectNo)
3) locks
显示所有被held或者等待的锁信息。
4. 分析tempdb满的步骤
1)先执行命令who,然后分析所有输出中ptempdb_pages不为0的连接,记录这些连接的spid和ptempdb_pages(该连接占用的tempdb的容量)。
2)根据上一步收集到的spid,执行sqltext <spid>,调查这些连接正在执行的sql信息。
通过以上步骤,我们就可以获知哪些任务在占用tempdb的空间,并且具体占用多少? 解决TEMPDB的直接办法,定时重启服务器是最好的办法! 呵呵 在高可靠系统中
一年的down机时间 只允许5分钟。。。。
重启是非不得已不能做呀;。。 好文章,支持 介绍sybmon的用法,挺好。 真是太棒了。请问哪里还有更详细的资料啊?谢谢 attach servername 完了记得 detach servername 。
论坛藏龙卧虎啊
这种内部诊断的程序都研究的那么细。佩服。 这个办法蛮有新意的,呵呵,不过提醒一下,sqltext可不是总是好用哟,一些情况下什么都不会打印出来的,比如一些复杂的存储过程。 sybmon不错,看来知道的不少,光分析tempdb就太可惜了,能干的事情太多了。 echoaix 发表于 2011-12-20 18:10 static/image/common/back.gif
sybmon不错,看来知道的不少,光分析tempdb就太可惜了,能干的事情太多了。
echoaix版大还有更详细的资料吗?
页:
[1]
2