Sybase数据库:日志过大导致不能启动

  • 来源: 赛迪网技术社区 作者: 若水   2008-04-08/13:19
  • Sybase数据库:日志过大导致不能启动

    问:有个问题问一下,关于SYBASE的:我打开数据库总是提醒:cannot open transaction log file-----cannot use log file "hms2000.log" since it is shorter than experted。我直接删除了日志,也不能正常启动,说找不到文件。请问这是怎么回事啊?附上出错的日志记录:I. 10/09 09:58:38. Sybase Adaptive server Anywhere Network server Version 7.0.2.1402 ;A=[M[>  
    I. 10/09 09:58:38. This software contains confidential and trade secret information of f5RBQ&lS  
    I. 10/09 09:58:38. Sybase, Inc.Use, duplication or disclosure of the software and }u_WP)(  
    I. 10/09 09:58:38. documentation by the U.S. Government is subject to restrictions set forth N O*(T`yv  
    I. 10/09 09:58:38. in a license agreement between the Government and Sybase, Inc. or other 60 dSO|A  
    I. 10/09 09:58:38. written agreement specifying the Government's rights to use the software pQb *Q2f4  
    I. 10/09 09:58:38. and any applicable FAR provisions, for example, FAR 52.227-19. yfBP#Xa:  
    I. 10/09 09:58:38. wl=sRnW  
    I. 10/09 09:58:38. Copyright 1989-2000 Sybase, Inc.All rights reserved. <sR2?yq"a  
    I. 10/09 09:58:38. All unpublished rights reserved. vl,W'W  
    I. 10/09 09:58:38. ThSywQ}~  
    I. 10/09 09:58:38. Sybase, Inc. 6475 Christie Avenue, Emeryville, CA 94608, USA |gJkR-|lFa  
    I. 10/09 09:58:38. Networked Seat (per-seat) model. Access to the server is limited to 99 seat(s). eHLSZQ+)  
    I. 10/09 09:58:38. This server is licensed to: _AqO+kH)  
    I. 10/09 09:58:38.lb TpT>Qd(b>  
    I. 10/09 09:58:38. TC?KKc rpq  
    I. 10/09 09:58:38. 10240K of memory used for caching ,x9!:I)  
    I. 10/09 09:58:38. Minimum cache size: 10240K, maximum cache size: 230848K $*su.x }8'  
    I. 10/09 09:58:38. Using a maximum page size of 1024 bytes a$1E @j/  
    I. 10/09 09:58:38. Starting database "XXXXXXX" (C:Program Filessybase数据服务器XXXXXXX.db) at Sun Oct 09 2005 09:58 V b+P4ua  
    I. 10/09 09:58:38. Database recovery in progress ~XOmFJwiw  
    I. 10/09 09:58:38.Last checkpoint at Sat Oct 08 2005 19:15 h!\snQ.d  
    I. 10/09 09:58:38.Checkpoint log... Sy#>o5D\  
    I. 10/09 09:59:03.Transaction log: XXXXXXX.LOG... o< $uK&  
    E. 10/09 09:59:03. Error: Cannot open transaction log file -- Can't use log file "XXXXXXX.LOG" since it is shorter than expected 8B KY(  
    I. 10/09 09:59:03. Error: Cannot open transaction log file -- Can't use log file "XXXXXXX.LOG" since it is shorter than expected mu.\Y'm  
    E. 10/09 09:59:03. Cannot open transaction log file -- Can't use log file "XXXXXXX.LOG" since it is shorter than expected 6(~F=k5W  
    I. 10/09 09:59:04. Database server stopped at Sun Oct 09 2005 09:59 c_-X`x  
    I. 10/09 10:58:33. Sybase Adaptive server Anywhere Network server Version 7.0.2.1402 U#`Lt\8  
    I. 10/09 10:58:33. This software contains confidential and trade secret information of S=1JPi(g~  
    I. 10/09 10:58:33. Sybase, Inc.Use, duplication or disclosure of the software and #&?6h5>  
    I. 10/09 10:58:33. documentation by the U.S. Government is subject to restrictions set forth IEd{DC  
    I. 10/09 10:58:33. in a license agreement between the Government and Sybase, Inc. or other mf'$IDACe  
    I. 10/09 10:58:33. written agreement specifying the Government's rights to use the software )pO"gz%  
    I. 10/09 10:58:33. and any applicable FAR provisions, for example, FAR 52.227-19. }7<ec6_  
    I. 10/09 10:58:33. = W0RDY* #p#分页标题#e# 
    I. 10/09 10:58:33. Copyright 1989-2000 Sybase, Inc.All rights reserved. ?hV[k8-(a  
    I. 10/09 10:58:33. All unpublished rights reserved. )Jpb=P@  
    I. 10/09 10:58:33. ~\lU`h`Ml  
    I. 10/09 10:58:33. Sybase, Inc. 6475 Christie Avenue, Emeryville, CA 94608, USA 8XZ d)H  
    I. 10/09 10:58:33. Networked Seat (per-seat) model. Access to the server is limited to 99 seat(s). $ t#'K] x  
    I. 10/09 10:58:33. This server is licensed to: c.N6P;}(M  
    I. 10/09 10:58:33.lb QA mE9  
    I. 10/09 10:58:33. `[{P#M;T  
    I. 10/09 10:58:33. 10240K of memory used for caching ax/q6PDy~  
    I. 10/09 10:58:33. Minimum cache size: 10240K, maximum cache size: 230848K  JJ&^|g0w  
    I. 10/09 10:58:33. Using a maximum page size of 1024 bytes L2MGX[SE@$  
    I. 10/09 10:58:33. Starting database "XXXXXXX" (C:Program Filessybase数据服务器XXXXXXX.db) at Sun Oct 09 2005 10:58 ?I5:}   
    I. 10/09 10:58:33. Database recovery in progress A!d-\}  
    I. 10/09 10:58:33.Last checkpoint at Sat Oct 08 2005 19:15 {.Xk#1.^(  
    I. 10/09 10:58:33.Checkpoint log... KQcN]z:T i  
    I. 10/09 10:58:55.Transaction log: XXXXXXX.LOG... LcsDxl>h  
    E. 10/09 10:58:55. Error: Cannot open transaction log file -- Can't use log file "XXXXXXX.LOG" since it is shorter than expected XW$7Te 0Q  
    I. 10/09 10:58:55. Error: Cannot open transaction log file -- Can't use log file "XXXXXXX.LOG" since it is shorter than expected :z%CIZ"  
    E. 10/09 10:58:55. Cannot open transaction log file -- Can't use log file "XXXXXXX.LOG" since it is shorter than expected ^dAE%`@SY  
    I. 10/09 10:58:57. Database server stopped at Sun Oct 09 2005 10:58 v+ ~Q{nN  
    答:首先要确定的一点:直接删除日志的方法是不可取的。您的这个问题,是因为日志没有及时整理导致自身过大,使数据库不能正常启动。 XeSCM" fX  
    我们知道,SYBASEsql Server用事务(Transaction)来跟踪所有数据库的变化。事务是SQLServer的工作单元。一个事务包含一条或多条作为整体执行的T-SQL语句。每个数据库都有自己的事务日志(TransactionLog),即系统表(Syslogs)。事务日志自动记录每个用户发出的每个事务。日志对于数据库的数据安全性、完整性至关重要,我们进行数据库开发和维护必须熟知日志的相关知识。 7 x_iX  
    OKnFZq  
    一、SYBASEsql server 如何记录和读取日志信息 xAbU0N  
    a|n' @cn  
    SYBASEsql Server是先记Log的机制。每当用户执行将修改数据库的语句时,SQLServer就会自动地把变化写入日志。一条语句所产生的所有变化都被记录到日志后,它们就被写到数据页在缓冲区的拷贝里。该数据页保存在缓冲区中,直到别的数据页需要该内存时,该数据页才被写到磁盘上。若事务中的某条语句没能完成,SQLServer将回滚事务产生的所有变化。这样就保证了整个数据库系统的一致性和完整性。 {kdop"c<k  
    lP|$sas  
    二、日志设备 2w8ALG.  
    xSs /gW!  
    Log和数据库的Data一样,需要存放在数据库设备上,可以将Log和Data存放在同一设备上,也可以分开存放。一般来说,应该将一个数据库的Data和Log存放在不同的数据库设备上。这样做有如下好处:一是可以单独地备份?Backup事务日志;二是防止数据库溢满;三是可以看到Log的空间使用情况。 {a0e4*L  
    we e}  
    所建Log设备的大小,没有十分精确的方法来确定。一般来说,对于新建的数据库,Log的大小应为数据库大小的30%左右。Log的大小还取决于数据库修改的频繁程度。如果数据库修改频繁,则Log的增长十分迅速。所以说Log空间大小依赖于用户是如何使用数据库的。此外,还有其它因素影响Log大小,我们应该根据实际操作情况估计Log大小,并间隔一段时间就对Log进行备份和清除。 HP0d+1=Qz  
    三、日志的清除 L=&r]  
    \FL;9z77Z  
    随着数据库的使用,数据库的Log是不断增长的,必须在它占满空间之前将它们清除掉。清除Log有两种方法: f.0,r8 #p#分页标题#e# 
    2D?3K~mm  
    1.自动清除法 n/14R-b1  
    [y. SP  
    开放数据库选项 Trunc Log on Chkpt,使数据库系统每隔一段时间自动清除Log。此方法的优点是无须人工干预,由SQLServer自动执行,并且一般不会出现Log溢满的情况;缺点是只清除Log而不做备份。 '$mHpjav  
    _X`ZD  
    2.手动清除法 D|IP O},  
    O J P@  
    执行命令“dump transaction”来清除Log。以下两条命令都可以清除日志: D;<H-.  
    8f,C7MuwV  
    dump transaction with truncate_only t^H_!<`k&  
     GpH;Slq  
    dump transaction with no_log I~I.?iKS|  
    S1tV|(  
    通常删除事务日志中不活跃的部分可使用“dump transaction with trancate_only”命令,这条命令写进事务日志时,还要做必要的并发性检查。SYBASE提供“dump transaction with no_log”来处理某些非常紧迫的情况,使用这条命令有很大的危险性,SQLServer会弹出一条警告信息。为了尽量确保数据库的一致性,你应将它作为“最后一招”。 wPm a+K1]q  
    a^mgUj)f  
    以上两种方法只是清除日志,而不做日志备份,若想备份日志,应执行“dump transaction database_name to dumpdevice”命令。  @6C  
    oZ?#FDT$X  
    四、管理庞大的事务 tllI('q  
     t$h\KG  
    有些操作会大批量地修改数据,如大量数据的修改(Update)、删除一个表的所有数据(Delete)、大量数据的插入(Insert),这样会使Log增长速度很快,有溢满的危险。下面给大家介绍一下如何拆分大事务,以避免日志的溢满。 g5hEHz)0  
    qU-~`lA!  
    例如执行“update tab_a set col_a=0”命令时,若表tab_a很大,则此Update动作在未完成之前就可能使Log溢满,引起1105错误(Log Full),而且执行这种大的事务所产生的独占锁(Exclusive table Lock),会阻止其他用户在执行Update操作期间修改这个表,这就有可能引起死锁。为避免这些情况发生,我们可以把这个大的事务分成几个小的事务,并执行“dump transaction”动作。 " hwY v  
    KorA& L?x  
    rQ]Wd  
    6k>l Pf6-O  
    上例中的情况就可以分成两个或多个小的事务: G >.z_w^~  
    JKwDiqioe  
    update tab_a set col_a=0 where col_b>x !U%{_7BQD  
    ) 7]FCHJ=  
    go . pWj=Qq4  
    mNU2ndG(  
    dump transaction database_name with truncate_only ZNd%^5w  
    #=P 9g6V  
    go .S)#UjW0$o  
    7wuJLL.  
    update tab_a set col_a=0 where col_b <=x 2O5A(o_x]  
    LK$xm4u+Z  
    go -&[9>  
    !{>+/cap  
    dump transaction database_name with truncate_only *KRt,hL #S  
    *ehs3'rYg  
    go 8^/  
    3a+VYG  
    这样,一个大的事务就被分成两个较小的事务。 uJ>5S 3  
    .fMjDA A  
    按照上述方法可以根据需要任意拆分大的事务。若这个事务需要备份到介质上,则不用“with truncate_only”选项。若执行“dump transaction with truncate_only”命令,应该先执行“dump database”。以此类推,我们可以对表删除、表插入等大事务做相应的拆分。 nWrrv  

    评论 {{userinfo.comments}}

    {{money}}

    {{question.question}}

    A {{question.A}}
    B {{question.B}}
    C {{question.C}}
    D {{question.D}}
    提交

    驱动号 更多