On Wed, May 11, 2011 at 1:47 PM, Mark Nigh <mnigh@xxxxxxxxxxxxxxx> wrote: > Some additional testing shows that the underlying filesystem btrfs does fail thus the daemon appropriately fails. > > The way I am simulating a failed HDD is by removing the HDD. The failure is working, > but the problem is when I reinsert the HDD. I think I see the BTRFS filesystem > recovery (btrfs filesystem show) and I can start the correct osd daemon that corresponds > to the mount point but I do not see the osd come up and in (ceph -s). I am assuming that you are using serial ATA (SATA), because that is what comes standard on most PCs these days. The last time I used SATA hotplug, which was in 2009, the driver support was still pretty flaky at the chipset level. Things may have improved since then, but I suspect that SATA hotplug is still an uncommon and poorly tested operation. If you really want to get hotplug working, start with the basics-- just see whether it works at the driver and block device level. Then get btrfs involved, and finally if all that works, try Ceph. However, it might be simpler just to simulate failures by randomly killing cosd processes. When cosd hangs on a sync for too long, it will deliver a SIGABRT to itself anyway. So the only part of the proecss you would be bypassing is the hang. You're putting your SATA driver and btrfs's error handling paths through a workout, but not really testing Ceph per se. Colin > > ceph version 0.27.commit: 793034c62c8e9ffab4af675ca97135fd1b193c9c. process: cosd. pid: 2702 > 2011-05-11 15:13:58.650515 7fc6a349d760 filestore(/mnt/osd2) mount FIEMAP ioctl is NOT supported > 2011-05-11 15:13:58.650754 7fc6a349d760 filestore(/mnt/osd2) mount detected btrfs > 2011-05-11 15:13:58.650768 7fc6a349d760 filestore(/mnt/osd2) mount btrfs CLONE_RANGE ioctl is supported > > If I try to restart the osd daemon, it is unable to kill the process and repeats trying to kill it. > > Is the underlying file system not recovery like I think? I guess removing and inserting the HDD isn't the correct way to simulate a dead HDD.? Show I following the process of removing the osd, initializing the osd data dir and then restart the osd daemon? > > Thanks. > > Mark Nigh > Systems Architect > Netelligent Corporation > mnigh@xxxxxxxxxxxxxxx > > > > -----Original Message----- > From: Mark Nigh > Sent: Wednesday, May 11, 2011 8:12 AM > To: 'ceph-devel@xxxxxxxxxxxxxxx' > Subject: OSD Crash > > I was performing a few failure test with the osd by removing a HDD from one of the osd host. All was well, the cluster noticed the failure and re-balanced data but when I replace the HDD into the host, the cosd crashed. > > Here is my setup. 6 osd host with 4 HDDs each (4 cosd daemons running for each host). 1 mon and 2 mds (separate host). > > Here is the log from the osd0 > > 2011-05-10 16:25:02.776151 7f9e16d36700 -- 10.6.1.92:6800/15566 >> 10.6.1.63:0/2322371038 pipe(0x4315a00 sd=14 pgs=0 cs=0 l=0).accept peer addr is really 10.6.1.63:0/2322371038 (socket is 10.6.1.63:42299/0) > os/FileStore.cc: In function 'unsigned int FileStore::_do_transaction(ObjectStore::Transaction&)', in thread '0x7f9e22577700' > os/FileStore.cc: 2120: FAILED assert(0 == "EIO handling not implemented") > ceph version 0.27 (commit:793034c62c8e9ffab4af675ca97135fd1b193c9c) > 1: (FileStore::_do_transaction(ObjectStore::Transaction&)+0x194) [0x5a0c84] > 2: (FileStore::do_transactions(std::list<ObjectStore::Transaction*, std::allocator<ObjectStore::Transaction*> >&, unsigned long)+0x156) [0x5a3536] > 3: (FileStore::_do_op(FileStore::OpSequencer*)+0x13e) [0x598ebe] > 4: (ThreadPool::worker()+0x2a2) [0x626fa2] > 5: (ThreadPool::WorkThread::entry()+0xd) [0x529f1d] > 6: (()+0x6d8c) [0x7f9e29434d8c] > 7: (clone()+0x6d) [0x7f9e2808204d] > ceph version 0.27 (commit:793034c62c8e9ffab4af675ca97135fd1b193c9c) > 1: (FileStore::_do_transaction(ObjectStore::Transaction&)+0x194) [0x5a0c84] > 2: (FileStore::do_transactions(std::list<ObjectStore::Transaction*, std::allocator<ObjectStore::Transaction*> >&, unsigned long)+0x156) [0x5a3536] > 3: (FileStore::_do_op(FileStore::OpSequencer*)+0x13e) [0x598ebe] > 4: (ThreadPool::worker()+0x2a2) [0x626fa2] > 5: (ThreadPool::WorkThread::entry()+0xd) [0x529f1d] > 6: (()+0x6d8c) [0x7f9e29434d8c] > 7: (clone()+0x6d) [0x7f9e2808204d] > os/FileStore.cc: In function 'unsigned int FileStore::_do_transaction(ObjectStore::Transaction&)', in thread '0x7f9e21d76700' > os/FileStore.cc: 2120: FAILED assert(0 == "EIO handling not implemented") > ceph version 0.27 (commit:793034c62c8e9ffab4af675ca97135fd1b193c9c) > 1: (FileStore::_do_transaction(ObjectStore::Transaction&)+0x194) [0x5a0c84] > 2: (FileStore::do_transactions(std::list<ObjectStore::Transaction*, std::allocator<ObjectStore::Transaction*> >&, unsigned long)+0x156) [0x5a3536] > 3: (FileStore::_do_op(FileStore::OpSequencer*)+0x13e) [0x598ebe] > 4: (ThreadPool::worker()+0x2a2) [0x626fa2] > 5: (ThreadPool::WorkThread::entry()+0xd) [0x529f1d] > 6: (()+0x6d8c) [0x7f9e29434d8c] > 7: (clone()+0x6d) [0x7f9e2808204d] > ceph version 0.27 (commit:793034c62c8e9ffab4af675ca97135fd1b193c9c) > 1: (FileStore::_do_transaction(ObjectStore::Transaction&)+0x194) [0x5a0c84] > 2: (FileStore::do_transactions(std::list<ObjectStore::Transaction*, std::allocator<ObjectStore::Transaction*> >&, unsigned long)+0x156) [0x5a3536] > 3: (FileStore::_do_op(FileStore::OpSequencer*)+0x13e) [0x598ebe] > 4: (ThreadPool::worker()+0x2a2) [0x626fa2] > 5: (ThreadPool::WorkThread::entry()+0xd) [0x529f1d] > 6: (()+0x6d8c) [0x7f9e29434d8c] > 7: (clone()+0x6d) [0x7f9e2808204d] > *** Caught signal (Aborted) ** > in thread 0x7f9e22577700 > ceph version 0.27.commit: 793034c62c8e9ffab4af675ca97135fd1b193c9c. process: cosd. pid: 1414 > 2011-05-10 22:01:13.762083 7f0620492760 filestore(/mnt/osd0) mount FIEMAP ioctl is NOT supported > 2011-05-10 22:01:13.762276 7f0620492760 filestore(/mnt/osd0) mount detected btrfs > 2011-05-10 22:01:13.762288 7f0620492760 filestore(/mnt/osd0) mount btrfs CLONE_RANGE ioctl is supported > *** Caught signal (Terminated) ** > in thread 0x7f061e7b4700. Shutting down. > > As you can see with the attached log, I try to restart the cosd at 22:01. The service is started but ceph -s doesn't include the osd. > > Thanks for your help. > > Mark Nigh > Systems Architect > Netelligent Corporation > mnigh@xxxxxxxxxxxxxxx > > > > This transmission and any attached files are privileged, confidential or otherwise the exclusive property of the intended recipient or Netelligent Corporation. If you are not the intended recipient, any disclosure, copying, distribution or use of any of the information contained in or attached to this transmission is strictly prohibited. If you have received this transmission in error, please contact us immediately by responding to this message or by telephone (314-392-6900) and promptly destroy the original transmission and its attachments. > -- > To unsubscribe from this list: send the line "unsubscribe ceph-devel" in > the body of a message to majordomo@xxxxxxxxxxxxxxx > More majordomo info at http://vger.kernel.org/majordomo-info.html > -- To unsubscribe from this list: send the line "unsubscribe ceph-devel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html