Dd
dd: Команда, котра не схожа на інші
dd (англ. dataset definition — визначення набору даних) — команда Unix, призначена для низькорівневого копіювання і конвертації необроблених (raw) даних. Команда використовується для копіювання визначеної кількості байтів чи блоків, заміни порядку байтів, копіювання областей файлів пристроїв, резервного копіювання завантажувального сектору жорсткого диску, або читання фіксованої кількості даних зі спеціальних файлів /dev/zero чи /dev/random.
Команду dd жартома називають "винищувач диску" ("disk destroyer"), "винищувач даних" ("data destroyer"), чи "стерти дані" ("delete data"), оскільки при виконанні низькорівневих операцій навіть незначна помилка (така, як переплутати параметри if та of) може призвести до втрати деяких або навіть усіх даних на диску.
Синтаксис команди dd:
- $ dd if=$input_data of=$output_data [options]
Вхідними та вихідними даними можуть бути диски, розділи, файли, пристрої ... практично все, з чого можна зчитувати інформацію, і куди її можна записувати. За допомогою dd можна також пересилати дані, наприклад, по локальній мережі. Можна використовувати вхідну частину команди, або тільки вихідну, а в деяких випадках можуть бути відсутні обидві частини. Все це проіллюстіровано в представленій нижче таблиці:
Параметри
- if=файл — читає дані з файлу замість стандартного вводу.
- of=файл — пише дані у файл замість стандартного виводу.
- bs=n — размір блоку.
- ibs=nn и obs=nn — задає, скільки байт потрібно зчитувати або записувати за раз.
- count=n — скільки блоків копіювати.
- seek=n — скільки блоків пропустити від початку в вихідному файлі.
- skip=n — скільки блоків від початку файлу пропустити перед початком копіювання.
- conv=фільтр,фільтр — застосувати фільтри для конвертації.
- ascii — конвертувати в ASCII з EBCDIC…
- ebcdic — …і навпаки.
- block — вирівнювання блоків.
- lcase — перетворювати в нижній регістр.
- ucase — перетворювати у верхній регістр.
- swap — міняти місцями пари байт.
- noerror — ігнорувати помилки вводу-виводу.
Використання
Синтаксис команди | Опис |
Файлові системи | |
dd if=/dev/urandom of=/dev/sda bs=4k | Заповнює пристрій випадковими даними |
dd if=/dev/sda of=/dev/sdb bs=4096 | Побайтне копіювання даних з пристрою на пристрій |
dd if=/dev/zero of=/dev/sda bs=4k | Очищення жорсткого диска (для повної впевненості у знищенні даних можна виконати кілька разів) |
dd if=inputfile of=/dev/st0 bs=32k conv=sync | Копіювання файлу на стрічковий пристрій |
dd if=/dev/st0 of=outfile bs=32k conv=sync | Копіювання файлу з стрічкового пристрою |
dd if=/dev/sda | hexdump -C | grep [^00] | Перевіряє, чи заповнений диск нулями |
dd if=/dev/urandom of=/home/$user/hugefile bs=4096 | Заповнює розділ (потрібно бути обережним з системними розділами) |
ls -l myfile -rw-r--r-- 6703104 Oct 31 18:25 myfile dd if=/dev/urandom of=myfile bs=6703104 count=1 | Перемішує вміст файлу (може застосовуватися перед його видаленням) |
dd if=/dev/sda3 of=/dev/sdb3 bs=4096 conv=notrunc,noerror | Копіює розділ до іншого розділу |
dd if=/proc/filesystems | hexdump -C | less | Перегляд доступних файлових систем |
dd if=/proc/partitions | hexdump -C | less | Перегляд розмірів доступних тем у кБ |
dd if=/dev/sdb2 ibs=4096 | gzip > partition.image.gz conv=noerror | Створює стиснений образ другого диска |
dd bs=10240 cbs=80 conv=ascii,unblock if=/dev/st0 of=ascii.out | Копіює вміст стрічкового пристрою в файл, перетворюючи кодування EBCDIC в ASCII |
dd if=/dev/st0 ibs=1024 obs=2048 of=/dev/st1 | Копіює вміст пристрою з розміром блоку 1кб на пристрій з розміром блоку 2 кБ |
dd if=/dev/zero of=/dev/null bs=100M count=100 100+0 records in 100+0 records out 10485760000 bytes (10 GB) copied, 5.62955 s, 1.9 GB/s | Копіює 10 ГБ нулів в нікуди |
dd if=/dev/zero of=/dev/sda bs=512 count=2 fdisk -s /dev/sda dd if=/dev/zero of=/dev/sda seek= (number_of_sectors - 20) bs=1k | Видаляє таблицю розділів диска. Так як таблиця розділів записує дані в початок в кінець диска, то після видалення даних з початку диска нам необхідно знайти кількість секторів (друга команда), а потім стерти останні 20 секторів. |
dd if=/home/$user/bootimage.img of=/dev/sdc | Створення завантажувального USB-диска (він показаний як / dev / sdc) |
dd if=/dev/sda of=/dev/null bs=1m | Хороший спосіб перевірки диска на зіпсовані блоки |
Резервне копіювання і системні операції | |
dd if=/dev/sda of=/dev/fd0 bs=512 count=1 | Копіювання головною завантажувального запису на дискету |
dd if=/dev/sda1 of=/dev/sdb1 bs=4096 | Повне копіювання диска на інший диск |
dd if=/dev/sr0 of=/home/$user/mycdimage.iso bs=2048 conv=nosync | Створення образу CD |
mount -o loop /home/$user/mycdimage.iso /mnt/cdimages/ | локальне монтування створеного образу |
dd if=/dev/sda2 of=/home/$user/hddimage1.img bs=1M count=4430 dd if=/dev/sda2 of=/home/$user/hddimage2.img bs=1M count=8860 [...] | Створення DVD-образів розділу (використовується для резервного копіювання) |
dd if=/$location/hddimage1.img of=/dev/sda2 bs=1M dd if=/$location/hddimage2.img of=/dev/sda2 seek=4430 bs=1M dd if=/$location/hddimage3.img of=/dev/sda2 seek=8860 bs=1M | Відновлення з створеної вище резервної копії |
dd if=/dev/zero count=1 bs=1024 seek=1 of=/dev/sda6 | Знищення суперблоку |
dd if=/dev/zero count=1 bs=4096 seek=0 of=/dev/sda5 | Ще один спосіб знищення суперблоку |
dd if=/home/$user/suspicious.doc | clamscan - | Перевірка файла на віруси (необхідний ClamAV) |
dd if=/home/$user/binary file | hexdump -C | less | Перегляд вмісту бінарного файлу (необхідний hexdump) |
dd if=/home/$user/bigfile of=/dev/null dd if=/dev/zero of=/home/$user/bigfile bs=1024 count=1000000 | Тестування жорсткого диска на швидкість читання / запису |
dd if=/dev/sda of=/dev/sda | Відновлює працездатність старих жорстких дисків (диск повинен бути отмонтировать) |
dd if=/dev/mem | strings | grep 'string_to_search' | Перевіряє вміст пам'яті (читане людиною) |
dd if=/dev/fd0 of=/home/$user/floppy.image bs=2x80x18b conv=notrunc | копіювання дискети |
dd if=/proc/kcore | hexdump -C | less | Перегляд віртуальної пам'яті |
dd if=/proc/filesystems | hexdump -C | less | Перегляд доступних файлових систем |
dd if=/proc/kallsyms | hexdump -C | less | Перегляд завантажених модулів |
dd if=/proc/interrupts | hexdump -C | less | Перегляд таблиці переривань |
dd if=/proc/uptime | hexdump -C | less | Перегляд часу роботи системи в секундах |
dd if=/proc/partitions | hexdump -C | less | Перегляд розмірів доступних тем у кб |
dd if=/proc/meminfo | hexdump -C | less | Перегляд статистики використання пам'яті |
dd if=/dev/urandom of=/home/$user/myrandom bs=100 count=1 | Створення файлу розміром 1 кб, заповненого сміттям |
dd if=/dev/mem of=/home/$user/mem.bin bs=1024 | Створення образу миттєвого стану системної пам'яті |
dd if=/home/$user/myfile | Друк файлу в stdout |
dd if=/dev/sda2 bs=16065 | hexdump -C | grep 'text_to_search' | Пошук заданого рядка на всьому розділі. Навіть якщо він захищений, ви можете завантажитися з liveCD |
dd if=/home/$user/file.bin skip=64k bs=1 of=/home/$user/convfile.bin | Копіювання файлу file.bin в convfile.bin за винятком перших 64 kB |
dd if=/home/$user/bootimage.img of=/dev/sdc | Створення завантажувального USB-пристрої (показано тут як / dev / sdc) |
dd if=/dev/mem bs=1k skip=768 count=256 2>/dev/null | strings -n 8 | Читання BIOS |
dd bs=1k if=imagefile.nrg of=imagefile.iso skip=300k | Конвертація образу Nero в стандартний ISO. Це можливо, оскільки всі відмінність між ними полягає в заголовку розміром 300 кб, додає Nero до стандартного ISO-образу. |
dd if=/dev/sda1 | gzip -c | split -b 2000m - /mnt/hdc1/backup.img.gz | Створення образу диска, стисненого за допомогою gzip і розрізаного на частини за допомогою split. |
cat /mnt/hdc1/backup.img.gz.* | gzip -dc | dd of=/dev/sda1 | Відновлення розділу з створеного вище образу. |
dd if=/dev/zero of=myimage bs=1024 count=10240 | Створення порожнього образу диска |
dd ibs=10 skip=1 | Вирізання перших 10 байт з stdin |
dd bs=265b conv=noerror if=/dev/st0 of=/tmp/bad.tape.image | Створення образу з стрічкового накопичувача з поганими ділянками |
dd if=/dev/sda count=1 | hexdump -C | перегляд MBR |
dd if=/dev/sda | nc -l 10001 nc $system_to_backup_IP 10001 | dd of=sysbackupsda.img | Швидке мережеве резервне копіювання за допомогою netcat |
d if=/dev/zero of=/dev/sdX bs=1024000 count=1 | Очищення перших 10 MB розділу |
dd if=/dev/zero of=tmpswap bs=1k count=1000000 chmod 600 tmpswap mkswap tmpswap swapon tmpswap | Створення тимчасового простору підкачки |
dd if=/dev/sda of=/dev/null bs=1024k count=1024 1073741824 bytes (1.1 GB) copied, 24.1684 s, 44.4 MB/s | Визначення швидкості системи введення/виведення вашого диска. Читання файлу розміром 1 Гб. |
dd if=/dev/random count=1 2>/dev/null | od -t u1 | awk '{ print $2}' | head -1 | Генерація випадкового числа |
dd if=/dev/mem of=myRAM bs=1024 | Копіювання вмісту оперативної пам'яті у файл. |
dd if=/dev/sda bs=512 count=1 | od -xa | Перегляд вмісту головною завантажувального запису в шістнадцятковому форматі і в ASCII |
dd if=/my/old/mbr of=/dev/sda bs=446 count=1 | Відновлення головною завантажувального запису, не зачіпаючи таблицю розділів. |
dd if=/dev/sda1 | split -b 700m - sda1-image | Створення копії розділу і збереження її в образах максимальним розміром 700 Мб. |
Работа с текстом | |
ls -l | dd conv=ucase | Перетворює висновок команди у верхній регістр |
echo "MY UPPER CASE TEXT" | dd conv=lcase | Перетворює будь-який текст в нижній регістр |
dd if=/etc/passwd cbs=132 conv=ebcdic of=/tmp/passwd.ebcdic | Перетворює файл системних паролів у файл формату EBCDIC фіксованої довжини |
dd if=text.ascii of=text.ebcdic conv=ebcdic | Перетворення ASCII в EBCDIC |
dd if=myfile of=myfile conv=ucase | Перетворення файлу в нижній регістр (проста заміна sed або tr) |
Автор проекту