L'aggiunta di un buffer di grandi dimensioni accelererà le cose in modo significativo . La dimensione predefinita è piccola; come 512 byte. Aumentare le dimensioni usando l'opzione bs. Sto solo usando sudo perché l'hai fatto.
sudo dd if=/dev/disk bs=4096m | sudo dd of=/Volumes/Path/To.iso bs=4096m
Questo comando dall'aspetto spaventoso chiederà ai comandi dd di riportare il loro stato. Il -s dice di segnalare.
sudo kill -s siginfo $(pgrep ^dd) # get dd info
Ho provato con varie dimensioni del buffer, più grande è il buffer più veloce sarà la copia. Non voglio ottenere un buffer così grande come il buffer deve essere impaginato.
Se ho sbagliato la sintassi sopra, questi sono i comandi effettivi che hanno funzionato per me. Presumo che tu sappia che è necessario smontare la partizione / unità prima di usare dd. Per alcuni comandi dd, avevo bisogno di usare sudo.
dd if=/dev/disk0s10 bs=4096m | gzip | dd of=~/disk0-s10 bs=4096m
dd if=~/disk0-s10 bs=4096m | gunzip | dd of=/dev/disk0s10 bs=4096m
sudo kill -s siginfo $(pgrep ^dd) # get dd info
Modifica: Gen 18,2019 Ho fatto i tempi usando uno o due comandi dd. Era una scossa di quale forma era più veloce. Il tempo nel mio test variava in genere di 0,3 di secondo tra i comandi. Tuttavia, in un caso i due comandi dd sono stati più lenti di oltre un secondo. La differenza sembrava essere il comando che veniva eseguito per primo. Il secondo test è stato sempre più veloce. Suppongo che l'unico comando dd costruisca un secondo processo per emettere i dati e comunichi al secondo processo tramite una pipe. Questo è più o meno come usare due comandi dd.
dd if=InstallESD.dmg bs=801920k of="/Volumes/--Mojave--/mojave2.dmg"
5+1 records in
5+1 records out
4719681368 bytes transferred in 28.887363 secs (163382216 bytes/sec)
Show_Time
date +%s
Elapsed time in seconds since start of processing: 84 Time of this step: 29
dd if=InstallESD.dmg bs=801920k | dd of="/Volumes/--Mojave--/mojave.dmg" bs=801920k
5+1 records in
5+1 records out
4719681368 bytes transferred in 27.383548 secs (172354633 bytes/sec)
0+72017 records in
0+72017 records out
4719681368 bytes transferred in 27.459524 secs (171877757 bytes/sec)
Show_Time
date +%s
Elapsed time in seconds since start of processing: 112 Time of this step: 28
rm "/Volumes/--Mojave--/mojave.dmg"
rm "/Volumes/--Mojave--/mojave2.dmg"
Show_Time
date +%s
Elapsed time in seconds since start of processing: 112 Time of this step: 0
dd if=InstallESD.dmg bs=801920k of="/Volumes/--Mojave--/mojave2.dmg"
5+1 records in
5+1 records out
4719681368 bytes transferred in 26.754509 secs (176406950 bytes/sec)
Show_Time
date +%s
Elapsed time in seconds since start of processing: 139 Time of this step: 27
dd if=InstallESD.dmg bs=801920k | dd of="/Volumes/--Mojave--/mojave.dmg" bs=801920k
5+1 records in
5+1 records out
4719681368 bytes transferred in 26.210222 secs (180070255 bytes/sec)
0+72017 records in
0+72017 records out
4719681368 bytes transferred in 26.286946 secs (179544682 bytes/sec)
Show_Time
date +%s
Elapsed time in seconds since start of processing: 165 Time of this step: 26
... le linee all'inizio erano tagliate. ...
Ecco lo script di bash che ho usato.
#!/bin/bash -v
function Show_Time () {
let currentRunTime="$( date +%s ) - ${Seconds_since_the_epoch_start}"
let stepRunTime=currentRunTime-previousRunTime
echo " Elapsed time in seconds since start of processing: ${currentRunTime}" \
" Time of this step: ${stepRunTime}"
echo
let previousRunTime=currentRunTime
}
savedCommandName="$0"
echo
echo "${savedCommandName} script last revised on $(GetFileInfo -m $0)"
#echo "${savedCommandName} script revised."
echo
# input file name "/Applications/InstallmacOSHighSierra.app/Contents/SharedSupport/InstallESD.dmg"
inputDir="/Applications/InstallmacOSHighSierra.app/Contents/SharedSupport"
cd ${inputDir}
inputName="InstallESD.dmg"
echo "inputDir is ${inputDir}"
echo "inputName is ${inputName}"
ls -l "${inputDir}/${inputName}"
ls -l "/Volumes/--Mojave--/mojave.dmg"
rm "/Volumes/--Mojave--/mojave.dmg"
ls -l "/Volumes/--Mojave--/mojave.dmg"
ls -l "/Volumes/--Mojave--/mojave2.dmg"
rm "/Volumes/--Mojave--/mojave2.dmg"
ls -l "/Volumes/--Mojave--/mojave2.dmg"
# Set the start time now that the user interaction is done
Seconds_since_the_epoch_start=$( date +%s )
# 80meg buffer
Show_Time
dd if=InstallESD.dmg bs=801920k of="/Volumes/--Mojave--/mojave2.dmg"
Show_Time
dd if=InstallESD.dmg bs=801920k | dd of="/Volumes/--Mojave--/mojave.dmg" bs=801920k
Show_Time
rm "/Volumes/--Mojave--/mojave.dmg"
rm "/Volumes/--Mojave--/mojave2.dmg"
Show_Time
dd if=InstallESD.dmg bs=801920k of="/Volumes/--Mojave--/mojave2.dmg"
Show_Time
dd if=InstallESD.dmg bs=801920k | dd of="/Volumes/--Mojave--/mojave.dmg" bs=801920k
Show_Time
rm "/Volumes/--Mojave--/mojave.dmg"
rm "/Volumes/--Mojave--/mojave2.dmg"
Show_Time
dd if=InstallESD.dmg bs=801920k of="/Volumes/--Mojave--/mojave2.dmg"
Show_Time
dd if=InstallESD.dmg bs=801920k | dd of="/Volumes/--Mojave--/mojave.dmg" bs=801920k
Show_Time