मौजूदा एसडीपीएन स्थापना को छोटे एसडी कार्ड में कॉपी करें


25

क्या एक मौजूदा और कॉन्फ़िगर किए गए रास्पियन इंस्टॉलेशन को छोटे एसडी कार्ड में कॉपी करना संभव है?

जब मैंने पहली बार रस्पियन स्थापित किया था तो मेरे पास केवल एक 32 जीबी कार्ड था जो स्पष्ट रूप से आवश्यकता से बड़ा है।


सिस्टम बेहतर तरीके से चलेगा और कार्ड आपके प्राथमिक विभाजन में अधिक खाली जगह के साथ लंबे समय तक चलेगा, इसलिए इसे बहुत अधिक न सिकोड़ें - इसे कम से कम अपने उपयोग से दोगुना रखें (जैसे, यदि आपका सिस्टम 2-3 जीबी का उपयोग करता है 8GB कार्ड, और सभी उपलब्ध स्थान को भरने के लिए विभाजन बढ़ाएँ)। ध्यान दें कि यदि आपने विभाजन को शुरू करने के लिए नहीं बढ़ाया है, तो यह 32 जीबी नहीं होगा, इसलिए आपको इसे सिकोड़ना नहीं पड़ सकता है।
गोल्डीलॉक्स

इसे इंगित करने के लिए धन्यवाद, लेकिन मेरा रास्पबेरी वर्तमान में सिर्फ 1.8 जीबी का उपयोग कर रहा है क्योंकि यह वास्तव में बुनियादी स्थापना है। इसलिए मुझे लगता है कि 4 जीबी पर्याप्त होना चाहिए।
mwld

मुझे लगता है कि जब मैंने पहली बार डेबियन व्हीज़ी को स्थापित किया था, तो मैंने इसे पूर्ण आकार तक बढ़ा दिया था। अब मैंने इसे 2.5 जीबी तक सिकोड़ लिया लेकिन फिर भी कोई सफलता नहीं मिली। नीचे मेरी टिप्पणी देखो।
mwld


1
यदि नीचे दिए गए उत्तरों में से कोई भी आपके प्रश्न को संतुष्ट करता है, तो कृपया उत्तर की जाँच करें।
वेस मोड्स

जवाबों:


12

इस उत्तर में, मैं प्रदर्शित करता हूं कि लोगों को समाधान के पीछे के तर्क को समझने और उनकी अन्य समस्याओं में कदमों को लागू करने में सक्षम होने के लिए कदम-दर-कदम क्या करना है।

लेकिन सबसे पहले, यह कहा जाना चाहिए कि यह एक एसडी कार्ड से एक छोटे (लेकिन डेटा के लिए काफी बड़ा) एसडी कार्ड में फाइलसिस्टम को स्थानांतरित करने के लिए एक सामान्य (रास्पि विशिष्ट नहीं) समस्या है।

आवश्यकताएँ

एक माइक्रो एसडी कार्ड रीडर और लिनक्स (मैं उबंटू को पसंद करता हूं) वाला एक लैपटॉप।

लघुरूप

PIBOX      : Raspberry Pi which is used
SD_CARD_A  : 8GB micro SD card which is used on PIBOX and on which Raspbian-lite (the OS) is installed
SD_CARD_B  : 2GB micro SD card which will be used on PIBOX and on which Raspbian-lite (the OS) will be installed

SD_CARD_A के विभाजन

जब PIBOX चल रहा होता है, हम विभाजन को सूचीबद्ध करते हैं (अनावश्यक सिस्टम विभाजन यहां प्रदर्शित नहीं किए जा रहे हैं)।

root@pibox:~# df -Th
Filesystem     Type      Size  Used Avail Use% Mounted on
/dev/root      ext4      7.3G  1.1G  5.9G  16% /
/dev/mmcblk0p1 vfat       63M   21M   43M  33% /boot

के रूप में SD_CARD_A पर 2 विभाजन कर रहे हैं /और /boot। यहां तक ​​कि कुल 2GB का उपयोग नहीं किया जाता है।

बैकअप SD_CARD_A

हम PIBOX को बंद और बंद करने के बाद, हम PIBOX बोर्ड से SD_CARD_A निकालते हैं और इसे अपने लैपटॉप के कार्ड रीडर में डालते हैं।

SD_CARD_A का विभाजन स्वचालित रूप से के रूप में हमारी प्रणाली में रखा जाता है /dev/sdc1और /dev/sdc2

root@mylaptop:~# df -Th
Filesystem                    Type      Size  Used Avail Use% Mounted on
/dev/sdb2                     ext4       22G   13G  7.9G  63% /
/dev/sdb1                     vfat      197M  2.6M  195M   2% /boot/efi
/dev/sda8                     ext4       66G   11G   52G  17% /home
/dev/sdc1                     vfat       63M   21M   43M  33% /media/some_user_name/boot
/dev/sdc2                     ext4      7.3G  1.1G  5.9G  16% /media/some_user_name/some_uuid_serial

हम उन विभाजनों को अपने सिस्टम से सफलतापूर्वक उन पर संचालित करने के लिए अनमाउंट करते हैं।

root@mylaptop:~# umount /dev/sdc1
root@mylaptop:~# umount /dev/sdc2

हम अगले चरणों में पुष्टि के लिए विवरण में SD_CARD_A की डिवाइस जानकारी प्रदर्शित करते हैं।

root@mylaptop:~# fdisk -l /dev/sdc
Disk /dev/sdc: 7969 MB, 7969177600 bytes
246 heads, 62 sectors/track, 1020 cylinders, total 15564800 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: 0x2019f6d8

   Device Boot      Start         End      Blocks   Id  System
/dev/sdc1            8192      137215       64512    c  W95 FAT32 (LBA)
/dev/sdc2          137216    15564799     7713792   83  Linux

ऊपर आप देख सकते हैं कि SD_CARD_A की क्षमता 8GB है।

हम SD_CARD_A को pibox.img फ़ाइल में क्लोन करते हैं।

root@mylaptop:~# dd bs=4MB if=/dev/sdc of=pibox.img
1992+1 records in
1992+1 records out
7969177600 bytes (8.0 GB) copied, 416.582 s, 19.1 MB/s

कॉपी किए गए बाइट्स के आकार की जांच करें, यह हमारे द्वारा प्राप्त मूल्य के बराबर है fdisk -l /dev/sdc

लिनक्स लूपबैक मॉड्यूल

लिनक्स में लूपबैक नामक एक मॉड्यूल होता है जो हमें एक फाइल को ब्लॉक डिवाइस के रूप में संभालने के लिए प्रदान करता है।

हम लूपबैक मॉड्यूल लोड करते हैं।

root@mylaptop:~# modprobe loop

हमें अप्रयुक्त लूपबैक डिवाइस पथ मिल जाता है।

root@mylaptop:~# losetup -f /dev/loop0

अब, हम pibox.img फ़ाइल के लिए एक लूपबैक डिवाइस बनाते हैं।

root@mylaptop:~# losetup /dev/loop0 pibox.img

हम विभाजन परिवर्तनों के बारे में कर्नेल को ट्रिगर करते हैं।

root@mylaptop:~# partprobe /dev/loop0

हम पुष्टि करते हैं कि पिछले ऑपरेशन सफल रहे हैं।

root@mylaptop:~# losetup /dev/loop0
/dev/loop0: [0806]:69 (/root/pibox.img)

हम लूपबैक डिवाइस की जानकारी को SD_CARD_A से तुलना करने के लिए विवरण में प्रदर्शित करते हैं।

root@mylaptop:~# fdisk -l /dev/loop0
Disk /dev/loop0: 7969 MB, 7969177600 bytes
255 heads, 63 sectors/track, 968 cylinders, total 15564800 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: 0x2019f6d8

      Device Boot      Start         End      Blocks   Id  System
/dev/loop0p1            8192      137215       64512    c  W95 FAT32 (LBA)
/dev/loop0p2          137216    15564799     7713792   83  Linux

ऊपर आप देख सकते हैं कि लूपबैक डिवाइस का आकार (= 7969177600 बाइट्स) और विभाजन SD_CARDIA के साथ समान हैं।

बेसिक मैथ्स

अब से, हम विभाजन पर केंद्रित होंगे /dev/loop0p2। इसे THE_PARTITION नाम दें

ब्लॉक का आकार 512 बाइट्स है (जैसा कि इकाइयों = सेक्टरों से शुरू होने वाली लाइन पर मुद्रित होता है .....)

THE_PARTITION ब्लॉक 137216 से शुरू होता है और ब्लॉक 15564799 पर समाप्त होता है जिसका अर्थ है कि इसका आकार 15427584 blocks(= 15564799 - 137216 + 1) है।

तो, बाइट्स में THE_PARTITION का आकार 7898923008 bytes(= 512 * 15427584) है।

SD_CARD_B में THE_PARTITION फिट करने के लिए, हम चाहते हैं कि इसका नया आकार 3710940 blocks या दूसरे शब्दों में 1900001280 bytes(= 512 * 3710940) हो।

तो, नए अंत ब्लॉक संख्या (= 137216) + (= 3710940) 3848155द्वारा गणना की जाती है ।start block numbersize in blocks1

फाइलसिस्टम बनाम विभाजन

2 ऑपरेशन हैं जो एक दूसरे के लिए गलत नहीं होने चाहिए।

  • फ़ाइल सिस्टम का आकार बदलना। हम इसका आकार सेट करके THE_PARTITION पर फ़ाइल सिस्टम को सिकोड़ देंगे 3710940 blocks
  • विभाजन का आकार देना। हम इसका अंतिम ब्लॉक नंबर सेट करके THE_PARTITION को छोटा कर देंगे 3848155

सिकुड़ती फाइलसिस्टम

फ़ाइल सिस्टम को सिकोड़ने से पहले, इसे स्वच्छ के रूप में चिह्नित किया जाना चाहिए e2fsck

root@mylaptop:~# e2fsck -f /dev/loop0p2
e2fsck 1.42.9 (4-Feb-2014)
Pass 1: Checking inodes, blocks, and sizes
Pass 2: Checking directory structure
Pass 3: Checking directory connectivity
Pass 4: Checking reference counts
Pass 5: Checking group summary information
/dev/loop0p2: 41175/475776 files (0.2% non-contiguous), 309183/1928448 blocks

हम फ़ाइल सिस्टम को सिकोड़ते हैं resize2fs

root@mylaptop:~# resize2fs /dev/loop0p2 3710940s
resize2fs 1.42.9 (4-Feb-2014)
Resizing the filesystem on /dev/loop0p2 to 463867 (4k) blocks.
The filesystem on /dev/loop0p2 is now 463867 blocks long.

विभाजन को सिकोड़ना

हम सीखते हैं कि THE_PARTITION नंबर क्या है parted

root@mylaptop:~# parted /dev/loop0
GNU Parted 2.3
Using /dev/loop0
Welcome to GNU Parted! Type 'help' to view a list of commands.
(parted) print                                                            
Model: Loopback device (loop)
Disk /dev/loop0: 7969MB
Sector size (logical/physical): 512B/512B
Partition Table: msdos

Number  Start   End     Size    Type     File system  Flags
 1      4194kB  70.3MB  66.1MB  primary  fat16        lba
 2      70.3MB  7969MB  7899MB  primary  ext4

(parted) quit

हम THE_PARTITION को छोटा करते हैं parted

root@mylaptop:~# parted /dev/loop0 unit s resizepart 2 3848155
Warning: Shrinking a partition can cause data loss, are you sure you want to continue?
Yes/No? Yes  

हम लूपबैक डिवाइस के साथ किया जाता है। हम इसे अलग कर लेते हैं।

root@mylaptop:~# losetup -d /dev/loop0

छवि फ़ाइल को छोटा करना

हम नई विभाजन तालिका को सत्यापित करते हैं।

root@mylaptop:~# fdisk -l pibox.img 

Disk pibox.img: 7969 MB, 7969177600 bytes
255 heads, 63 sectors/track, 968 cylinders, total 15564800 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: 0x2019f6d8

    Device Boot      Start         End      Blocks   Id  System
pibox.img1            8192      137215       64512    c  W95 FAT32 (LBA)
pibox.img2          137216     3848155     1855470   83  Linux

आउटपुट में, यह स्पष्ट रूप से देखा जाता है कि THE_PARTITION की अंतिम ब्लॉक संख्या कम हो गई है from 15564799 to 3848155

अंतिम ब्लॉक जिसका हम उपयोग करते हैं 3848155। ब्लॉक नंबरिंग 0. से शुरू होती है, हमारे पास कुल 3848155 + 1 ब्लॉक हैं और pibox.img फ़ाइल का नया आकार1970255872 bytes (= (3848155 + 1) * 512) होना चाहिए ।

हम pibox.img फ़ाइल को काटते हैं।

root@mylaptop:~# truncate --size=1970255872 pibox.img

हम pibox.img फ़ाइल के नए आकार को सत्यापित करते हैं।

root@mylaptop:~# ls -l pibox.img 
-rw-r--r-- 1 root root 1970255872 Oct 13 21:53 pibox.img

SD_CARD_B बनाना

हमने अपने लैपटॉप के कार्ड रीडर में SD_CARD_B डाला। SD_CARD_B का विभाजन स्वचालित रूप से के रूप में हमारी प्रणाली में रखा जाता है /dev/sdc1और /dev/sdc2

root@mylaptop:~# df -Th
Filesystem                    Type      Size  Used Avail Use% Mounted on
/dev/sdb2                     ext4       22G   13G  7.9G  63% /
/dev/sdb1                     vfat      197M  2.6M  195M   2% /boot/efi
/dev/sda8                     ext4       66G   11G   52G  17% /home
/dev/sdc1                     vfat       63M   21M   43M  33% /media/some_user_name/boot
/dev/sdc2                     ext4      1.8G  1.6G   59M  97% /media/some_user_name/some_uuid_serial

ऊपर आप देख सकते हैं कि SD_CARD_B की क्षमता 2GB है।

हम उन विभाजनों को अपने सिस्टम से SD_CARD_B पर सफलतापूर्वक संचालित करने के लिए अनमाउंट करते हैं।

root@mylaptop:~# umount /dev/sdc1
root@mylaptop:~# umount /dev/sdc2

हम SD_CARD_B में pibox.img फ़ाइल को क्लोन करते हैं।

root@mylaptop:~# dd bs=4MB if=pibox.img of=/dev/sdc
492+1 records in
492+1 records out
1970255872 bytes (2.0 GB) copied, 646.967 s, 3.0 MB/s

कॉपी किए गए बाइट्स के आकार की जांच करें, यह हमारे द्वारा प्राप्त मूल्य के बराबर है ls -l pibox.img

बूटिंग PIBOX

हमारे लैपटॉप से ​​SD_CARD_B को बाहर निकालने और PIBOX बोर्ड में डालने के बाद, हम सिस्टम को बूट करते हैं और PIBOX कंसोल में लॉगिन करते हैं।

हम विभाजन को सूचीबद्ध करते हैं (कुछ अन्य अनावश्यक सिस्टम विभाजन यहां प्रदर्शित नहीं किए जा रहे हैं)।

root@pibox:~# df -Th
Filesystem     Type      Size  Used Avail Use% Mounted on
/dev/root      ext4      1.8G  1.1G  601M  64% /
/dev/mmcblk0p1 vfat       63M   21M   43M  33% /boot

अच्छा था। मुझे लगता है कि लूपबैक को सेट करने के साथ आपका कुछ सामान लंबे समय तक घुमावदार और अनावश्यक हो सकता है, आप इसे देखना चाहते हैं। कुछ काफ़ी मिलती-जुलती सवाल से बहुत मिलता-जुलता: raspberrypi.stackexchange.com/a/29952/5538
गोल्डीलॉक्स

@goldilocks, परीक्षण नहीं किया गया है लेकिन मुझे लगता है कि लूपबैक का उपयोग करना आवश्यक है। जहाँ तक मुझे पता है कि बिंब सीधे छवि फ़ाइल पर काम नहीं कर सकता है, इसे इसके संचालन के लिए एक उपकरण इंटरफ़ेस की आवश्यकता है।
vhaha

हां, लेकिन मुझे लगता है कि आप पाएंगे कि आपको परेशान नहीं होना है losetupया यहां तक ​​कि -o loop=whatever। अन्य पोस्ट के अनुसार मैं सिर्फ उपयोग करता हूं mount -o offset=123 /imagefilepath /mntpointऔर लूपबैक का उपयोग निहित है। मुझे लगता है कि अब आम तौर पर linux पर सच है - कोशिश करो और देखो। आप तब यह कहकर कम कर सकते हैं कि विभाजन को एक आभासी "लूपबैक डिवाइस" के माध्यम से रखा गया है।
गोल्डीलॉक्स

5

जब आप उपयोग करते हैं dd if=/dev/sdx of=/path/to/image bs=1M, /dev/sdxतो संपूर्ण "डिस्क" को संदर्भित करता है, इसलिए छवि हमेशा पूरे कार्ड का आकार होगी।

इसके बजाय, आपको यह उपयोग करने की आवश्यकता होगी कि विभाजन संख्या dd if=/dev/sdxn ...कहाँ nहै।

/bootविभाजन के लिए एक बार और विभाजन के लिए - आपको संभवतः दो बार ऐसा करने की आवश्यकता होगी /

फिर आपको नए कार्ड पर विभाजन बनाने की आवश्यकता होगी जो कम से कम उन दो मूल लोगों के रूप में बड़े हैं, जो सामग्री को वापस करने के लिए।


3

प्राथमिक विभाजन को छोटे आकार में सिकोड़ने के लिए पार्टेड (विभाजन संपादक) जैसी किसी चीज़ का उपयोग करें और अब क्लोनज़िला जैसे टूल का उपयोग करके अपने नए कार्ड में छोटे विभाजन से कॉपी करें। यद्यपि आपको किसी अन्य कंप्यूटर पर ऐसा करना होगा।


दुर्भाग्य से यह काम नहीं किया। मैंने GParted के साथ विभाजन को 2.5 GB तक सिकोड़ लिया। लेकिन जब मैंने USB स्टिक से इसकी एक छवि बनाने की कोशिश की, तो यह बड़ा हो गया (4.3 जीबी - लेकिन मुझे लगता है कि यह पूरी 32 जीबी की नकल करना चाहता था और एफएटी फ़ाइल आकार सीमा के कारण केवल 4.3 जीबी पर रोक दिया गया था)।
mwld

2
मैं कमांड का इस्तेमाल किया dd if=/dev/sdx of=/path/to/image bs=1M: इस सूत्र से raspberrypi.stackexchange.com/questions/311/...
mwld

क्या आपके पास इस बारे में कोई विचार है कि मैं सिर्फ एक छवि में 2.5 जीबी के साथ प्राथमिक विभाजन की प्रतिलिपि कैसे बना सकता हूं और फिर भी इसमें से बूट करने योग्य रास्पबियन के साथ एसडी कार्ड बना सकता हूं?
mwld

देरी से जवाब देने के लिए माफी। मैंने 4GB एसडी कार्ड के साथ शुरुआत की, एक छवि बनाई और फिर उस छवि को 8GB और बड़े कार्ड में लिखा। मुझे अभी तक जो कुछ भी काम किया है उसके लिए एक बड़े विभाजन का उपयोग करने की आवश्यकता नहीं है। मैं एक ऐसे उपकरण के बारे में नहीं जानता, जो आपको एसडी कार्ड पर एक व्यक्ति विभाजन की एक छवि बनाने देगा।
जेरी गगनोन

3
  1. पहले से बताए गए तरीकों में से एक का उपयोग करके कार्ड की एक छवि बनाएं - मैं अपने रास्पबेरी पाई का बैकअप कैसे ले सकता हूं?

  2. छवि को छोटा करने के लिए http://sirlagz.net/2013/03/10/script-automatic-rpi-image-downsizer/ पर स्क्रिप्ट का उपयोग करें

  3. नए छोटे कार्ड पर आकार की छवि को पुनर्स्थापित करें


मैं इस पृष्ठ पर टकरा गया क्योंकि मैं अपनी रास्पियन छवि का बैकअप लेने के लिए एक ही लक्ष्य प्राप्त करने की कोशिश कर रहा हूं, हालांकि मैं पूरे कार्ड को कार्ड पर केवल प्रासंगिक डेटा नहीं चाहता हूं। प्रति ऊपर सुझाव के रूप में, मैं यहाँ स्क्रिप्ट के लिए देख रहा था sirlagz.net/2013/03/10/script-automatic-rpi-image-downsizer लेकिन एक नहीं मिल सका। अगर इस लिंक पर कोई भी अपडेट हो सकता है, तो क्या यह कहीं उपलब्ध है?
शालिवर्मा

मैं अभी भी लिंक का उपयोग कर सकता हूं और पोस्ट स्वयं एक स्क्रिप्ट है। स्क्रिप्ट को एक फ़ाइल में कॉपी करें और इसे नाम दें script.sh, फ़ाइल का उपयोग करके निष्पादन योग्य बनाएं chmodऔर इसे निष्पादित करें।
मिहिर

1

मैं कुछ समय के rsyncलिए फाइल सिस्टम को एक डिस्क से दूसरी में कॉपी करने के लिए उपयोग कर रहा हूं , जिसमें कोई हिचकी नहीं है। Rsync का उपयोग करने का लाभ यह है कि यह डिवाइस के ब्लॉक-स्तरीय प्रतिलिपि करने के बजाय, फाइलसिस्टम की सामग्री की नकल कर रहा है; नतीजतन, यह वास्तव में परवाह नहीं करता है कि लक्ष्य और स्रोत ड्राइव किस आकार के हैं, इसलिए जब तक लक्ष्य ड्राइव में डेटा रखने के लिए पर्याप्त जगह नहीं है।

तो यहां बताया गया है कि मैं यह कैसे करूंगा:

  1. अपने वांछित नए, छोटे एसडी कार्ड पर एक नया रास्पियन इंस्टॉलेशन बनाएं।
  2. नई स्थापना में बूट करें और संपूर्ण डिस्क को भरने के लिए फाइल सिस्टम का विस्तार करें। पी को बंद करो।
  3. अब नए और पुराने कार्ड को माउंट करें और पुराने कार्ड rsync -avx oldFilesystem newFilesystemसे फाइल सिस्टम के साथ नए कार्ड पर फाइल सिस्टम को कॉपी / ओवरराइट करने के लिए उपयोग करें।
  4. अंत में, अपने नए सिस्टम में बूट करें, और rpi-updateसुनिश्चित करें कि आपका फर्मवेयर सुसंगत और अप टू डेट है।

इसके बाद, आपके नए कार्ड में इस पर पूरी तरह कार्यात्मक रास्पियन प्रणाली स्थापित होनी चाहिए।


तो इस विधि (चरण 3) के लिए, मुझे 2 एसडी कार्ड रीडर की आवश्यकता है?
विक्टर वान ही

या तो दो एसडी कार्ड रीडर या एक मध्यवर्ती उपकरण। आप अपनी हार्ड ड्राइव पर एक फ़ोल्डर में पुराने फाइल सिस्टम को rsync कर सकते हैं, फिर उस फ़ोल्डर को दूसरे एसडी कार्ड पर rsync करें, यदि आप रीडर नहीं चुनना चाहते हैं।
sdenton4

1

मैंने बैकअप के लिए एक शेल स्क्रिप्ट बनाई और एक एसडी कार्ड पर सभी डेटा को पुनर्स्थापित किया। यह पहले कुछ डेटा (मेरी परियोजना के अनुसार) को हटाता है और विभाजन को न्यूनतम आकार तक सिकोड़ता है, इसलिए छवि एसडी कार्ड पर डेटा जितनी बड़ी है। इसके अतिरिक्त, स्क्रिप्ट छवि की * .zip फ़ाइल बनाती है। बनाई गई छवि को दूसरे एसडी कार्ड में पुनर्स्थापित करने के बाद विभाजन अधिकतम आकार में बढ़ जाएगा। स्क्रिप्ट उन कमांड का उपयोग करती है जो अन्य उत्तरों में उल्लिखित हैं। जैसा कि यह मेरी मुट्ठी खोल स्क्रिप्ट है इस आकार के साथ इसे बनाने में मुझे घंटों लग गए और यह सही जेट नहीं है। विशेष रूप से मुझे नहीं पता कि कैसे resize2fs और fdisk के रिटर्न मानों को संभालना है ताकि उपयोगकर्ता को मेरे द्वारा आवश्यक मानों में टाइप करना पड़े। क्या इसे ठीक करने के लिए कोई विचार हैं? मुझे उम्मीद है कि यह स्क्रिप्ट किसी और की मदद करेगी। इसे संपादित और सुधारने के लिए स्वतंत्र महसूस करें।

"Usage:
    <skriptname> -b <path>                  create backup of SC Card (dev/mmcblk0) to file <path>/JJJJ-MM-DD_HHMM.img
    <skriptname> -r <path>/FILENAME.img     restore an exitsting image (<path>/FILENAME.img) to the SD Card (dev/mmcblk0) 
    <skriptname> -r <path>/FILENAME.zip     unzip and restore an exitsting image (<path>/FILENAME.zip) to the SD Card (dev/mmcblk0)
    <skriptname> -h                         show this hlep

यह रहा:

#!/bin/bash 

# check if the user is root
if (( $EUID != 0 )); then
  echo "This script requires root privileges please run as root"
  exit
fi


while getopts ":b:r:h" opt; do
  case $opt in
    b)
      mode="backup"
      OUTPATH=$OPTARG
      ;;
    r)
      mode="restore"
      DIRFILENAME=$OPTARG
      ;;
    h)
      mode="help"
      ;;
    \?)
      echo "Invalid option: -$OPTARG. Use -h for help" >&2
      exit 1
      ;;
    :)
      echo "Option -$OPTARG requires an argument. Use -h for help" >&2
      exit 1
      ;;
  esac
done
# no option
if [ $OPTIND == 1 ]
then
  echo "$(basename "$0") needs an option! Use -h for help"
  exit 1
fi


myMount(){
  # create mountpoint if not existing
  if [ ! -d /tmp/sd2/ ] ; then
    mkdir /tmp/sd2
  fi

  # mount partition
  mount -v -t ext4 /dev/mmcblk0p2 /tmp/sd2
  err=$?
  if [ $err != 0 ]; then
    echo "mount failed error: $err"
    exit 1
  fi
}

myUmount(){
  cd /home/ # otherwise umount will fail
  # fuser -vm /tmp/sd2/

  # umount partition
  umount -v /tmp/sd2
  err=$?
  if [ $err != 0 ]; then
    echo "umount failed error: $err"
    exit 1
  fi
}

myEnlarge(){
  echo "enlarge partition..."
  # enlarge partition is not posible with fdisk -> delete and recreate it
  (
  echo d # delete partition
  echo 2 # patition number
  echo n # add a new partition
  echo p # primary partition
  echo 2 # partition number
  echo   # first sector (accept default: varies)
  echo   # last sector (accept default: varies)
  echo w # write changes
  ) | fdisk /dev/mmcblk0

  echo "\n check filesystem... "
  e2fsck -f -v -C 0 /dev/mmcblk0p2

  # enlarge filesystem to maxsize
  resize2fs -p /dev/mmcblk0p2
}

case "$mode" in
"help")
  echo "Usage:
    $(basename "$0") -b <path>                  create backup of SC Card (dev/mmcblk0) to file <path>/JJJJ-MM-DD_HHMM.img
    $(basename "$0") -r <path>/FILENAME.img     restore an exitsting image (<path>/FILENAME.img) to the SD Card (dev/mmcblk0) 
    $(basename "$0") -r <path>/FILENAME.zip     unzip and restore an exitsting image (<path>/FILENAME.zip) to the SD Card (dev/mmcblk0)
    $(basename "$0") -h                         show this hlep
--------------------------------
Adrian Zeitler, Germany 2017"
  ;;
"backup")  ####################################### backup ####################################### 
  echo "an image of the SD Card (/dev/mmcblk0) whitch is as smal as possible will be created to $OUTPATH."
  # ------------------  delete some data --------------------

  echo "Do you want to delete tempfiles? [y/n]" 
  read delfiles

  if [ "$delfiles" = "y" ]
    then
      echo "Delete tempfiles..."

      myMount

      # remove some data
      cd /tmp/sd2/home/alarm/
      rm -v -f hagelbeere.db
      rm -v -f HAILcam.log
      rm -v -f HAILcam.log.1
      rm -v -f test.jpg

      myUmount

    elif [ "$delfiles" = "n" ]
      then
    echo "I don't delete anything."
    else
    echo "Sorry, I didn't understand."
    exit 1
  fi


  # --------------------------------------------------------------
  # shrink partition 2 to minimum size

  echo "check file system... "
  e2fsck -f -v -C 0 /dev/mmcblk0p2
  err=$?
  if [ $err != 0 ]; then
    echo "file system check failed, error: $err"
    exit 1
  fi

  echo "shrink filesystem of partition 2 to minimum size..."
  resize2fs -p -M /dev/mmcblk0p2
  err=$?
  if [ $err != 0 ]; then
    echo "resize2fs failed, error: $err"
    exit 1
  fi
  # --> Das Dateisystem auf /dev/mmcblk0p2 ist nun 692365 Blöcke groß.

  echo "Please tell me the new filesystem size displayed above:"
  read size
  # from resize2fs blocksize, fdisk wants sector: sector = block * 8
  size=$(( $size*8 ))

  # shrink partition is not posible with fdisk -> delete and recreate it
  (
  echo d # delete partition
  echo 2 # patition number
  echo n # add a new partition
  echo p # primary partition
  echo 2 # partition number
  echo   # first sector (accept default: varies)
  echo +$size  # last sector
  echo w # write changes
  ) | fdisk /dev/mmcblk0
  err=$?
  if [ $err != 0 ]; then
    echo "fdisk failed, error: $err"
    exit 1
  fi


  # --------------------------------------------------------------

  # fill unused space with zeros
  echo "Do you want to fill unused space with zeros? [y/n]" 
  read fillzeros


  if [ "$fillzeros" = "y" ]
    then
      echo "Copy zeros. This will end up with an error. But this is ok."

      myMount    

      dd if=/dev/zero | pv | dd of=/tmp/sd2/nullen.datei conv=noerror,notrunc,sync bs=10240
      # exits with error -> this is normal

      # dlelete zeros
      rm -v -f /tmp/sd2/nullen.datei
      sync

      myUmount

    elif [ "$fillzeros" = "n" ]
      then
    echo "I don't delete anything."
    else
    echo "Sorry, I didn't understand."
    exit 1
  fi

  # --------------------------------------------------------------

  # find out end of partition
  fdisk -l /dev/mmcblk0
  echo "Please tell me the end of mmcblk0p2 displayed above."
  read count



  DATE=$(date +"%Y-%m-%d_%H%M")
  IMGFILENAME=$DATE.img 
  echo "Do you want to create image with filename $OUTPATH$IMGFILENAME? [y/n]"
  read answer
  if [ "$answer" = "y" ]
  then
    echo "Do you want to create a *.zip file of the created image? [y/n]"
    read zip
    echo "Do you want to enlarge partition 2 to maxsize after image creation? [y/n]"
    read enlarge

    echo "create image..."
    cd $OUTPATH
    # create image with dd, stop at and of partition
    # count=N   copy only N input blocks
    # bs=BYTES  read and write up to BYTES bytes at a time = block size
    # pv    show status
    dd if=/dev/mmcblk0 | pv -s $(( $count*512 )) | dd of=$IMGFILENAME bs=512 count=$count
    err=$?
    if [ $err != 0 ]; then
      echo "dd failed error: $err"
      exit 1
    fi

    # --------------------------------------------------------------
    # create zip file
    # or like this:
    # sudo dd if=/dev/sdX | pv |gzip > /pfad/zur/datei.img.gz
    if [ "$zip" = "y" ]
    then
      echo "create zip file..."
      zip $DATE.zip $IMGFILENAME
    fi
    # --------------------------------------------------------------
  fi

  # --------------------------------------------------------------
  # enlarge partition 2

  if [ "$enlarge" = "y" ]
  then
    myEnlarge
  fi

  ;; #end case mode backup
"restore")  ####################################### restore ####################################### 
  #chek if image exists
  if [[ -s "$DIRFILENAME" ]]
  then
    # check if file is an image or zip file
    if [[ $DIRFILENAME =~ \.img$ ]]
    then
      IMGFILENAME=$(basename "$DIRFILENAME")
    elif [[ $DIRFILENAME =~ \.zip$ ]]
    then
      ZIPFILENAME=$(basename "$DIRFILENAME")
    else
      echo "Not the right file format. I accept *.img and *.zip"
      exit 1
    fi
  else
    echo "Image file does not exist."
    exit 1
  fi
  echo "the file $DIRFILENAME will be restored to the SD Card /dev/mmcblk0"

  #change to the path of the imagefile
  SOURCEPATH=$(dirname "$DIRFILENAME")
  cd $SOURCEPATH


  if [ "$ZIPFILENAME" != "" ]
  then
    echo "unzip file"
    # change file extention form zip zu img
    l=$(( ${#ZIPFILENAME}-3 ))
    IMGFILENAME="${ZIPFILENAME:0:l}img"
    unzip $ZIPFILENAME
  fi

  echo "Do you realy want to restore $SOURCEPATH/$IMGFILENAME to the SD card /dev/mmcblk0? 
  Warning: all data on the device /dev/mmcblk0 will be lost! [y/n]"
  read answer
  if [ "$answer" = "y" ]
  then
    echo "Do you want to enlarge partition 2 to maxsize after restoring? [y/n]"
    read enlarge
    echo "restore image..."
    filesize=$(wc -c <"$IMGFILENAME")
    echo "Filesize = $filesize Byte"
    dd if=$IMGFILENAME | pv -s $filesize | dd of=/dev/mmcblk0 bs=512
    err=$?
    if [ $err != 0 ]; then
      echo "dd failed error: $err"
      exit 1
    fi
  fi

  # --------------------------------------------------------------
  # enlarge partition 2
  if [ "$enlarge" = "y" ]
  then
    myEnlarge
  fi

  ;; #end case mode restore
esac

0

सबसे आसान समाधान मुझे लगा कि ऊपर बताए गए dd कमांड्स का उपयोग करके मूल बड़े कार्ड का बैकअप करना है और फिर pivriter जैसी किसी चीज़ का उपयोग करके छवि को छोटे कार्ड में पुनर्स्थापित करना है। dd काम भी कर सकता है ... निश्चित नहीं। PiWriter ने कमरे से बाहर निकलने के बाद एक त्रुटि लौटा दी, लेकिन चूंकि छवि में छोटे कार्ड के आकार से परे कोई वास्तविक डेटा नहीं था, यह सिर्फ खाली क्षेत्रों को छोटा कर रहा था। मुझे यकीन नहीं है कि इसके निहितार्थ क्या हैं ... विभाजन को जांच या मरम्मत की आवश्यकता हो सकती है लेकिन मैं यह सत्यापित कर सकता हूं कि जब मैंने इसे पाई में डाला तो यह काम कर गया।


1
यह एक बहुत ही खतरनाक सलाह है, आप कभी नहीं जान पाएंगे कि वास्तव में आकार से परे कोई डेटा था या नहीं। हम काम के समाधान के लिए अधिक विश्वसनीय और सिद्ध हैं।
लेनिक

मैं खतरनाक रूप से जी रहा हूं, मैं क्या कह सकता हूं;) सभी गंभीरता में हालांकि मुझे dd या पार्टीशन मैप्स के साथ काम करने का बहुत अनुभव नहीं है इसलिए मैं यहां अनछुए इलाके में हूं। मैं शायद भाग्यशाली हो गया क्योंकि मेरे पास केवल 16MB कार्ड से 8GB कार्ड में जाने वाले लगभग 800MB डेटा था। हालांकि, जिज्ञासा से बाहर, क्या यह संभवतया यह है कि डेटा को डीफ़्रैग करने का कोई तरीका है यह सुनिश्चित करने के लिए कि यह विभाजन की शुरुआत में समूहीकृत है? हैक लगता है, लेकिन हो सकता है?
कुत्ता

मुझे डीफ़्रैग के बारे में नहीं पता है, लेकिन आप निश्चित रूप से अपने विभाजन का आकार बदल सकते हैं और उन्हें एसडी कार्ड की शुरुआत में स्थानांतरित कर सकते हैं, इसलिए वे केवल शुरुआत पर कब्जा कर लेते हैं। साधारण dd से थोड़ा अधिक समय लगता है, लेकिन परिणाम बहुत अधिक विश्वसनीय होते हैं।
लेनिक

0

मैं win32diskimager-RELEASE-0.1-r15-win32छवि को पढ़ने के लिए एक पुराने संस्करण का उपयोग करता हूं , यह 8GB एसडी कार्ड से भी 4GB की एक छवि बनाता है फिर एक छवि को win32diskimager के नवीनतम संस्करण के साथ लिखता है।

मैं पुराने संस्करण का उपयोग करता हूं क्योंकि पुराना हर त्रुटि को छोड़ देगा।


क्या नए संस्करण में कोई विकल्प नहीं है, 0.95, जो आपको वही करने की अनुमति देता है, अर्थात, हर त्रुटि को छोड़ दें? दुर्भाग्य से sourceforge पेज उपलब्ध विकल्पों में से किसी को सूचीबद्ध करने के लिए प्रकट नहीं होता है। यह प्री-बीटा सॉफ्टवेयर
ग्रीनोनलाइन

मुझे किसी प्रोग्राम का उपयोग करने से कोई वार्म-एंड-फ़ज़ीज़ नहीं मिलता है जो हर त्रुटि को छोड़ देगा।
रुफुसवीस
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.