The .sqd file in question was a bit over 8M in size. Is this a
problem for Squish running under dos?
Hello Roy!
28 Jul 04 20:07, Roy J. Tellason wrote to all\:
The .sqd file in question was a bit over 8M in size. Is this a
problem for Squish running under dos?
Nope...I have many that are larger without issue. SQFIX and GOLDED
DOS versions start misbehaving when areas hit 5400 msgs or so here, though, so I cap mine at 5000. If they go over and break, then
SQFIX32 might work...but not always. Even with 5K caps, here's my
top 5:
ALLFIX_F SQD 28,155,429 07-29-04 3:44a
WEATHER SQD 27,625,285 07-29-04 3:43a
U-F1O4Q SQD 20,507,829 07-29-04 4:09a
U-RV6BX SQD 15,777,708 07-29-04 4:09a
U-RVG8O SQD 15,584,469 07-29-04 3:39a
If you don't already have SQPACK in a regular maintenance routine
(daily here), it is probably a good idea to run it both before and
after your manual cleanup activity, to insure the integrity of the
area. There were probably some pointers that were confused before
you started (in the .sqi), which got really confused by the time
you were done.
- 672 - Old=1131352; New=1131352
This is after I'd trimmed out a bunch of stuff...
5400 messages?
There were something over 8000 of them in there, I
forget how many now.
And yes, this is the dos version.
Hello Roy!
31 Jul 04 12:13, Roy J. Tellason wrote to Mike Tripp:
- 672 - Old=1131352; New=1131352
This is after I'd trimmed out a bunch of stuff...
The file should've gotten smaller the first run after you deleted messages.
Even without parameters, SQPACK should purge the "slack space"
occupied by the deleted messages. Even if you trim to a specific quantity of messages, the 5K you have today may be fewer bytes
than the 5K you had yesterday. If that's not the case, then
you'll see the same bytes reported for Old/New as above.
5400 messages?
That seems to be where GoldEd/DOS starts complaining...GoldEd/2 is
still fine beyond there...and your editor may have no trouble.
I forget the magic number where SQFIX starts suggesting that you
use SQFIX32 instead...but I use the lowest common denominator,
which for me happens to be the editor's limit.
There were something over 8000 of them in there, I
forget how many now.
672 according to the line above...and now you have a 1mb file
instead of the 8mb you originally asked about.
And yes, this is the dos version.
And you will have different luck between the 16- and 32-bit DOS
versions of SQFIX, but my experience is that is the message
quantity (.SQI index entries) and not the filesize of the .SQD that
makes or breaks you. It's not that rare that there is some index
cleanup even on areas with low caps and small .SQDs, and both SQFIX
and SQPACK have to manage these while doing their thing.
I'm seeing the same numbers in both cases there because I have no
settings in the area.
Right. But to get to that point I had to *move* the remaining
messages I wanted to keep from one area to another.
All with today's date, and a timestamp within the past hour when I
was reading it last. What's that sqi file used for anyhow?
Hello Roy!
01 Aug 04 04:07, Roy J. Tellason wrote to Mike Tripp:
I'm seeing the same numbers in both cases there because I have no
settings in the area.
Lack of settings alone won't keep the numbers static. If you
manually kill one message and SQPACK again, Old should be larger
than New. If you manually edit one existing message to remove a few
lines from the message, Old should be larger than New.
Right. But to get to that point I had to *move* the remaining
messages I wanted to keep from one area to another.
Gotcha...and obviously the stats you're posting are for the new
version of the area and not the original hosed version.
It is the hosed version that should've been shrinking as messages
were moved out of it.
The new version was only growing to swallow the new messages being appended, so there's no reason for them to be occupying more than
the actual number of bytes required to do so.
All with today's date, and a timestamp within the past hour when I
was reading it last. What's that sqi file used for anyhow?
Those that've been into the source up to their elbows can probably
find plenty of holes with my analogy, but if you understand the
basics of how DOS manages files and space allocated on a FAT hard
drive: the .SQI is the FAT table for the files (messages) within
Squish's hard drive (.SQD).
The .SQI basically has the pointers to where the header for each
message starts and how many blocks it occupies. If you delete a
message, Squish just updates the .SQI file that references the
deleted data to remove the pointer to its header and updates it's
usage map to show that space as available for writing new data
again. The size of the .SQD is not necessarily representative of
the actual number of bytes required by the currently retained
messages. Squish will expand the .SQD if more space is needed to accomodate a new retention peak, but it will not shrink it just
because fewer are required today than yesterday.
Just as bad things can happen to a FAT if operations fail or are interrupted by a system lockup or power failure, the same is true
for Squish and .SQI/.SQD manipulations. SQFIX does for the
Squishbase what CHKDSK and/or Disk Doctor does for the integrity of
the FAT. It looks to make sure that a message header actually
starts where each .SQI entry says it does and looks for space that
the .SQI says should be in use by a retained message but actually
isn't (akin to lost clusters and cross-linked files) and attempts
to either fix or remove .SQI entries that don't seem to match
reality found in the .SQD.
SQPACK is analagous to DEFRAG. If you have specified parameters,
it first marks the messages that fail those parameters as deleted
and then "compresses" the .SQD data to the beginning of the .SQD
file and shrinks the .SQD file down to the actual size required to
store the actual bytes associated with those messages that are
still retained, rather than the size being some former worst-case
maximum that was required to store messages that met the SQSET
parameters at some point in the past since you last SQPACKed.
So if you use no purge parameters, never manually delete/edit a
message in an area, and never have any problem that causes the .SQI
to lose synch with the actual contents of the .SQD, it will appear
that SQPACK never does anything...just as running DEFRAG wouldn't accomplish anything for your hard drive if you only appended new
files one at a time and never deleted or modified an existing file
since your last DEFRAG. If, however, you make any of those changes
or SQFIX frees a pointer to an existing message because of a data integrity issue, it is possible/probable that there will be some
delta between the old/new bytes when you SQPACK next, even if you
haven't assigned specific purge criteria to the area.
The new version was only growing to swallow the new messages
being appended, so there's no reason for them to be occupying
more than the actual number of bytes required to do so.
Yup. And the way things looked it wasn't ever gonna get any smaller.
I'm looking at something like 38M currently on that drive, not so
much that I need to worry about an 8M file eating too much space but still...
Makes sense. This also explains some why TimED's undelete
function seems to grab *all* deleted messages, I guess that was
just simpler to code, or something.
There are only a few areas like that here, most are set for
specified
time frames, typically 60 days.
Hello Roy!
02 Aug 04 04:07, Roy J. Tellason wrote to Mike Tripp:
The new version was only growing to swallow the new messages
being appended, so there's no reason for them to be occupying
more than the actual number of bytes required to do so.
Yup. And the way things looked it wasn't ever gonna get any smaller.
I'm looking at something like 38M currently on that drive, not so
much that I need to worry about an 8M file eating too much space but still...
I was referring to your new replacement files here, not the
original hosed version. If you don't assign it any purge
paramaters either, then there's no reason for SQPACK to ever shrink
the file, and it should head straight back for 8mb or however far
it grows until it a data integrity issue stops one utility or
another from being able to interact with it correctly any more.
If you want to keep areas uncapped, it might help to do a monthly
SQREIDX or SQFIX event to catch little issues before they become
big/fatal issues.
Makes sense. This also explains some why TimED's undelete
function seems to grab *all* deleted messages, I guess that was
just simpler to code, or something.
Yep...and probably has the same pitfoils as UNDELETE in DOS.
"Deleted" data is overwritten by new data arriving...so some
deleted msgs are unrecoverable. TimEd is probably just grabbing all
of the puzzle pieces it can find to start with, figuring out which
fit together, and then throwing away the few leftovers that don't
seem to fit anywhere when done.
There are only a few areas like that here, most are set for
specified time frames, typically 60 days.
SQUISH and SQPACK work together to maintain the quantity limit.
SQPACK alone does the limit by days. SQPACK should =always= show
some shrinkage on each daily run for areas with a days limit,
unless the area is newer than the limit or the area has days
without mail.
Sysop: | digital man |
---|---|
Location: | Riverside County, California |
Users: | 1,024 |
Nodes: | 17 (1 / 16) |
Uptime: | 01:10:28 |
Calls: | 503,341 |
Calls today: | 10 |
Files: | 107,025 |
D/L today: |
28,347 files (1,939M bytes) |
Messages: | 441,532 |
Posted today: | 4 |