AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 591048
Accepted
user1340582
user1340582
Asked: 2014-04-25 03:44:19 +0800 CST2014-04-25 03:44:19 +0800 CST 2014-04-25 03:44:19 +0800 CST

IBM DB2 9.7,无法增加 LOGFILSIZ 或 LOGPRIMARY 值

  • 772

我正在使用 IBM DB2 9.7 LUW 数据库。我当前的循环日志记录数据库配置值如下:

LOGFILSIZ: 1024
LOGPRIMARY: 13
LOGSECONDARY: 15

我收到事务日志已满的错误,因此我需要增加日志大小。我尝试了以下方法:

LOGFILSIZ: 4000
LOGPRIMARY: 10
LOGSECONDARY: 20

我还重新启动了数据库。LOGSECONDARY更改为 20,但仍LOGFILSIZ保持在 1024 和LOGPRIMARY13。

我是否为我的问题更改了正确的值,为什么即使我重新启动了数据库,这些值也不会改变?

log-files
  • 2 2 个回答
  • 3657 Views

2 个回答

  • Voted
  1. Best Answer
    Ian Bjorhovde
    2014-04-25T11:39:36+08:002014-04-25T11:39:36+08:00

    您正在更改正确的参数,但听起来好像您实际上并没有重新启动数据库,这可以解释为什么LOGSECOND立即生效,但LOGPRIMARY尚未LOGFILSIZ更改。您可以使用命令查看这些配置参数的当前值和延迟(待定)值GET DATABASE CONFIGURATION FOR <yourdb> SHOW DETAIL。我怀疑你会看到 和 的延迟值LOGPRIMARY分别LOGFILSIZ是 10 和 4000。

    确保完全回收 DB2 数据库的最简单方法是停止并重新启动整个实例(使用db2stop force和db2start命令)。之后,您可以选择使用该ACTIVATE DATABASE语句激活数据库。

    不过,您不必关闭整个 DB2 实例。要正确地重新启动 DB2 数据库,您必须停用它(即,使数据库解除分配给它的所有内存)。您可以通过终止与数据库的所有连接(使用该FORCE APPLICATION语句)然后(如有必要)发出该DEACTIVATE DATABASE语句来做到这一点。您可以通过发出命令来验证数据库是否完全停止LIST ACTIVE DATABASES- 如果您的数据库不在返回的列表中,则它已停止。

    在此(或)之后与数据库的任何新连接ACTIVATE DATABASE都将导致 DB2 启动有问题的数据库,此时它将使用新参数分配日志文件。

    • 1
  2. ultimatum
    2014-06-03T01:30:59+08:002014-06-03T01:30:59+08:00

    您必须确保更改在磁盘和内存中都有效。您可以使用db2pd命令(随版本 8.2 发布)或使用上面 Ian 提到的GET DATABASE CONFIGURATION命令检查这一点。

    主要区别在于 db2pd 命令不需要连接到数据库,而GET DATABASE CONFIGURATION FOR dbname SHOW DETAIL确实需要连接(注意 SHOW DETAIL 子句,这需要连接 - 不是标准的 GET DATABASE CONFIGURATION FOR dbname 命令)

    db2pd -d 数据库名称 dbcfg | egrep 'LOGFILSIZ|LOGPRIMARY|LOGSECOND'

    这将列出以下 3 个值-

    Description                             Memory Value                Disk Value
    Log file size (4KB)                         (LOGFILSIZ) = 1024                       4000
    Number of primary log files                (LOGPRIMARY) = 13                         10
    Number of secondary log files               (LOGSECOND) = 20                         20
    

    您可能会注意到 LOGSECOND 更改立即对磁盘和内存生效,而其他 2 个更改需要重新启动数据库才能使更改在内存中生效 - 因此数据库才能实际使用它。

    对于重启,您可以按照标准顺序 - 停用数据库、关闭实例、清理资源、启动实例然后激活数据库并验证磁盘和内存上的上述值是否相同。

    • db2 停用 db dbname
    • db2stop
    • ipclean -a
    • db2start
    • db2 激活 db 数据库名
    • 1

相关问题

  • 基于时间戳剪切日志文件部分的快速脚本

  • 如何以友好的格式读取 pcap 文件?

  • 什么是好的日志查看器,例如 apache、postfix、syslog?

  • 是否有一种简单的方法可以生成有关 IIS 中“死”文件的报告?

  • 避免将某些丢失的文件记录到 Apache2 错误日志中

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve