Thread (2 messages) 2 messages, 2 authors, 2010-07-08

RE: [PATCH 27/33] extension of IncrementalRemove to store location (port) of removed device

From: Hawrylewicz Czarnowski, Przemyslaw <hidden>
Date: 2010-07-08 16:02:32

-----Original Message-----
From: Neil Brown [mailto:neilb@suse.de]
Sent: Tuesday, July 06, 2010 9:33 AM
To: Czarnowska, Anna
Cc: linux-raid@vger.kernel.org; Hawrylewicz Czarnowski, Przemyslaw;
Labun, Marcin; Neubauer, Wojciech; Williams, Dan J; Ciechanowski, Ed;
dledford@redhat.com
Subject: Re: [PATCH 27/33] extension of IncrementalRemove to store
location (port) of removed device

On Mon, 5 Jul 2010 10:40:54 +0100
"Czarnowska, Anna" [off-list ref] wrote:
quoted
From: Przemyslaw Czarnowski
[off-list ref]
quoted


If the disk is taken out from its port this port information is lost.
Only udev rule can provide us with this information, and then we have
to store it somehow. This patch adds writing 'cookie' file in
/var/run/mdadm directory in form of file named with value of <path-id>,
containing the names of arrays holding this device before it was
removed.
quoted
FAILED_SLOTS constant has been added to hold the location of cookie
files.
quoted


Signed-off-by: Przemyslaw Czarnowski
<przemyslaw.hawrylewicz.czarnowski@intel.com<mailto:przemyslaw.hawrylew
icz.czarnowski@intel.com>>
quoted
---

 Incremental.c |   63
++++++++++++++++++++++++++++++++++++++++++++++++++++----
quoted
 Makefile      |    6 +++-

 mdadm.h       |    8 +++++++

 3 files changed, 70 insertions(+), 7 deletions(-)


diff --git a/Incremental.c b/Incremental.c index 20e3445..adaefb9
100644
quoted
--- a/Incremental.c
2> >
quoted
+++ b/Incremental.c
@@ -937,19 +937,22 @@ int Incremental_container(struct supertype *st,
char *devname, int verbose,
quoted
  * raid arrays, and if so first fail (if needed) and then remove the
device.
quoted
  *

  * @devname - The device we want to remove

+ * @id_path - name as found in /dev/disk/by-path for this device

  *

  * Note: the device name must be a kernel name like "sda", so

  * that we can find it in /proc/mdstat

  */

-int IncrementalRemove(char *devname, char *path, int verbose)

+int IncrementalRemove(char *devname, char *id_path, int verbose)

 {

      int mdfd;

      int rv;

-     struct mdstat_ent *ent;

+     struct mdstat_ent *ent, *mds, *mi;

      struct mddev_dev_s devlist;

+     char path[PATH_MAX];

+     FILE *id_fd;



-     if (!path) {

-           fprintf(stderr, Name ": incremental removal without --
path <path_id> lacks "
quoted
+     if (!id_path) {

+           fprintf(stderr, Name ": incremental removal without --
path <id_path> lacks "
quoted
                  "the possibility to re-add new device in this
port\n");
quoted
            return 1;

      }
@@ -965,15 +968,65 @@ int IncrementalRemove(char *devname, char
*path, int verbose)
quoted
                  "of any array\n", devname);

            return 1;

      }

+     strncpy(path, FAILED_SLOTS, PATH_MAX);

+     if (mkdir(path, O_CREAT) < 0 && errno != EEXIST) {
It is incorrect to path O_CREAT to mkdir.
It should be permission bits such as '0700' or S_IRWXU.

Also, the strncpy is pointless, just use
    mkdir(FAILED_SLOTS, 0700)
Sure, good point
quoted
+           fprintf(stderr, Name ": can't create file to save path to
old disk\n");
quoted
+           return 1;

+     }

+     snprintf(path, PATH_MAX, FAILED_SLOTS "/%s", id_path);

+

+     if ((id_fd = fopen(path, "w")) == NULL) {

+           fprintf(stderr, Name ": can't create file to save path to
old disk\n");
quoted
+           return 1;

+     }
Again, I don't think it is reasonably to failed the "-If" just because
you
cannot record the removal.

quoted
-     Manage_subdevs(ent->dev, mdfd, &devlist, verbose);

+

+     /* slightly different behavior for native and external */

+     if (!is_external(ent->metadata_version)) {

+           /* just write array device */

+           if (fprintf(id_fd, "%s\n", ent->dev) < 0) {

+                 fprintf(stderr, Name ": Failed to write to
<id_path> cookie\n");
quoted
+                 fclose(id_fd);

+                 unlink(path);

+           }
Do we really want to record the array as "md0" or "md127" ??

I would have thought we would record the uuid, probably together with
the
metadata type to ensure no ambiguity if some time passes before
plugging a
new device in.
We may even want to let the metadata handler provide a string to save
and
later restore.
The requirements for this feature are not clear enough right now. We thought
of deleting cookies during de-assemblation or assemblation. Other alternative
we planned was to store UUID of array, as cookie timeout is not limited right 
now, and device name is obviously inappropriate. But this code above shows
the general idea.
Or on the other hand, do we need to record anything other than "this
device
was using in an md array" which tells is that it is appropriate for md
to
grab any device that is plugged in.
Once a device has been taken for use by md, it should surely be put to
the
best use based on what the various policies allow, should it not?
i.e. exactly the same slot in the same array is not necessary is it?
(and if it is, then we would need to record the slot number, and I
don't
think you do).
Our point was to put new drive into the same container as previous disk, and
let mdmon make use of it.
quoted
+#ifndef FAILED_SLOTS

+#define FAILED_SLOTS "/var/run/failed-slots"

+#endif /* FAILED_SLOTS */
This should be in /var/run/mdadm/ somewhere.
e.g. /var/run/mdadm/failed-slots.
Yes, you're right
NeilBrown
By the way, some rework of the hot-insert was needed, as in early udev rules /dev/disk/by-path links are not available.
The patches are ready, so if you want to take a look, I'm OK to send them. Otherwise we'll prepare new series of all patches with code reworked after your comments. I know, that new policy framework is getting ready, but we hope that parts of our work will comply with new design...

-- 
Przemyslaw Hawrylewicz-Czarnowski
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help