디스크 복제에 DD 사용


182

디스크 복제 도구와 관련하여 여러 가지 질문 dd이 있으며 한 번 이상 제안되었습니다. 나는 이미 사용 dd하기 쉽기 때문에 이미 나 자신을 사용 하는 것을 고려해 왔으며 거의 모든 부팅 가능한 Linux 배포판에서 쉽게 사용할 수 있다고 생각했다.

dd디스크 복제 에 사용하는 가장 좋은 방법은 무엇입니까 ? 빠른 Google 검색을 수행했으며 첫 번째 결과는 명백한 시도 실패 였습니다 . 을 사용한 후해야 할 일 dddd있습니까? 즉 읽을 수없는 것이 있습니까?


dd가 어떻게 작동하는지 알고 있습니다. 제 질문은 디스크를 복제 할 때 (링크로 설명 된 것처럼) dd와 관련된 알려진 문제의 방향에 더 가깝습니다. 아마도 이것은 명확하지 않았습니다. 그의 답변에 포함되어 있고 귀하의 답변은 "한 번도 문제가 없었습니다"입니다. 흥미로운 점을 분명히 제시 했으므로 귀하의 답변도 찬성했습니다 (진행 표시가없는 점이 마음에 듭니다).
falstro 2016 년

1
: 당신이 Spolsky 범프 가지고 같은데 joelonsoftware.com/items/2009/05/29.html
카일 크로닌


3
Joel이 서버 오류의 좋은 예로써이 질문에 링크 한 것은 아이러니 한 일이지만, 그에 대한 대답은별로 없었습니다. dd불량 블록을 건너 뛸 수 있는 올바른 옵션 이있는 25 개 중 (주석 제외)에는 한 가지 대답이 없었으며 이는 복구를 위해 디스크를 복제 할 때 필수적입니다. 더 나은 답변을 추가하여 불량 블록이있는 디스크를 복제 할 수 있습니다.dd if=/dev/sda of=/dev/sdb bs=4096 conv=sync,noerror
Sam Watkins

드라이브 구조에 의존하는 파일 시스템에 대해 이야기하고 복원이 동일하지 않은 하드 드라이브에서 수행되면 dd 복원이 "실패"할 수 있다고 생각합니까? dd 복원에서 일부 오류가 발생했으며 이것이 내 경우의 문제라고 생각합니다.
Marco

답변:


160

dd는 가장 확실한 복제 도구이며 다음 명령을 사용하여 100 % 복제본을 생성합니다. 한 번도 문제가 없었습니다.

dd if=/dev/sda of=/dev/sdb bs=32M

모든 바이트를 복제하는 동안 사용중인 드라이브 나 파티션에서이 값을 사용해서는 안됩니다. 특히 데이터베이스와 같은 응용 프로그램은이 문제에 잘 대처할 수 없으므로 데이터가 손상 될 수 있습니다.


12
물론, / dev / sdb가 최소한 / dev / sda만큼 크면 ...
Eddie

22
"bs = 100M conv = notrunc"를 추가하면 내 경험이 훨씬 빠릅니다.
Tim Williscroft

127
'i'와 'o'문자에 매우주의하십시오 ...
bandi

17
아무도이 트릭을 알지 못하는 것 같습니다 ... dd는 비대칭 복사 프로그램입니다. 즉, 먼저 읽고, 쓰고, 다시 읽습니다. dd를 자신에게 파이프하고 다음과 같이 대칭으로 복사를 수행하도록 할 수 있습니다 dd if=/dev/sda | dd of=/dev/sdb. 내 테스트에서 파이프없이 명령을 실행하면 ~ 112kb / s의 처리량이 나왔습니다. 파이프로 ~ 235kb / s를 얻었습니다. 이 방법으로 문제가 발생하지 않았습니다. 행운을 빕니다!
Mistiry

13
@Mistiry, 그것은 대칭이라는 단어의 의미가 아닙니다.
psusi

113

공간을 절약하기 위해 다음과 같이 gzip으로 dd에 의해 생성 된 데이터를 압축 할 수 있습니다.

dd if=/dev/hdb | gzip -c  > /image.img

다음을 사용하여 디스크를 복원 할 수 있습니다.

gunzip -c /image.img.gz | dd of=/dev/hdb

더 많은 공간을 절약하려면 미리 복제하려는 드라이브 / 파티션을 조각 모음 (적절한 경우) 한 다음 나머지 사용되지 않은 공간을 모두 제로화하여 gzip을 쉽게 압축하십시오.

mkdir /mnt/hdb
mount /dev/hdb /mnt/hdb
dd if=/dev/zero of=/mnt/hdb/zero

조금만 기다리면 dd는 결국 "disk full"메시지와 함께 실패합니다.

rm /mnt/hdb/zero
umount /mnt/hdb
dd if=/dev/hdb | gzip -c  > /image.img

또한 kill 명령으로 신호를 보내어 백그라운드에서 dd 프로세스를 실행하여 상태를보고 할 수 있습니다. 예 :

dd if=/dev/hdb of=/image.img &
kill -SIGUSR1 1234

시스템을 확인하십시오-위의 명령은 Linux, OSX 및 BSD dd 명령에 사용되는 신호가 다릅니다 (OSX 사용 SIGINFO- Ctrl+ T를 눌러 상태를보고 할 수 있음 ).


2
BTRFS, NILFS와 같은 "현대"fs와 함께 작동합니까?
Steve Schnepp

DD는 파일 시스템보다 낮은 추상화 수준의 블록 장치에서 작동하므로 그렇습니다. 그래도 실제로 시도하지는 않았습니다. 흠, NILFS는 흥미롭게 보입니다. 나는 그것을 살펴 봐야 할 것입니다.
David Hicks

4
+1 kill -SIGUSR1 %1, OSX dd 명령은 SIGUSR1을 행복하게 받아들입니다 ... 매우 유용합니다. 감사합니다!
stuartc

1
Kill -SIGUSR1 1234내가 찾던 +1
hot2use

2
되어야합니까 : dd if=/dev/hdb | gzip -c > /image.img.gz?
Mike Causer

37

주의 : 라이브 파일 시스템을 사용하면 파일이 손상 될 수 있습니다. 그 이유는 간단하며 진행중인 파일 시스템 활동을 이해하지 못하며 완화하려고 시도하지 않습니다. 쓰기가 부분적으로 진행중인 경우 부분 쓰기를 얻게됩니다. 이것은 일반적으로 사물에는 좋지 않으며 일반적으로 데이터베이스에는 치명적입니다. 또한, 경우가 발생하기 쉬운 오타-망치는 경우 당신에게 매개 변수 비애를. 대부분의 경우 rsync멀티 태스킹 이 등장한 이후에도 똑같이 효과적인 도구 이며 개별 파일에 대한 일관된보기를 제공합니다.

그러나 DD는 마운트되지 않은 드라이브의 비트 상태를 정확하게 캡처해야합니다. 부트 로더, llvm 볼륨, 파티션 UUID 및 레이블 등 대상 비트를 비트 용으로 미러링 할 수있는 드라이브가 있는지 확인하십시오.


7
sync파일 손상 문제에 대한 답이 아니라고 생각합니다 . 작업 sync중 데몬이나 다른 파일 뒤에 더 많은 파일을 쓰면 어떻게됩니까 dd?
삭제됨

5
드라이브를 먼저 마운트 해제하거나 읽기 전용으로 다시 마운트하는 것이 좋습니다. 항상 가능하지는 않습니다.
Alex Bolotov

1
어떤 경우에는 rsync를 사용하고 파일 처리 마법을 사용하여 일관된 파일을 얻고 Copy On Write 시맨틱이 들어오는 쓰기를 처리하게합니다.
jldugger

4
마운트 된 파일 시스템에서 dd를 실행하면 마운트 된 파일 시스템의 파일이 손상되지는 않지만 파일 시스템의 복사본이 반드시 알려진 양호한 상태에 있다는 것을 추가하고 싶습니다.
3molo

1
를 사용 rsync하면 대상 파일 시스템 의 내부 데이터 가 일치합니다. 그것은 하지 않습니다 파일의 데이터가 일치하는지 확인 - 그렇게하려면, 당신은 파일이 잠금을 존중해야하는 파일에 기록하는 프로그램을 잠글 필요가있다.
Martin Geisler

26

dd를 사용하여 불량 섹터를 포함 할 수있는 디스크를 복제 할 때 "conv = noerror, sync"를 사용하여 오류가 발생했을 때 멈추지 않고 누락 된 섹터를 널 바이트로 채 웁니다. 이것은 일반적으로 고장난 디스크에서 복구를 시도 할 때 수행하는 첫 번째 단계입니다. 복구를 시도하기 전에 복사본을 얻은 다음 양호한 (복제 된) 디스크에서 복구를 수행하십시오. 복사 할 수없는 빈 섹터에 대처하기 위해 복구 도구에 남겨 둡니다.

또한 dd의 속도는 bs (블록 크기) 설정에 영향을받을 수 있습니다. 나는 보통 bs = 32768을 시도하지만 자신의 시스템에서 테스트하여 가장 빠른 것이 무엇인지 확인할 수 있습니다. (이는 테이프에 쓰는 경우와 같은 다른 이유로 특정 블록 크기를 사용할 필요가 없다고 가정합니다.)


13
불량 섹터가있는 디스크가있는 경우 실제로 dd 대신 'ddrescue'를 사용해야합니다. 훨씬 효율적이며 더 많은 데이터를 복구 할 가능성이 훨씬 높습니다. (dd_rescue와 혼동하지 마십시오. 좋지 않습니다)
davr

3
불량 블록을 건너 뛰려고하면 큰 블록 크기를 사용하지 않아야합니다. 그렇지 않으면 너무 많이 건너 뜁니다. 4096은 충분히 큽니다.
Sam Watkins '11

17

디스크를 복제하려면 실제로 입력과 출력을 dd로 지정하기 만하면됩니다.

dd if=/dev/hdb of=/image.img

물론, / dev / hdb에서 직접 읽을 수있는 적절한 권한이 있고 (루트로 실행하는 것이 좋습니다) / dev / hdb 가 마운트 되지 않았는지 확인하십시오 (디스크가있는 동안에는 복사하고 싶지 않습니다) 변경 중-읽기 전용으로 장착하는 것도 가능합니다). 완료되면 image.img는 전체 디스크의 바이트 단위 복제본이됩니다.

dd를 사용하여 디스크를 복제하는 데는 몇 가지 단점이 있습니다. 먼저, dd는 빈 디스크 공간까지도 전체 디스크를 복사하며 큰 디스크에서 수행하면 이미지 파일이 매우 커질 수 있습니다. 둘째, dd는 진행 표시를 전혀 제공하지 않으므로 복사 시간이 오래 걸리므로 실망 스러울 수 있습니다. 셋째,이 이미지를 다른 드라이브 (다시 dd를 사용하여)에 복사하면 원래 디스크보다 크거나 커야하지만 대상 디스크에있을 수있는 추가 공간은 사용할 수 없습니다. 파티션 크기를 조정하십시오.

디스크 간 직접 복사를 수행 할 수도 있습니다.

dd if=/dev/hdb of=/dev/hdc

그러나 여전히 여유 공간에 관한 위의 제한 사항이 적용됩니다.

문제 나 문제가있는 한, dd는 대부분 훌륭한 일을합니다. 그러나 얼마 전에 나는 죽게 될 하드 드라이브를 가지고 있었기 때문에 dd를 사용하여 완전히 죽기 전에 어떤 정보를 복사하려고 시도했습니다. 그런 다음 dd가 읽기 오류를 잘 처리하지 못한다는 사실을 알게되었습니다. 디스크에 dd가 읽을 수없는 여러 섹터가있어 dd가 사본을 포기하고 중지시킵니다. 당시 나는 (비록 읽기 오류가 발생에도 불구하고 계속 DD 말할 수있는 방법을 찾을 수 없습니다 나타나는 이 해당 설정을 가지고있는 것처럼)을, 그래서 수동으로 지정 꽤 많은 시간을 보냈다 건너 뛰고을 통해 힙합을 추구 읽을 수없는 섹션.

나는이 문제에 대한 해결책을 연구하는 데 시간을 보냈으며 (작업을 마친 후) ddrescue 라는 프로그램을 찾았습니다 . 사이트에 따르면 dd와 같이 작동하지만 오류가 발생하더라도 계속 읽습니다. 필자는 실제로 프로그램을 사용한 적이 없지만 특히 복사하려는 디스크가 오래된 디스크 인 경우 시스템에 문제가 있어도 불량 섹터가있을 수 있습니다.


7
... dd는 진행 상황을 전혀 보여주지 않습니다 ...- 글쎄요, 사실이 아닙니다-진행 상황을 보여줄 수있는 까다로운 방법이 있습니다-dd 프로세스의 pid ( 'ps -a | grep dd')를 찾아야합니다. 이 프로세스에 USR1 신호를 보냅니다.- 'kill -USR1 <dd_pid_here>'(<> 제외)로 dd가 진행 정보를 표시하도록합니다.
Michal Bernhard

4
"dd에서 읽을 수없는 디스크의 여러 섹터": conv=sync,noerror도움 이 될 것 같습니다 .
Gauthier

2
conv=sync,noerror옵션은 불량 블록을 건너 가지가 제대로 정렬되도록 이미지에 그들을 제로로 dd는 허용, 필수적이다. 그것에 대해 의견을 말한 소수의 사람들에게 제안합니다.
샘 왓킨스

1
GNU ddrescue는 특별한 옵션없이 진행률 표시기를 제공하며 복사를 중지하고 중단 한 부분부터 다시 시작할 수 있습니다.
endolith

2
dd로 진행하는 덜 까다로운 방법은 옵션을 추가하는 것입니다status=progress
James

11

소스 드라이브가 전혀 손상된 경우 (개인 취향) 또는 GNU를 사용 dd_rhelp하면 더 운이 좋습니다.dd_rescueddrescue

그 이유는 읽기 오류시 dd계속 시도하고 노력하며 시간 초과가 발생할 때까지 오랫동안 기다릴 수 있기 때문입니다. dd_rescue오류를 읽은 다음 디스크에서 더 많은 지점을 선택하고 마지막 오류를 다시 읽는 것과 같은 현명한 작업을 수행하며 dd_rhelp기본적으로 dd_rescue세션 관리자 dd_rescue입니다.

최종 결과는 dd_rhelp최소 시간에 최대 데이터 복구입니다. 당신이 dd_rhelp실행 을 떠나면 결국 결국 같은 작업을 수행 dd합니다. 그러나 dd100Gb 디스크의 바이트 100에서 읽기 오류가 발생하면 다른 9,999,900 바이트 *를 복구하기 위해 오랜 시간을 기다려야하는 반면, dd_rhelp+ dd_rescue는 대량의 데이터를 훨씬 빠르게 복구합니다.


1
dd_rescue와 ddrescue 중에서 선택하는 데 도움이됩니다 : askubuntu.com/a/211579/50450
Johann

7

소스 디스크에는 마운트 된 파일 시스템이 없어야합니다. 사용자가 블록 장치를 읽을 수 있으면 (루트 작동) 'dd if = / dev / sda ....'를 실행하십시오.

이제 깔끔한 것 중 하나는 바이트 스트림을 생성한다는 것입니다.이를 사용하여 압축, 네트워크를 통해 전송, 더 작은 얼룩으로 청크 등을 수행 할 수 있습니다.

예를 들어 :

dd if=/dev/sda | ssh user@backupserver "cat > backup.img"

그러나 더 강력하게 :

dd if=/dev/sda | pv -c | gzip | ssh user@backupserver "split -b 2048m -d - backup-`hostname -s`.img.gz"

위의 내용은 소스 하드 드라이브의 압축 이미지를 원격 시스템으로 복사하며, 진행중인 업데이트를 유지하면서 소스 호스트 이름을 사용하여 번호가 지정된 2G 청크로 저장합니다.

디스크 크기, 소스의 CPU 속도, 대상의 CPU 속도, 네트워크 속도 등에 따라 압축을 건너 뛰거나 원격에서 압축을 수행하거나 ssh의 압축을 활성화 할 수 있습니다.


+1 gzip을 통한 배관은 많은 시간과 대역폭을 절약 할 수 있습니다!
M. Dudley

또한 dd 명령에 'bs = 1M'을 추가하면 일반적으로 속도가 크게 향상됩니다.
retracile

6

디스크를 복제하려면 입력과 출력을 dd다음 과 같이 지정하면됩니다 .

dd if=/dev/hdb of=hdb.img

물론, 직접 읽을 수있는 적절한 권한이 있는지 /dev/hdb(루트로 실행하는 것이 좋습니다) /dev/hdb마운트되어 있지 않은지 확인하십시오 (디스크가 변경되는 동안 복사하지 않으려는 경우). 완료되면 hdb.img전체 디스크의 바이트 별 복제본이됩니다.

dd디스크 복제 에 사용하는 데는 몇 가지 단점이 있습니다 . 먼저 dd전체 디스크, 빈 공간을 복사하고 큰 디스크에서 수행하면 이미지 파일이 매우 커질 수 있습니다. 둘째, dd진행 표시가 전혀 없으므로 복사 시간이 오래 걸리므로 실망 할 수 있습니다. 셋째,이 이미지를 다른 드라이브 (다시 dd를 사용하여)에 복사하면 원래 디스크보다 크거나 커야하지만 대상 디스크에있을 수있는 추가 공간은 사용할 수 없습니다. 파티션 크기를 조정하십시오.

디스크 간 직접 복사를 수행 할 수도 있습니다.

dd if=/dev/hdb of=/dev/hdc

그러나 여전히 여유 공간에 관한 위의 제한 사항이 적용됩니다.

첫 번째 단점은 복사 할 때 데이터를 gzipping하여 해결할 수 있습니다. 예를 들면 다음과 같습니다.

dd if=/dev/hdb | gzip -9 > hdb.img.gz

pipeview ( pv) 도구를 사용하여 두 번째 단점을 해결할 수 있습니다 . 예를 들면 다음과 같습니다.

dd if=/dev/hdb | (pv -s `fdisk -l /dev/hdb | grep -o '[0-9]*\{1\} MB' | awk '{print $1}'`m) | cat > hdb.img

세 번째 단점을 극복 할 방법이 없습니다.

또한 dd더 많은 양의 데이터를 처리하도록 지시 하여 복사 시간을 단축 할 수 있습니다 . 예를 들면 다음과 같습니다.

dd if=/dev/hdb of=hdb.img bs=1024

1
세 번째 단점을 극복하는 방법을 이미 말씀하셨습니다. 파티션 크기를 조정하십시오. 파티션을 확대하는 것은 일반적으로 안전하고 빠른 작업입니다 (축소 또는 이동과는 달리 데이터가 이동하기 때문에 느리고 더 위험합니다).
davr

gzipping은 현재 또는 삭제 된 데이터로 채워지기 때문에 한동안 사용 된 디스크에서는 작동하지 않습니다. gzip은 비어있는 공간이 0으로 설정되어있는 경우에만 작동하며, 이는 새 디스크의 경우에만 해당됩니다.
Tozz

3
@Tozz : 파일 시스템을 0으로 채워진 파일로 채우고 디스크에 동기화 한 다음 삭제하여 파일 시스템 이미지의 압축성을 향상시킬 수 있습니다. dd if=/dev/zero bs=1M of=/balloon; sync; rm /balloon (파일 시스템 계층의 모듈로 추가 정보.)
retracile

5

dd 및 rescue 디스크로 할 수있는 또 다른 좋은 점은 네트워크를 통한 데이터 복사입니다.

remote_machine$ nc -l -p 12345

local_machine$ dd if=/dev/sda | nc remote_machine 12345

네트워크가 로컬이 아닌 경우 두 파이프 라인 모두에서 gzip을 사용할 수 있습니다. 진행하려면을 사용하십시오 pv. 복사가 끝난 후 local_machine의 netcat을 종료하려면 추가 -w 5하거나 무언가를 추가하십시오 .


9
이것은 정확하지 않습니다. '여기서 remote_machine'명령과 같은 뭔가 누락 > disk_backup.img하거나 |dd of=/dev/sdb또는 수행하려는 작업에 따라 다른 것을. 디스크 이미지를 stdout에 덤프하고 싶지 않다고 생각합니다.
davr

1
전송 된 데이터를 추가로 최소화하기 위해 양쪽 끝에 gzip을 넣습니다.
3molo

4

dd는 모든 빈 공간을 포함 하여 정확한 사본을 만듭니다 .

그것의 의미는:

  1. 두 번째 드라이브는 최소한 첫 번째 드라이브보다 커야합니다
  2. 두 번째 드라이브가 더 크면 추가 공간이 낭비됩니다 (파일 시스템 확장 할 수 있음)
  3. 소스 드라이브가 가득 차지 않으면 dd는 빈 공간을 복사하는 데 많은 시간을 낭비합니다.
  4. 이 방법으로 전체 드라이브 또는 단일 파티션을 복사 할 수 있습니다.
  5. 이것이 부팅 가능한 드라이브라면 dd를 사용한 후 부트 로더를 설치해야합니다

도움이 되길 바랍니다


8
전체 하드 디스크를 복제하는 경우 부트 로더도 복제합니다.
Cristian Ciupitu

Welll, 단지 thouhgt이지만 gparted를 사용하여 파티션 / 디스크를 사용중인 것으로 복사 할 수 없었습니다. 한 번의 이미지라고 가정하면이 문제를 완화해야합니다.
bbqchickenrobot 2014 년


3

또 다른 중요한 기능은 MBR, 파티션 테이블 및 부팅 레코드를 복사하는 것입니다.

다만

dd if=/dev/sda of=parttable bs=512 count=1

글을 쓸 때 다른 방향으로 fdisk후 와 폴란드어 .

파티션 테이블을 백업하면 훨씬 안전합니다.

또한 (파티션 구조를 변경하는 동안) 다른 하드 드라이브로 마이그레이션하는 것도 즐겁습니다.


3

이것은 저렴한 해킹이지만 DD 프로세스를 모니터링하는 빠르고 더러운 방법입니다.

dd 명령을 실행하십시오. 새 쉘을 열고 ps awx를 수행하여 dd 프로세스의 PID를 찾으십시오. 이제 새로운 쉘 유형 watch -n 10 kill -USR1 {pid of your DD process}

이것은 감시 출력 창에서는 아무 것도하지 않지만 원래 DD 쉘로 돌아 가면 DD는 10 초마다 상태 보고서 출력을 시작합니다. watch 명령에서 -n 10을 다른 시간대로 변경할 수 있습니다.

타키온


OS X은 watch사용할 수 없으며 -USR1dd를 죽입니다. 다음 명령은 작동합니다. while [ true ]; do killall -INFO dd; sleep 30; done
Adam Franco

나는 이것이 초보자에게 매우 실용적이라고 생각하지 않으며, 그들은 pv명령 으로 더 잘 제공 될 수 있습니다 .
로비 Mckennie

dd에서 CTRL-T를 사용하여 SIGINFO를 보낼 수도 있습니다. while 루프보다 쉽고 OSX 10.6 CD에는 killall이 없습니다. en.wikipedia.org/wiki/Unix_signal#Sending_signals
Citizen Kepler

3
dd if=/dev/sda of=/dev/sdb bs=4096 conv=sync,noerror

이것은 디스크를 복사하고 오류가있는 블록을 건너 뜁니다. 이것은 매우 중요합니다.

dd를 사용하여 디스크를 복제하거나 복구하기위한 기본 및 필수 옵션입니다.

다른 답변을 게시하고 싶지 않았지만 이미 게시 된 25 개 중 필수 "conv = sync, noerror"옵션에 대한 올바른 답변은 없습니다.


1
실제로 그것은 하나의 답변 과 적어도 두 개의 의견으로 이전에 언급되었습니다 .
Michael Hampton

1
@Michael 링크 된 답변에는 전체 예제 명령이 포함되어 있지 않으며 다른 결함이 있습니다 conv=sync,noerror. 각 불량 블록에 대해 너무 많은 데이터를 건너 뛰므로 큰 블록 크기를 사용하는 것은 좋지 않습니다 . 이러한 옵션은 "복구 복제"에 필수적이며 주석을 검색 할 필요가 없습니다. 디스크에 불량 블록이없는 경우 (예 : 깨끗한 디스크 복제, 복구에는) 가장 인기있는 답변이 적합합니다.
Sam Watkins

@Michael 내가 준 예제는 전문 디스크 복구에 여러 번 사용한 명령입니다. 약간 더 나은 작업을 수행 할 수있는 다른 도구가 있지만, 내가 제공 한 dd예는 여기의 다른 모든 예 보다 디스크 복구 복제에 더 좋고 오류없는 디스크 복제에도 적합합니다. 그러므로 나는 "디스크 복제에 DD를 사용하는 방법"에 대한 나의 대답이 여기에 가장 좋다고 생각한다. 나는 진행 상황, 압축 등의 모니터링에 대한 정보를 추가하지 않았다. 왜냐하면 간단하게 유지하고 기본 사항을 올바르게 얻는 짧은 대답을 제공하는 데 집중하기 때문이다.
Sam Watkins

3

실제로 이런 식으로 시도해 볼 수 있습니다

dd if = / dev / sda2 of = / dev / sdb2 bs = 4096 conv = sync, noerror

모든 오류를 건너 뛰고 파티션 또는 하드 드라이브를 정확하게 복제


conv = sync, noerror 여야합니다. sync 옵션이 필요합니다. 그렇지 않으면 오류가있는 블록은 0으로 복사되지 않고 제거됩니다.
Sam Watkins '11

2

dd는 진행 정보를 제공합니다-리눅스에서 대부분의 버전. 나는 유닉스 맛을 기억하지 못하는 것을 보았습니다.

매뉴얼 페이지에 : 실행중인 'dd'프로세스로 USR1 신호를 보내면 I / O 통계가 표준 오류로 인쇄 된 다음 복사가 다시 시작됩니다.

이 기능을 정기적으로 사용합니다.


유용하지만 초보자에게는 실용성이 의심됩니다.
로비 Mckennie

2

누군가는 이것을 말해야했습니다 : Clonezilla에게 시도하십시오 (http : // clonezilla.org/)

무엇을 얻습니까? 파일 시스템의 사용 된 부분 만 복사합니다. Clonezilla는 dd, grub, sfdisk, parted, partimage, ntfsclone 및 / 또는 partclone을 사용합니다. 선택한 옵션에 따라

적절한 문서는 http : // clonezilla.org/clonezilla-live/doc/에서 찾을 수 있습니다.


설명서가 약간 거칠다는 것을 알았고 Linux PATA 드라이브를 SATA 드라이브로 복제해도 부팅 할 수있는 것으로 남겨 두지 않았습니다 (아직). 그러나 dd와 동일한 결과에 훨씬 빠르며 랩톱 드라이브 업그레이드에 효과적이었습니다.
jbdavid 09 년

2

진행률을 보여주는 dd를 사용하여 복사하는 방법 (이 경우 원격 시스템에 동일한 원리가 적용됨)

/ tmp / pid에 파일 디스크립터 3을 통해 pid를 저장하여 작동합니다. 그런 다음 USR1 신호로 후속 킬에 사용됩니다. 주름은 stderr의 진행 결과를 서브 쉘을 통한 stderr 필터링을 통해 한 줄로만 필터링하는 것이 었습니다.

(dd bs=1M if=$lv-snapshot & echo $! >&3 ) 3>/tmp/pid  2> >(grep 'copied' 1>&2) | gzip --fast | ssh $DEST "gzip -d | dd bs=1M of=$lv" &
# Need this sleep to give the above time to run
sleep 1
PID=$(</tmp/pid)

while kill -0 $PID; do
  kill -USR1 $PID
  sleep 5
done

질문과는 관련이 없지만 서브 쉘과 높은 (stderr보다 높은) 파일 디스크립터를 사용하여 데이터를 전달하는 깔끔한 쉘 트릭, +1
falstro

디스크를 복제 할 때 그것이 내가 복제에 사용되는 것의 최종 결과를 넣을 때 적당한 장소를 보였다 그래서 나는 그것을 :) 나 자신이 아니라 깔끔한라고 생각, 특히 이후, 다른 DD 옵션이 페이지에 자신을 언급했다
에드워드 Groenendaal를

2

대부분의 정보는 이전에 삽입 된 레시피에서 설명되었지만 모두 설명되지 않았습니다.

리눅스에서는 dd 명령으로 하드 드라이브 나 파티션을 복제 할 수 있습니다. 실수를 할 때 모든 데이터가 손실됩니다.

처음에는 대상을 사용하지 않아야하고, 둘째로 소스를 사용하지 않거나, 읽기 전용 모드로 다시 마운트해야합니다. 그렇지 않으면 복사가 손상됩니다. 다시 마운트 할 수없는 경우 Linux 라이브 배포판으로 부팅 가능한 드라이브 (hdd / ssd / pendrive)를 만드십시오. 나는 knoppix를 prever, 그러나 이것은 당신의 선택입니다. 가능하면 단일 사용자 모드의 경우 시스템 레벨을 1로 부팅하거나 변경하거나 시스템을 단일 사용자 모드로 직접 재부팅 할 수 있습니다. 하나의 파티션 만 복제하는 경우이 파티션을 마운트 해제하거나 RO에 다시 마운트해야합니다.

umount /mountpoint_or_device

또는

remount -o,ro /mountpoint_or_device

전체 하드 드라이브를 복제하려면 모든 파티션을 마운트 해제하거나 다시 마운트해야합니다.

소스 및 대상 장치를 식별해야합니다. dmesg를 참조하십시오. 여기에 공급 업체 등과 함께 장치에 대한 모든 필요한 정보가 저장되어 있습니다. 다른 경우 장치 크기를 기반으로 식별이 가능합니다. 다음으로 목적지는 소스와 같거나 커야합니다. 소스를 계산해야합니다 (예 : 파티션 구조 (GPT가있을 수 있음) 제외). 3. 바이트 단위의 블록 크기, 일반적으로 512입니다.

예를 들면 다음과 같습니다.

# fdisk -l /dev/sda

Disk /dev/sda: 21.5 GB, 21474836480 bytes
255 heads, 63 sectors/track, 2610 cylinders, total 41943040 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x000f1d1e

   Device Boot      Start         End      Blocks   Id  System
/dev/sda1   *        2048    40136703    20067328   83  Linux
/dev/sda2        40138750    41940991      901121    5  Extended
/dev/sda5        40138752    41940991      901120   82  Linux swap /     Solaris

다음으로 512 개 이상의 디바이더를 사용해 봅시다. 41943040 개의 물리 섹터가 있습니다.

41943040 / 256 = 163840, 256 섹터를 대량 복사 할 수 있습니다. 더 할 수 있을까요? 시도해 봅시다 : 41943040 / 1024 = 40960, 이것으로 충분하다고 생각합니다. 이것을 선택하겠습니다. 섹터 그룹의 크기를 계산해 봅시다 : 512 (섹터 크기) * 1024 = 524288 바이트 eq 512K. 그런 다음 bs = 512K 이하의 매개 변수를 사용할 수 있지만이를 2 ^ x로 나눕니다. 내부 캐시가 큰 최신 하드 드라이브의 경우이 정도면 충분합니다. 캐시가 훨씬 작은 구형 드라이브의 경우 32K 이하이면 충분합니다.

그런 다음 준비 후 복사 할 수 있습니다 : dd if = / dev / source_devide of = / dev / destination_device bs = 32K 그리고 복사가 완료됩니다. 실수로 가져 오기 및 데이터를 덮어 쓰게됩니다. 대상에서 모든 내용을 덮어 씁니다.

손상된 소스 디스크에서 데이터를 복구하려고하면 기본 섹터 크기를 사용하는 것이 좋습니다. 일반적으로 512 바이트이며 conv = notrunc 옵션을 추가하십시오. 그렇지 않으면 불량 섹터로 인해 소스에서 떨어진 홀이 대상에서 섹터 이동으로 연결됩니다. 수리 할 기회가 거의 없어 사본이 손상 될 수 있습니다. 명령은 다음과 같습니다.

dd if=/dev/source of=/dev/destination bs=512 conv=notrunc  

드라이브와 시스템이 포기하고 섹터별로 끝까지 걸어 갈 때까지 오래 기다립니다.

dd는 파티션을 새로운 장소로 옮기는 데 유용한 도구입니다. 파티션을 생성하고 dd를 새로운 파티션으로 만들면 (이것은 더 클 수도 있고 더 클 수도 있습니다) 가능하다면 모든 새로운 파티션을 채우기 위해 복사 된 파일 시스템을 확장하십시오 .ext3 / ext4 / xfs / zfs / btrfs는이 기능을 가지고 있습니다. 마지막으로 / etc / fstab을 변경 한 다음 가능하면 umount / mount 또는 시스템을 재부팅해야합니다.

물론 모든 유형의 파티션을 복제 할 수 있습니다. dd 명령은 파일 시스템 유형을 조사하지 않으며 구조와 관련이 없습니다. 이 명령은 NTFS 또는 다른 파티션 유형을 복제하는 데 사용할 수 있습니다.

어떤 트릭이 있습니다. 매개 변수를 설정하지 않으면 dd는 stdout에 출력을 넣습니다. 그런 다음 디스크 또는 파티션의 압축 된 원시 복사본을 만들 수 있습니다.

dd if=/dev/sda bs=512 | gzip >/any/place/computerOne_sda.gz

물론이 작업은 오프라인에서 수행해야합니다. 다음을 통해이를 복원 할 수 있습니다.

zcat /any/place/computerOne_sda.gz| dd of=/dev/sda bs=512   

이 백업으로 모든 sda 하드 드라이브를 덮어 쓰고 모든 현재 데이터가 손실됩니다. NTFS 창 파티션과 여기에서 사용하는 하드 드라이브로도이를 수행 할 수 있습니다. 물론 선택에 따라 다른 압축 명령을 사용할 수 있습니다.


1

bzip2또는 gzip대신 에 파티션 (또는 디스크)의 압축 된 이미지 파일을 즉석에서 만들 수 있습니다 dd. 이동식 미디어에 이미지를 저장하는 데 좋습니다.

bzip2 -c /dev/sdaX >imagefile.bz2
or
gzip -c /dev/sdaX >imagefile.gz

디스크가 이전에 많이 사용 된 경우 이미징 전에 사용하지 않은 모든 공간을 0으로 채워 압축을 향상시킬 수 있습니다.

mkdir /mnt/mymountpoint
mount /dev/sdaX /mnt/mymountpoint
cat /dev/zero >/mnt/mymountpoint/dummyfile.bin
(Wait for it to end with a "disk full" error)
rm /mnt/mymountpoint/dummyfile.bin
umount /mnt/mymountpoint

이미지를 다른 디스크로 복원하려면 다음을 수행하십시오.

bzcat imagefile.bz2 >/dev/sdbY
or
zcat imagefile.gz >/dev/sdbY

남은 공간을 0으로 채우는 속임수로 바뀌 었습니다. 똑똑한!
혼란

이것, 나는 이것을 필요로했다! SD 카드는 이전에 비디오 캡처에 사용되었으며 쓰레기로 가득 차 있었고 압축은 전혀 도움이되지 않았습니다.
코디 스미스

0

어떤 이유로 오디오 트랙으로 CD를 이미징 할 때 dd가 실패합니다. 이미지 + TOC 파일을 얻으려면 cdrdao 또는 이와 유사한 것을 사용해야합니다.


0

속도에 대한 참고 사항 : 내 경험에서 dd는 기본 bs = 512 대신 bs = 1024를 지정하면 두 배 빠릅니다. 더 큰 블록 크기를 사용하면 bs = 1024보다 눈에 띄는 속도 향상이 없습니다.


4
디스크 클러스터는 일반적으로 현재 약 4k이므로 4096을 사용하는 것이 좋은 옵션 일 수 있으며 한 번에 2 개의 클러스터를 읽으려는 경우 8192도 가능합니다. 조각난 메모리 문제가 발생할 때 너무 크게 가지 마십시오
user4767

0

전체 디스크를 기록 할 때주의해야 할 사항은 수신 디스크의 마스터 부트 레코드를 덮어 쓰는 것입니다. 여기에는 파티션 테이블 및 기타 중요한 정보가 포함됩니다. 새 디스크가 이전 디스크와 동일하지 않은 경우 모든 종류의 테이블을 만들 수 있습니다. 파티션 복사는 일반적으로 더 안전합니다 (스왑 파티션은 복사 할 필요가 없습니다)


0

나는 몇 년 동안 관리자 역할을 벗어 났지만 'dd'가 업무에 달려 있음을 알고 있습니다. 필자는이 기술을 80 년대 후반 Sun Sparc 및 386i 컴퓨터에서 정기적으로 사용했습니다. 여러 QIC 테이프에 분산 된 CAD 소프트웨어를 실행하는 30 386i 시스템 이상의 클라이언트를 주문했습니다.

첫 번째 컴퓨터에 앱을 설치하고, 앱을 구성하고, SunOS의 sys-unconfig를 실행하고, 다른 SCSI 주소를 가진 신발 상자에 드라이브를 배치 한 다음 다른 30 개의 드라이브에 'dd'로 진행했습니다.


0

다른 사람들이 위에서 언급했듯이, 마운트 된 파일 시스템을 복제해야하는 문제 중 하나는 잠재적 인 데이터 손상입니다. 이것은 전체 드라이브 복제에는 적용되지 않지만 LVM을 사용하는 경우 LogicalVolume을 스냅 샷하고 스냅 샷에서 dd를 사용하여 일관된 이미지를 얻을 수 있습니다.



0

초보자에게 반드시 경고해야 할 경고 : 적어도 일부 버전의 경우 bs = X는 문자 그대로 X 크기의 메모리가 할당됨을 의미합니다. RAM이 1GB이고 스왑이 충분하지 않은 시스템에서 bs = 2GB는 나쁜 일이 발생할 수 있습니다.

당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.