informix GBase -179 ISAM error: No free disk space for sort.

本文介绍了解决数据库在进行大规模数据排序时遇到的磁盘空间不足问题,分析了错误原因并提供了两种解决方案:增加数据库内存和为临时数据库空间添加chunk。最终选择了第二种方案实施。
部署运行你感兴趣的模型镜像

项目场景:

单表100W+,需要通过时间排序分页查询数据。

问题描述:

-179 ISAM error: No free disk space for sort.
官方解释如下

在执行排序时,数据库服务器找不到足够的连续空闲磁盘空间来创建必要的临时文件。在 再次运行程序之前,您可能没有足够的磁盘空间,并且需要提供更多的磁盘空间。当您在DBSPACETEMP中指定临时 dbspace 的名称或在 PSORT_DBTEMP 中指定目录名时,可能会出错。检查DBSPACETEMP 中指定的临时空间名的拼写。如果指定了多个临时 dbspace ,请检查是否使用

原因分析:

内存太小,排序的内存放不下,在磁盘里面做排序;结果磁盘也耗尽了
在这里插入图片描述

解决方案:

  1. 添加数据库内存
  2. 添加chunk到tmpdbs1

我们选择第二种

onspaces -a tmpdbs1 -p /home/informix/gbase/jmgc_dbs/tmpdbs2-o 0 -s 10485760

您可能感兴趣的与本文相关的镜像

ACE-Step

ACE-Step

音乐合成
ACE-Step

ACE-Step是由中国团队阶跃星辰(StepFun)与ACE Studio联手打造的开源音乐生成模型。 它拥有3.5B参数量,支持快速高质量生成、强可控性和易于拓展的特点。 最厉害的是,它可以生成多种语言的歌曲,包括但不限于中文、英文、日文等19种语言

[2025-09-16 14:21:08,746] ERROR WorkerSourceTask{id=informix-connector-0} Task threw an uncaught and unrecoverable exception. Task is being killed and will not recover until manually restarted (org.apache.kafka.connect.runtime.WorkerTask:190) io.debezium.DebeziumException: Couldn't obtain database name at io.debezium.connector.informix.InformixConnection.retrieveRealDatabaseName(InformixConnection.java:84) at io.debezium.connector.informix.InformixConnection.<init>(InformixConnection.java:76) at io.debezium.connector.informix.InformixConnectorTask.lambda$start$1(InformixConnectorTask.java:75) at io.debezium.jdbc.DefaultMainConnectionProvidingConnectionFactory.<init>(DefaultMainConnectionProvidingConnectionFactory.java:16) at io.debezium.connector.informix.InformixConnectorTask.start(InformixConnectorTask.java:74) at io.debezium.connector.common.BaseSourceTask.start(BaseSourceTask.java:248) at org.apache.kafka.connect.runtime.WorkerSourceTask.initializeAndStart(WorkerSourceTask.java:231) at org.apache.kafka.connect.runtime.WorkerTask.doRun(WorkerTask.java:186) at org.apache.kafka.connect.runtime.WorkerTask.run(WorkerTask.java:237) at java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515) at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264) at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128) at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628) at java.base/java.lang.Thread.run(Thread.java:834) Caused by: java.sql.SQLException: No connect permission. at com.informix.util.IfxErrMsg.buildExceptionWithMessage(IfxErrMsg.java:424) at com.informix.util.IfxErrMsg.buildIsamException(IfxErrMsg.java:403) at com.informix.jdbc.IfxSqli.addException(IfxSqli.java:3023) at com.informix.jdbc.IfxSqli.receiveError(IfxSqli.java:3274) at com.informix.jdbc.IfxSqli.dispatchMsg(IfxSqli.java:2269) at com.informix.jdbc.IfxSqli.receiveMessage(IfxSqli.java:2194) at com.informix.jdbc.IfxSqli.executeOpenDatabase(IfxSqli.java:1798) at com.informix.jdbc.IfxSqliConnect.<init>(IfxSqliConnect.java:1742) at com.informix.jdbc.IfxDriver.connect(IfxDriver.java:167) at io.debezium.jdbc.JdbcConnection.lambda$patternBasedFactory$1(JdbcConnection.java:246) at io.debezium.jdbc.JdbcConnection$ConnectionFactoryDecorator.connect(JdbcConnection.java:132) at io.debezium.jdbc.JdbcConnection.establishConnection(JdbcConnection.java:920) at io.debezium.jdbc.JdbcConnection.connection(JdbcConnection.java:904) at io.debezium.jdbc.JdbcConnection.connection(JdbcConnection.java:898) at io.debezium.jdbc.JdbcConnection.queryAndMap(JdbcConnection.java:642) at io.debezium.jdbc.JdbcConnection.queryAndMap(JdbcConnection.java:515) at io.debezium.connector.informix.InformixConnection.retrieveRealDatabaseName(InformixConnection.java:81) ... 13 more Caused by: java.sql.SQLException: ISAM error: no record found. at com.informix.util.IfxErrMsg.buildExceptionWithMessage(IfxErrMsg.java:424) at com.informix.util.IfxErrMsg.buildException(IfxErrMsg.java:399) at com.informix.util.IfxErrMsg.getSQLException(IfxErrMsg.java:373) at com.informix.jdbc.IfxSqli.receiveError(IfxSqli.java:3278) ... 26 more
最新发布
09-17
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值