| Text 18906, 214 rader
Skriven 2016-12-04 03:57:06 av Ben Ritchey (1:393/68)
Ärende: DDRescue
================
How to Clone a Hard Drive With Bad Sectors Using ddrescue
Sun Feb 08, 2015 2:06 pm
This is a subject that comes up often on the various forums, so I figure I'll 
just create a tutorial about it and when the subject arises we can just point 
people here.
Introduction: When a hard drive is known, or assumed, to have bad sectors the 
first thing that you should ever do before attempting data recovery is get a 
good clone of the good sectors which you can work from. Attempting to scan and 
recover data from such a drive directly without cloning first is very likely 
result in the drive completely failing. In data recovery it is best practice to
always clone first because in many cases there are bad sector area's of 
supposed "healthy" hard drives that can cause them to fail during the process.
The best way to clone is using specialized hardware such as DeepSpar Disk 
Imager, Data Extractor (in PC-3000), Atola, etc. However for the sake of this 
tutorial we'll assume that you don't have access to such hardware and need to 
do this using software only.
Please Note: if you data is critical to your life and/or business it is always 
best to seek out professional data recovery services rather than attempt this 
yourself. Also if your hard drive is clicking, making other strange noise, 
showing wrong capacity, or not appearing in BIOS you should immediately power 
it down and seek professional advise. Neither Data Medics LLC, the owner of 
this forum, not it's author take any responsibility for the results of any DIY 
data recovery attempts.
Why you can't clone in Windows: There are a great number of Windows based data 
recovery and backup programs out there which make claims of being able to clone
hard drives with bad sectors. This may be partly true, as some employ bad 
sector skipping code to jump ahead a large number of sectors when a bad sector 
is hit and attempt to continue. However none are well suited to the task simply
because all Windows based applications rely on the Windows host controller to 
interface with the drive. Currently there is no known workaround for this in 
Windows. The Windows host controller unfortunately does not allow software 
running in Windows to directly control ATA commands issued to the drive (such 
as read timeouts) which are necessary to effectively clone as much data as 
possible from hard drive with bad sectors. Fortunately there is another OS 
capable of running on your computer that does not suffer from these same 
constraints....
Linux: This open source free operating system gives applications far more 
control of the hardware they interface with and is well suited for handling 
this type of issue. Even better most builds of Linux include a copy of a free 
tool with some great features for cloning hard drives with bad sectors...GNU 
ddrescue. Not to be confused with dd or dd_rescue which are similar programs 
but not quite as good for this task.
For the purpose of this tutorial we'll be using a Knoppix Live edition of Linux
due to it's ease of use, however many other builds of Linux can be used as 
well.
Step 1: Setting up a Linux Live CD, DVD, or USB
You can simply download and burn the ISO file of Knoppix to a CD or DVD: 
Available Here
Or for even better performance you can easily set up a Live USB stick using 
this program: LinuxLive USB Creator
After you've installed the program, simply run it, select your USB key, select 
download, and then find Knoppix in the drop down box of available builds. The 
rest is pretty self explanatory.
Step 2: Boot your system into Linux
Usually this is a simple matter of rebooting your system and then either 
adjusting the boot order in BIOS or hitting a function button such as F8 to 
select an alternate boot device. On initial start up Knoppix will need to go 
through some persistent memory configuration. You'll want to take care of this 
as the persistent memory will come in handy later. Generally you should set it 
to as much as possible.
You'll also want to install ddrescue and hwinfo packages if they aren't already
present. Just open a terminal and type the following commands one at a time and
be sure to select 'y' when prompted in the terminal:
sudo apt-get update
sudo apt-get install gddrescue
sudo apt-get install hwinfo
Step 3: Connect the Source and Target Hard Drives
This can be done before boot if you'd like and if it's IDE you'll have to do 
that, however Linux supports hot connecting SATA devices quite well on most 
hardware, so I find it's generally best to connect afterward to avoid 
unnecessary accessing of the device during boot.
Note: it's imperative that you actually direct SATA connect the source drive 
(one your recovering data from) to the computer, and not use a USB adapter! The
target or destination drive can be connected via USB if it's easier, however 
this may slow the process down in some cases.
Also you'll want to determine a location to store the log file (extremely 
important - this is more than just a log). You can use the persistent memory of
the Linux USB if you'd like, or (if using a CD/DVD) you can connect another 
thumb drive to store the log file. In the example below I'll be using the 
persistent memory so I can store the log files on the desktop in Linux.
Step 4: Determining the device paths
The easiest way to do this is to simply open a terminal in Linux and type in 
the following command:
hwinfo --short
This will provide a basic list of all hardware connected to the system. If you 
scroll up just a bit, you'll see a list of the storage devices along with 
serial/model number, and their respective paths (E.G. "/dev/sda1"). At this 
point should double (or even triple) check which physical drive is which based 
on serial number, model number, etc. and then write down their paths on a piece
of paper noting which is your source and destination drives. Be aware that if 
you disconnect and reconnect a drive the path is likely to change. If you 
accidentally clone the wrong direction there is no going back, period!
Step 5: Issuing the ddrescue command in terminal
The basic ddrescue syntax is: ddrescue [triggers] [source drive] [destination 
drive] [log file full path]
Some triggers you'll want to be familiar with for this process:
(all are case sensitive)
-f [Force] This is always necessary to use if you're cloning to an actual drive
and not an image file.
-d [Direct Access] Gives the program direct access to the storage device (not 
always necessary, and may give errors if system doesn't support it)
-R [Reverse Clone] Very handy to clone both directions to and from a large area
of bad sectors
-r [number of retries] Generally shouldn't be used on the initial clone, but 
perhaps on successive passes
-A [Try Again] Marks all failed blocks to unread in the log and attempts again 
(only use after first pass of cloning)
There are also a number of other triggers available on this website, but most 
you won't need for this process.
Why you must use a log file: This file is not just a log of the program's 
activity as you might suspect. Personally I think it should be renamed. It's 
actually a list of sector ranges which have been copied, skipped, marked as 
bad, etc. which the program will use on successive passes to get as much data 
as possible. When cloning a drive with bad sectors this feature must always be 
used.
So then assuming that your source drive is "/dev/sda" and the target drive is 
"/dev/sdb" your first pass attempt to clone the data will look something like 
this:
ddrescue -f /dev/sda /dev/sdb /home/users/knoppix/Desktop/log1.log
(I used the desktop to store the log so I can look at it & manually edit it if 
needed. Note that even the paths are case sensitive)
At this point you should see the program go to work "rescuing" data. You'll 
also notice a speed indicator which let's you know how fast it's cloning data 
onto the target drive. At times, it'll hit an area of bad sectors and slow down
(this is perfectly normal). The program will then automatically jump ahead read
backwards up to the area of bad sectors and then continue reading forward again
(this is all automated if you used a log file). After it has completed reading 
the drive, it will also then automatically go back and "split" the bad sector 
areas in half and attempt reading the sectors in between.
If you want to pause the process press "Ctl + C" and it will stop. You can then
adjust the triggers in the command and re-issue it if you want.
Generally this process will pick up just about as many sectors as you can 
expect to grab, however if you want to run another pass and try to get some 
more data you can then try using the -A trigger to retry all the bad areas.
Occasionally a drive will have one or more areas of severe bad sectors that the
program struggles to get through, or even will cause the drive to become 
completely unresponsive. In such a case you'll want to use the -R (reverse) 
trigger. Then the drive will read backwards up to the same area, hopefully 
getting the majority of the data. If the drive has become unresponsive you may 
need to power cycle the drive (unplug it & plug it back in), recheck it's path 
(likely to change), and then reissue the command using the new drive path, but 
the same log file.
So a reverse clone command using the same above example will look like:
ddrescue -f -R /dev/sda /dev/sdb /home/users/knoppix/Desktop/log1.log
When issuing subsequent commands in Linux terminal the Up Arrow can be used to 
cycle through past commands you've typed so you can quickly adjust the command 
and re-input it.
After you're confident that you've cloned as much data as possible using 
ddrescue, you're now ready to move the target drive over and begin scanning it 
with data recovery software such as R-Studio to begin the file recovery.
Hopefully this helps someone. :D
ÖÄ Keep the faith, ÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ·
³                                                                    ³
³    Ben  aka cMech  Web: http|ftp|binkp|telnet://cmech.dynip.com    ³
³                  Email: fido4cmech(at)lusfiber.net                 ³
³              Home page: http://cmech.dynip.com/homepage/           ³
ÓÄÄÄÄÄÄÄÄÄÄÄ WildCat! Board 24/7  +1-337-984-4794  any BAUD 8,N,1 ÄÄĽ
... It's past time to go when you start asking yourself if it's time to go.
--- GoldED+/W32-MSVC v1.1.5 via Mystic BBS
 * Origin: FIDONet - The Positronium Repository (1:393/68)
 |