sybase数据库tempdb日志滿了

原创 2007年09月26日 12:35:00
 
开发数据库服务器遇到这样的一个问题,使用了一段时间之的后,突然之间数据库就用不了了,现象是新连接连接不上,已经连接的执行sql时,报出tempdb日志满了,无法进行操作的错误,而且控制台无法连接上服务器,所有操作都无法正常进行。
经过上网查询,得知是tempdb日志满了,缺省情况下,tempdb数据库是放置在master设备上,容量为2M,而临时数据库是活动最为平凡的数据库常常被用来排序、创建临时表、重格式化等操作,所以tempdb的优化应该受到特别的关注。安装Sybase的时候就应该把tempdb的空间扩大,并且最好新建一个表空间给它专门用。
正常的时候可以用sp_helpdb tempdb命令查看tempdb,可以看到tempdb占用空间的情况。
如果日志满了,可以执行dump tran tempdb with truncate_only或者dump tran   tempdb with no_log来清除日志,但是现在根本无法执行该语句,因为tempdb已经满了,根本没有空间来执行该语句,这该怎么办,好像进入了一个死循环里,日志满了要清除,但因为满了又无法清除,看来只能先扩容了,现在已经没有一个空闲的表空间了,控制台根本无法连接上数据库,只能用语句来新建一个表空间,下面是新建表空间的语句:
disk init
name="tempdblog",
physname="c:/sybasedb/tempdblog.dat",
vdevno=11,
size= 409600
go
   新建好表空间后,将该空间分配给tempdb存放日志用如下命令:
   alter database tempdb log on tempdblog=800
   如果要分配数据空间,用如下命令:
   alter database tempdb on tempdbdata=1024
   分配好后,就可以执行之前的清除日志的语句:
   dump tran tempdb with truncate_only
   或者 dump tran tempdb with no_log
   如果不想占用master的空间,可以执行如下语句将master上为tempdb的空间删除:
sp_dropsegment "default",tempdb,master
sp_dropsegment logsegment,tempdb,master
 
还可以将临时数据库与高速缓冲进行绑定
tempdb数据库是活动最为平凡的数据库,常常被用来排序、创建临时表、重格式化等操作,它会频繁地使用数据缓存,所以应为临时数据库创建高速缓存,从而可以使其常驻内存并有助于分散I/O,根据服务器的实际情况,我们为tempdb数据库创建100M的高速缓存,实现方法如下:
1、创建命名高速缓存
  sp_cacheconfig “tempdb_cache”,”100m”,”mixed”
go
2、重新启动server
3、捆绑临时数据库到tempdb_cache高速缓存
  sp_bindcache “tempdb_cache”, tempdb
go
以上操作已在系统中实现,硬件环境为IBMX系列服务器,操作系统为sco unix 5.0.6,系统优化后,性能得到较为明显的提高。 

Sybase临时数据库tempdb优化

 将Sybase临时数据库tempdb从master设备上移走的两种方法:缺省情况下,tempdb数据库是放置在master设备上,容量为2M,而临时数据库是活动最为平凡的数据库常常被用来排序、创建临...
  • andkylee
  • andkylee
  • 2009年11月18日 21:59
  • 2690

sybase数据库tempdb空间满故障解决

公司部分业务系统使用的是sybase数据库,  前几天开发同事使用过程中,数据库突然无法连接,发现报错,如下图;  该故障是由于tempdb存储空间已满,于是,为tempdb扩容,具体步骤...
  • iris_xuting
  • iris_xuting
  • 2016年12月20日 18:37
  • 526

关于 sybase 的 tempdb 数据库

tempdb是临时库tempdb可以alter的。     一般要根据你使用临时表的大小而定,我们有过1G的tempdb。     tempdb的数据不会影响其他的数据库,他的作用一般用于存储过程存临...
  • zwhfyy
  • zwhfyy
  • 2007年07月24日 10:16
  • 2092

sybase ASE tempdb 空间不足解决办法

报错信息如下 Space available in the log segment has fallen critically low in database 'tempdb'. All futu...
  • lileizhang
  • lileizhang
  • 2014年08月16日 22:07
  • 2081

Sybase对多个临时数据库tempdb的支持

发现Sybase有个非常有趣的特性,就是支持多个tempdb。虽然一向对Sybase没什么好感,但对这个特性还是十分欣赏。查看了一点资料,觉得Sybase自身的一个白皮书比较权威,试着做个翻译。 ...
  • xujinyang
  • xujinyang
  • 2012年02月21日 11:09
  • 1369

Sql Server Tempdb原理-日志机制解析实践

Sql Server Tempdb原理-日志机制解析实践 笔者曾经在面试DBA时的一句”tempdb为什么比其他数据库快?”使得95%以上的应试者都一脸茫然.Tempdb作为Sqls...
  • weizhiai12
  • weizhiai12
  • 2016年05月24日 16:33
  • 281

Sybase清理海量历史数据(单张表几亿数据真实环境使用中)

之前在试验了bcp,传统的正向delete方法皆不可取的情况下,考虑使用select into 反向做法,把要保留的数据通过select into 法重新创建对象, 达到了数据快速进入新表,并对新表进...
  • xujinyang
  • xujinyang
  • 2011年10月13日 19:06
  • 1205

Sybase 海量数据分页瞬间完成

海量数据分页(100W条),首次分页大概为10秒左右。以后翻页基本上是瞬间完成。要求是无排序情况下。 目前sybase分页: 1,hibernate分页:hibernate分页前几页和后几页没问题,如...
  • damenggege123
  • damenggege123
  • 2013年04月22日 10:15
  • 5066

【数据库 'tempdb' 的日志已满】最新解决方法

数据库 'tempdb' 的日志已满 执行sql 语句,中间没有用到临时表 提示服务器: 消息 9002,级别 17,状态 2,行 1 数据库 'tempdb' 的日志已满。请备份该数据...
  • andyjiang2008
  • andyjiang2008
  • 2015年04月03日 09:20
  • 3731

数据库 'tempdb' 的事务日志已满。若要查明无法重用日志中的空间的原因

最常的做法: --1.清空日志 DUMP TRANSACTION tempdb WITH NO_LOG --2.截断事务日志: BACKUP LOG tempdb WITH NO_LOG --3.收缩...
  • yenange
  • yenange
  • 2014年02月27日 11:24
  • 11396
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:sybase数据库tempdb日志滿了
举报原因:
原因补充:

(最多只允许输入30个字)