how does ext3 handle no communication to storage
Sev Binello
sev at bnl.gov
Wed Aug 30 15:21:28 UTC 2006
Theodore Tso wrote:
> On Tue, Aug 29, 2006 at 11:09:35AM -0400, Sev Binello wrote:
>
>>From a strictly practical and immediate stand point,
>>what is the best way to handle this situation if it should occur again in
>>the near future ?
>
>
> Without any kernel patches, the best thing to do is, (a) don't restore
> the path to the device, (b) unmount the filesystem, (c) Compile the
> enclosed flushb program (also found in the e2fsprogs sources, but not
> compiled by most or all distributions), and run it: "flushb
> /dev/hdXX", and only after completing all of these steps, you can
> restore the path and do fsck of the filesystem if you are feeling
> sufficiently paranoid, and then remount it.
>
> I wish I could offer you something better, but that's what we have at
> the moment.
>
> - Ted
>
> /*
> * flushb.c --- This routine flushes the disk buffers for a disk
> *
> * Copyright 1997, 2000, by Theodore Ts'o.
> *
> * WARNING: use of flushb on some older 2.2 kernels on a heavily loaded
> * system will corrupt filesystems. This program is not really useful
> * beyond for benchmarking scripts.
> *
> * %Begin-Header%
> * This file may be redistributed under the terms of the GNU Public
> * License.
> * %End-Header%
> */
>
> #include <stdio.h>
> #include <string.h>
> #include <unistd.h>
> #include <stdlib.h>
> #include <fcntl.h>
> #include <sys/ioctl.h>
> #include <sys/mount.h>
>
> /* For Linux, define BLKFLSBUF if necessary */
> #if (!defined(BLKFLSBUF) && defined(__linux__))
> #define BLKFLSBUF _IO(0x12,97) /* flush buffer cache */
> #endif
>
> const char *progname;
>
> static void usage(void)
> {
> fprintf(stderr, "Usage: %s disk\n", progname);
> exit(1);
> }
>
> int main(int argc, char **argv)
> {
> int fd;
>
> progname = argv[0];
> if (argc != 2)
> usage();
>
> fd = open(argv[1], O_RDONLY, 0);
> if (fd < 0) {
> perror("open");
> exit(1);
> }
> /*
> * Note: to reread the partition table, use the ioctl
> * BLKRRPART instead of BLKFSLBUF.
> */
> if (ioctl(fd, BLKFLSBUF, 0) < 0) {
> perror("ioctl BLKFLSBUF");
> exit(1);
> }
> return 0;
> }
Thanks Ted.
What's the best way to keep informed as to when the patch
to the kernel is made and released ?
-Sev
--
Sev Binello
Brookhaven National Laboratory
Upton, New York
631-344-5647
sev at bnl.gov
More information about the Ext3-users
mailing list