ITEM: F5728L
Problem copying sparse files to a new filesystem
Question:
I have a system where I am trying to copy a filesystem from one volume
group to another volume group. I am using the "cp" command to
accomplish this. The source filesystem is called "/uo2" and is 800meg
in size. The actual amount used from the "df" command is 600meg. I am
trying to copy this to another filesystem that is 655 MB in size. The
copy only gets about 2/3 of the way and stops with the filesystem
becoming full. What gives?
Response:
The customer has Oracle database files in his system. It turns out
that the database files were created as sparse datafile. This means
that though they might have been allocated by Oracle at 100meg, since
Oracle uses null bytes to allocate it, the null blocks are NOT
actually allocated physical space. The problem the customer is
experiencing is related to problem C6019. Apparently, "cp" is
expanding these files when they hit the destination filesystem and
causing the filesystem to fill up before completion of the copy.
Response:
To understand this problem I wrote the following c program:
\# mknullfile.c - create a file full of null characters
\#include \
\#include \
\#define FILE_NAME "null.file"
main()
{ int i;
FILE *out_file;
out_file=fopen(FILE_NAME,"w");
if (out_file == NULL ) {
(void) fprintf (stderr,"can not open output file\\n");
}
for (i=1;i\<=102400;i++) {
fputc('\\0',out_file);
}
(void) fclose(out_file);
}
This creates a file full of nulls that is 102400 bytes called null.file.
\# fileplace -v null.file
File: null.file Size: 102400 bytes Vol: /dev/hd1 (4096 byte blks)
Inode: 34869 Mode: -rw-r--r-- Owner: dbraden Group: system
Logical blocks
--------------
34949-34956 8 blks, 32 KB, 32.0%
34958-34974 17 blks, 68 KB, 68.0%
25 blocks over space of 26: space efficiency = 96.2%
2 fragments out of 25 possible: sequentiality = 95.8%
\# find . -name null.file -print | backup -ivf/tmp/null.bu
then cd to another directory and
\# restore -xvf/tmp/null.bu
\# fileplace -v null.file
File: null.file Size: 102400 bytes Vol: /dev/hd1 (4096 byte blks)
Inode: 88110 Mode: -rw-r--r-- Owner: dbraden Group: system
Logical blocks
--------------
unallocated 24 blks, 96 KB, 96.0%
88131 1 blk, 4 KB, 4.0%
1 blocks over space of 1: space efficiency = 100.0%
1 fragment out of 1 possible: sequentiality = 100.0%
Thus we have a sparse file. ls -l shows the same size for both files
\# cp null.file null.file2
\# fileplace -v null.file2
File: null.file2 Size: 102400 bytes Vol: /dev/hd1 (4096 byte blks)
Inode: 88154 Mode: -rw-r--r-- Owner: dbraden Group: system
Logical blocks
--------------
88152-88159 8 blks, 32 KB, 32.0%
88161-88177 17 blks, 68 KB, 68.0%
25 blocks over space of 26: space efficiency = 96.2%
2 fragments out of 25 possible: sequentiality = 95.8%
Now the file is not sparse. Thus the customer's problem of running
out of space when he does a copy.
backup & restore will preserve sparseness
tar will not preserve sparseness - it will take more blocks after
extraction
pax will aggressively preserve sparseness - a non sparse fill will
become sparse after being backuped and restored with pax
du incorrectly shows the number of blocks for a sparse file. In the
previous example "du -a null.file" will show either 8 or 200 blocks
for these files if they are sparse/not sparse respectively. df also
incorrectly states the amount of space taken by sparse files!!!
With the sparse.file in /home
\# df /home
Filesystem Total KB free %used iused %iused Mounted on
/dev/hd1 794624 120432 84% 18436 9% /home
\# del sparse.file (which is 102400 bytes)
\# df /home
Filesystem Total KB free %used iused %iused Mounted on
/dev/hd1 794624 120440 84% 18435 9% /home
It freed up only 8K!!! This is a potential problem in reducing
filesystems. Use either pax or backup/restore (not tar) when
reducing filesystems.
Customer is on AIX 3.2.3. He would like us to report a defect because
he cannot use cp; however, the man page for du states that "unallocated
blocks are not accounted for in the reported block counts." The df
command states that "Under certain exceptional conditions, these counts
may be in error. For example, if a file system is being actively
modified ... "
I also found a document on sparse files:
/public/support/aix/backup/sparse_files
which also documents the effects of pax and dd on sparse files.
A way to determine which, if any, files are sparse follows:
find . -print | xargs -n1 fileplace /tmp/fileplace.output
Then vi /tmp/fileplace.output and search for "unallocated".
Response:
I called the customer and explained why they reporting a defect would
be to no avail. Now that they understand the problem, they can live
with it though they are somewhat disappointed they have to deal with
it.
HR
CENTER
FONT size=2Support Line: Problem copying sparse files to a new filesystem ITEM: F5728L
BRDated: January 1994 Category: N/A
BRThis HTML file was generated 99/06/24~13:30:51
BRComments or suggestions?
A href="../../../../feedback.html"BContact us/B/ABR
/FONT
/CENTER
/BODY
/HTML