在DM7中,log_commit.log文件用于记录数据库接收到的所有SQL语句等信息,DBA可以通过分析该文件来帮助解决问题。要生成该文件,只需将配置文件dm.ini中的参数SVR_LOG设置为1,即启用SVR_LOG就可以了。
log_commit.log默认存储在与bin目录同级的log目录下。但是在读写频繁的生产环境中,存储为默认路径可能会有如下问题发生:
1、dmp或bak文件未及时清理,累积造成磁盘空间不足,导致log_commit日志无法正常存储,从而使数据库无法被正常访问。
2、存储足够数量的log_commit.log文件,会更加利于DBA对数据库业务运行状态进行分析,但难免出现为了保证磁盘空间而减少对log_commit.log文件存储数量的情况。
尽早更换该日志文件的存储路径,就可以很好的避免陷入上述两难的窘境。
当然,上述问题未必一定发生,但是生产环境中未雨绸缪总还是好些。何况,修改方法非常简单。按如下三步:
步骤1:检查。
确保dm.ini中SVR_LOG=1,且有SVR_LOG_NAME参数及对应参数值,及log目录下有sqllog.ini文件:
步骤2:修改。
在SQL日志的配置文件sqllog.ini中修改:
FILE_PATH = 指定log_commit存储路径
比如:
文件sqllog.ini用于SQL日志的配置。当把dm.ini中参数SVR_LOG置为1(图1),才会打开SQL日志。
步骤3:使配置生效。
如果在服务器启动过程中,修改了sqllog.ini文件。修改之后的文件,只要调用过程SP_REFRESH_SVR_LOG_CONFIG() 就会生效。如下:
最后可以执行任意查询语句,确认一下日志的生成情况。
通过简单的检查、修改、使配置生效三步就可以修改log_commit.log日志文件存储路径的修改。
关于对log_commit.log日志文件的存储内容、个数、大小进行配置的方法,基本都是在配置文件中增加相应配置项,具体可以参考《DM7系统管理员手册》。