ERROR EN DBSPACE TEMPORAL

hola:

Tenemos instalador informix 9.21 en windows server 2000 con los service pack correspondientes.
Nos aparece el siguiente error con el DBSPACETEMP, en el log:

Mon Oct 25 16:33:58 2010

16:33:58 Booting Language from module <>
16:33:58 Loading Module
16:33:58 Booting Language from module <>
16:33:58 Loading Module
16:34:03 Informix Dynamic Server 2000 Version 9.21.TC4 Software Serial Number AAD#J113536
16:34:03 Informix Dynamic Server 2000 Initialized – Shared Memory Initialized.

16:34:03 Warning: Invalid (non-existent/blobspace/disabled) dbspace listed
in DBSPACETEMP: ‘E:\IFMXDATA\OL_CEO\tempdbs_dat.000’

16:34:03 Physical Recovery Started at Page(7:3).
16:34:09 Physical Recovery Complete: 0 Pages Examined 0 Pages Restored.

16:34:09 Logical Recovery Started.
16:34:09 10 recovery worker threads will be started.
16:34:12 Logical Recovery Complete.
0 Committed, 0 Rolled Back, 0 Open, 0 Bad Locks

16:34:13 Onconfig parameter ROOTSIZE modified from 30720 to 1000000.
16:34:13 Can NOT change ROOTSIZE without reinitializing, leaving 30720.
16:34:13 Dataskip is now OFF for all dbspaces
16:34:14 Init operation complete - Mode Online
16:34:14 On-Line Mode
16:34:14 Checkpoint Completed: duration was 0 seconds.
16:34:14 Checkpoint loguniq 167, logpos 0x46b018

16:35:04 Checkpoint Completed: duration was 0 seconds.
16:35:04 Checkpoint loguniq 167, logpos 0x46c018

16:35:05 Informix Dynamic Server 2000 Stopped.

16:35:24 Informix Dynamic Server 2000 Started.

En el onconfig lo tenemos de esta forma:

#**************************************************************************

INFORMIX SOFTWARE, INC.

Title: onconfig.std

Description: Informix Dynamic Server Configuration Parameters

#**************************************************************************

Root Dbspace Configuration

ROOTNAME rootdbs # Root dbspace name
ROOTPATH E:\IFMXDATA\ol_ceo\rootdbs_dat.000
# Path for device containing root dbspace
ROOTOFFSET 0 # Offset of root dbspace into device (Kbytes)
#ROOTSIZE 30720 # Size of root dbspace (Kbytes)
ROOTSIZE 1000000

Disk Mirroring Configuration Parameters

MIRROR 0 # Mirroring flag (Yes = 1, No = 0)
MIRRORPATH # Path for device containing mirrored root
MIRROROFFSET 0 # Offset into mirrored device (Kbytes)

Physical Log Configuration

PHYSDBS rootdbs # Location (dbspace) of physical log
#PHYSDBS logsdbs
#PHYSFILE 2000 # Physical log file size (Kbytes)
PHYSFILE 20000

Logical Log Configuration

LOGFILES 32 # Number of logical log files
LOGSIZE 20000 # Logical log size (Kbytes)
LOG_BACKUP_MODE MANUAL # Logical log backup mode (MANUAL, CONT)

Diagnostics

MSGPATH C:\informix\ol_ceo.log # System message log file path
CONSOLE C:\informix\conol_ceo.log # System console message path
ALARMPROGRAM C:\informix\etc\log_full.bat # Alarm program path
TBLSPACE_STATS 1 # Maintain tblspace statistics

System Diagnostic Script.

SYSALARMPROGRAM - Full path of the system diagnostic script (e.g.

c:\informix\etc\evidence.bat.) Set this parameter

if you want a different Diagnostic Script than

{INFORMIXDIR}\etc\evidence.bat, which is default.

System Archive Tape Device

#TAPEDEV \.\TAPE0 # Tape device path
TAPEDEV E:\IFMXBKUP\backup.bak
TAPEBLK 16 # Tape block size (Kbytes)
TAPESIZE 2147483647 # Maximum amount of data to put on tape (Kbytes)

Log Archive Tape Device

#LTAPEDEV \.\TAPE1 # Log tape device path
LTAPEDEV E:\IFMXBKUP\log.bak
LTAPEBLK 16 # Log tape block size (Kbytes)
LTAPESIZE 2147483647 # Max amount of data to put on log tape (Kbytes)

Optical

STAGEBLOB # Informix Dynamic Server/Optical staging area
OPTICAL_LIB_PATH # Location of Optical Subsystem driver DLL

System Configuration

SERVERNUM 0 # Unique id corresponding to a server instance
DBSERVERNAME ol_ceo # Name of default Dynamic Server
DBSERVERALIASES # List of alternate dbservernames
NETTYPE soctcp,1,NET # Override sqlhosts nettype parameters
DEADLOCK_TIMEOUT 60 # Max time to wait of lock in distributed env.
RESIDENT 0 # Forced residency flag (Yes = 1, No = 0)

MULTIPROCESSOR 1 # 0 for single-processor, 1 for multi-processor
NUMCPUVPS 4 # Number of user (cpu) vps
SINGLE_CPU_VP 0 # If non-zero, limit number of cpu vps to one

NOAGE 0 # Process aging
AFF_SPROC 0 # Affinity start processor
AFF_NPROCS 0 # Affinity number of processors

Shared Memory Parameters

LOCKS 50000 # Maximum number of locks
BUFFERS 200 # Maximum number of shared buffers
NUMAIOVPS 1 # Number of IO vps
PHYSBUFF 32 # Physical log buffer size (Kbytes)
LOGBUFF 32 # Logical log buffer size (Kbytes)
LOGSMAX 60 # Maximum number of logical log files
CLEANERS 1 # Number of buffer cleaner processes
SHMBASE 0xc000000 # Shared memory base address
SHMVIRTSIZE 8192 # initial virtual shared memory segment size
SHMADD 8192 # Size of new shared memory segments (Kbytes)
SHMTOTAL 0 # Total shared memory (Kbytes). 0=>unlimited
CKPTINTVL 300 # Check point interval (in sec)
LRUS 8 # Number of LRU queues
LRU_MAX_DIRTY 60 # LRU percent dirty begin cleaning limit
LRU_MIN_DIRTY 50 # LRU percent dirty end cleaning limit
LTXHWM 50 # Long transaction high water mark percentage
LTXEHWM 60 # Long transaction high water mark (exclusive)
TXTIMEOUT 0x12c # Transaction timeout (in sec)
STACKSIZE 64 # Stack size (Kbytes)

System Page Size

BUFFSIZE - Dynamic Server no longer supports this configuration parameter.

To determine the page size used by Dynamic Server on your platform

see the last line of output from the command, ‘onstat -b’.

Recovery Variables

OFF_RECVRY_THREADS:

Number of parallel worker threads during fast recovery or an offline restore.

ON_RECVRY_THREADS:

Number of parallel worker threads during an online restore.

OFF_RECVRY_THREADS 10 # Default number of offline worker threads
ON_RECVRY_THREADS 1 # Default number of online worker threads

Data Replication Variables

DRINTERVAL 30 # DR max time between DR buffer flushes (in sec)
DRTIMEOUT 30 # DR network timeout (in sec)
DRLOSTFOUND \tmp # DR lost+found file path

CDR Variables

CDR_LOGBUFFERS 2048 # size of log reading buffer pool (Kbytes)
CDR_EVALTHREADS 1,2 # evaluator threads (per-cpu-vp,additional)
CDR_DSLOCKWAIT 5 # DS lockwait timeout (seconds)
CDR_QUEUEMEM 4096 # Maximum amount of memory for any CDR queue (Kbytes)
CDR_LOGDELTA 30 # % of log space allowed in queue memory
CDR_NUMCONNECT 16 # Expected connections per server
CDR_NIFRETRY 300 # Connection retry (seconds)
CDR_NIFCOMPRESS 0 # Link level compression (-1 never, 0 none, 9 max)

Backup/Restore variables

BAR_ACT_LOG C:\informix\bar_ol_ceo.log #Path of log file for onbar.exe
BAR_MAX_BACKUP 0
BAR_RETRY 1
BAR_NB_XPORT_COUNT 10
BAR_XFER_BUF_SIZE 15
BAR_BSALIB_PATH C:\ISM\2.20\bin\libbsa.dll # Location of ISM XBSA DLL

RESTARTABLE_RESTORE off #To support restartable restore…values on/off

Informix Storage Manager variables

ISM_DATA_POOL ISMData
ISM_LOG_POOL ISMLogs

Read Ahead Variables

RA_PAGES # Number of pages to attempt to read ahead
RA_THRESHOLD # Number of pages left before next group

[b]# DBSPACETEMP:

Dynamic Server equivalent of DBTEMP for SE. This is the list of dbspaces

that the Dynamic Server SQL Engine will use to create temp tables etc.

If specified it must be a colon separated list of dbspaces that exist

when the Dynamic Server system is brought online. If not specified, or if

all dbspaces specified are invalid, various ad hoc queries will create

temporary files in /tmp instead.

DBSPACETEMP E:\IFMXDATA\OL_CEO\tempdbs_dat.000 # tempdbs # Default temp dbspaces[/b]

DUMP*:

The following parameters control the type of diagnostics information which

is preserved when an unanticipated error condition (assertion failure) occurs

during Dynamic Server operations.

For DUMPSHMEM, DUMPGCORE and DUMPCORE 1 means Yes, 0 means No.

DUMPDIR C:\tmp # Preserve diagnostics in this directory
DUMPSHMEM 1 # Dump a copy of shared memory
DUMPGCORE 0 # Dump a core image using ‘gcore’
DUMPCORE 0 # Dump a core image (Warning:this aborts Dynamic
DUMPCNT 1 # Number of shared memory or gcore dumps for
# a single user’s session

FILLFACTOR 90 # Fill factor for building indexes

method for Dynamic Server to use when determining current time

USEOSTIME 0 # 0: use internal time(fast), 1: get time from OS(slow)

Parallel Database Queries (pdq)

MAX_PDQPRIORITY 100 # Maximum allowed pdqpriority
DS_MAX_QUERIES 32 # Maximum number of decision support queries
DS_TOTAL_MEMORY 4096 # Decision support memory (Kbytes)
DS_MAX_SCANS 1048576 # Maximum number of decision support scans
DATASKIP off # List of dbspaces to skip

OPTCOMPIND

0 => Nested loop joins will be preferred (where

possible) over sortmerge joins and hash joins.

1 => If the transaction isolation mode is not

“repeatable read”, optimizer behaves as in (2)

below. Otherwise it behaves as in (0) above.

2 => Use costs regardless of the transaction isolation

mode. Nested loop joins are not necessarily

preferred. Optimizer bases its decision purely

on costs.

OPTCOMPIND 2 # To hint the optimizer

DIRECTIVES 1 # Optimizer DIRECTIVES ON (1/Default) or OFF (0)

ONDBSPACEDOWN 2 # Dbspace down option: 0 = CONTINUE, 1 = ABORT, 2 = WAIT
LBU_PRESERVE 0 # Preserve last log for log backup
OPCACHEMAX 0 # Maximum optical cache size (Kbytes)

HETERO_COMMIT (Gateway participation in distributed transactions)

1 => Heterogeneous Commit is enabled

0 (or any other value) => Heterogeneous Commit is disabled

HETERO_COMMIT 0

SBSPACENAME sbspace # Default sbspace

BLOCKTIMEOUT 3600 # Default timeout for system block

Optimization goal: -1 = ALL_ROWS(Default), 0 = FIRST_ROWS

OPT_GOAL -1

ALLOW_NEWLINE 0 # embedded newlines(Yes = 1, No = 0 or anything but 1)
SYSSBSPACENAME sbspace # Default System sbspace

The following are default settings for enabling Java in the database.

#VPCLASS jvp,num=1 # Number of JVPs to start with
JVPJAVAHOME # JDK installation root directory
JVPHOME C:\informix\extend\krakatoa # Krakatoa installation directory
JVPPROPFILE C:\informix\extend\krakatoa.jvpprops_ol_ceo # JVP property file
JDKVERSION 1.2 # JDK version supported by this server
JVMTHREAD native # Java VM thread type (green or native)

The path to the JRE libraries relative to JVPJAVAHOME

JVPJAVALIB \jre\bin\

The JRE libraries to use for the Java VM

JVPJAVAVM hpi;jvm;java;net;math;zip;jpeg

Classpath to use upon Java VM start-up (use _g version for debugging)

JVPCLASSPATH C:\informix\extend\krakatoa\krakatoa.jar;C:\informix\extend\krakatoa\jdbc.jar

JVPLOGFILE C:\informix\extend\krakatoa/jvp.log # JVP log file.

Cual seria el error por el que no lo toma?. Puse todo el onconfig por si tenemos otro error en la configuración.

Muchas gracias!!!

Hola pablo, en la variable dbspacetemp debes poner el nombre logico del dbspace y no el archivo fisico.
Supongamos que el dbspace se llama tempdbs, deberias tener lo siguiente:

DBSPACETEMP tempdbs # tempdbs # Default temp dbspaces

Ya que esta, te diría que aumentes la cantidad de buffers, actualmente tenes solo 200. Esto depende de la memoria fisica que tengas, pero te diría que lo cambies en principio a 10000.
Tambien cambia al valor 1 la variable LBU_PRESERVE. Esto te permitirá, en el caso que se llenen los logical logs sin que tenga su backup, que el ultimo logical logs no se use y te permita hacer backup de los mismos.
Otra cosa a reveer es el tamaño del fisical log, no se corresponde con el tamaño total de los logical logs. Deberia ser de un 20 a un 25% del tamaño total de los fisical logs.

Muchisimas gracias por la pronta respuesta modifico los parametros y te digo como me andubo.

Pablo:

En el log también figura un error que pasa desapercibido porque es como que el motor no le da bolilla.

Por allí dice que se modificó el tamaño del rootdbs de 30720 a 1000000 en el ONCONFIG lo cual es cierto, pero no le da bolilla porque dice que para modificar el tamaño hay que hacerlo con una reinicialización del motor (que obviamente borrará todos los dbspaces ya generados). En consecuencia el motor deja el rootdbs en 30720, ignorando lo que se puso en el ONCONFIG.

Fijensé que es lo que quieren hacer, y si desean un rootdbs más grande deberán reinicializar el motor después de modificar el ONCONFIG.

En mi opinión personal sería recomendable un rootdbs bastante más grande que los 30720 que creo que son el default.

Saludos

Gustavo