विभिन्न तार्किक क्षेत्र आकार के साथ बनाई गई GPT विभाजन तालिका को पहचानना


9

मेरे पास एक 3TB ड्राइव है जिसे मैंने GPT का उपयोग करके विभाजित किया है:

$ sudo sgdisk -p /dev/sdg
Disk /dev/sdg: 5860533168 sectors, 2.7 TiB
Logical sector size: 512 bytes
Disk identifier (GUID): 2BC92531-AFE3-407F-AC81-ACB0CDF41295
Partition table holds up to 128 entries
First usable sector is 34, last usable sector is 5860533134
Partitions will be aligned on 2048-sector boundaries
Total free space is 2932 sectors (1.4 MiB)

Number  Start (sector)    End (sector)  Size       Code  Name
   1            2048           10239   4.0 MiB     8300
   2           10240      5860532216   2.7 TiB     8300

हालाँकि, जब मैं इसे USB अडैप्टर के माध्यम से जोड़ता हूं, तो यह 4096 के तार्किक क्षेत्र के आकार की रिपोर्ट करता है और कर्नेल अब विभाजन तालिका को नहीं पहचानता है (क्योंकि यह सेक्टर 1 में GPT की तलाश में है, जो अब 512 के बजाय 4096 ऑफसेट पर है):

$ sudo sgdisk -p /dev/sdg
Creating new GPT entries.
Disk /dev/sdg: 732566646 sectors, 2.7 TiB
Logical sector size: 4096 bytes
Disk identifier (GUID): 2DE535B3-96B0-4BE0-879C-F0E353341DF7
Partition table holds up to 128 entries
First usable sector is 6, last usable sector is 732566640
Partitions will be aligned on 256-sector boundaries
Total free space is 732566635 sectors (2.7 TiB)

Number  Start (sector)    End (sector)  Size       Code  Name

लिनक्स को जीपीटी को 512 पर पहचानने के लिए बाध्य करने का कोई तरीका है? वैकल्पिक रूप से, क्या दो GPT हेडर बनाने का एक तरीका है, एक 512 और 4096 पर एक, या वे ओवरलैप करेंगे?

संपादित करें: मैंने कुछ वर्कअराउंड पाए हैं, जिनमें से कोई भी बहुत अच्छा नहीं है:

  1. मैं डिस्क को विभाजित करने के लिए लूपबैक डिवाइस का उपयोग कर सकता हूं:

    $ losetup /dev/loop0 /dev/sdg
    

    लूपबैक उपकरणों में हमेशा 512 का एक सेक्टर आकार होता है, इसलिए यह मुझे डिवाइस को विभाजन करने की अनुमति देता है कि मैं कैसे चाहता हूं। हालाँकि, कर्नेल लूपबैक उपकरणों पर विभाजन तालिकाओं को नहीं पहचानता है, इसलिए मुझे एक और लूपबैक डिवाइस बनाना होगा और मैन्युअल रूप से विभाजन और स्ट्रीक को निर्दिष्ट करना होगा:

    $ losetup /dev/loop1 /dev/sdg -o $((10240*512)) --sizelimit $(((5860532216-10240)*512))
    

    मैं इसे स्वचालित करने के लिए एक स्क्रिप्ट लिख सकता हूं, लेकिन यह स्वचालित रूप से करने में सक्षम होना अच्छा होगा।

  2. मैं nbd-server और nbd-client चला सकता हूं; NBD डिवाइसेस में डिफ़ॉल्ट रूप से 512-बाइट सेक्टर होते हैं, और NBD डिवाइसेस विभाजन योग्य होते हैं। हालाँकि, NBD दस्तावेज़ीकरण nbd सर्वर और क्लाइंट को एक ही सिस्टम पर चलाने के खिलाफ चेतावनी देता है; परीक्षण करते समय, इन-कर्नेल एनबीडी क्लाइंट को लटका दिया गया और मुझे सर्वर को मारना पड़ा।

  3. मैं एक ही सेटअप का उपयोग करके istgt (उपयोगकर्ता-स्थान iSCSI लक्ष्य) चला सकता हूं। यह 512-बाइट क्षेत्रों के साथ सिस्टम के लिए एक और SCSI डिवाइस प्रस्तुत करता है। हालाँकि, परीक्षण करते समय, यह विफल हो गया और ext4 कोड में कर्नेल NULL पॉइंटर डिफरेंस का कारण बना।

  4. मैंने अभी तक देवमापर की जांच नहीं की है, लेकिन यह काम कर सकता है।


1
इस ब्लॉग पोस्ट को देखें: goughlui.com/2013/10/02/…
fpmurphy

जवाबों:


3

मुझे एक समाधान मिला: kpartx नामक एक प्रोग्राम, जो एक यूजरस्पेस प्रोग्राम है जो लूपबैक उपकरणों से विभाजन बनाने के लिए डेमपर का उपयोग करता है, जो बहुत अच्छा काम करता है:

$ loop_device=`losetup --show -f /dev/sdg`
$ kpartx -a $loop_device
$ ls /dev/mapper
total 0
crw------- 1 root root  10, 236 Mar  2 17:59 control
brw-rw---- 1 root disk 252,   0 Mar  2 18:30 loop0p1
brw-rw---- 1 root disk 252,   1 Mar  2 18:30 loop0p2
$
$ # delete device
$ kpartx -d $loop_device
$ losetup -d $loop_device

यह अनिवार्य रूप से वह करता है जो मैं विकल्प 1 में करने की योजना बना रहा था, लेकिन बहुत अधिक सफाई से।


2

यदि कर्नेल मॉड्यूल का max_partपैरामीटर loopसेट है , तो लिनक्स पर, लूप डिवाइस विभाजन योग्य हैं । यदि loopअंतर्निहित (मॉड्यूल नहीं) है, तो आप loop.max_part=31इसके बजाय एक कर्नेल कमांड लाइन पैरामीटर पास कर सकते हैं ।

इसलिए जब आप loopविभाजन योग्य ब्लॉक डिवाइस प्राप्त करने के लिए ड्राइवर को कॉन्फ़िगर करते हैं , तो यह सिर्फ एक काम करना चाहिए:

losetup --show -f /dev/sda

कुछ पाने के लिए /dev/loopXp1, /dev/loopXp2... प्रत्येक विभाजन के लिए उपकरण।

जब से आप अपना प्रश्न पोस्ट करते हैं, तो कुछ नोटों को कर्नेल में उस मोर्चे पर विकसित किया गया है:

  • 4.14 के बाद से, लूप डिवाइस ( losetup -b 4096उदाहरण के लिए) के अलावा 512 के अलावा एक तार्किक ब्लॉक आकार निर्दिष्ट करना संभव है । इसके बनने के बाद लूप डिवाइस का ब्लॉक साइज बदलना भी संभव है।

  • 4.11 के बाद से, nbd डिवाइसेस का लॉजिकल ब्लॉक साइज़ nbd-client ( -bऑप्शन) को दिए गए ब्लॉक साइज़ पर सेट होता है। चूंकि डिफ़ॉल्ट ब्लॉक आकार है (और था) 1024, इसका मतलब है कि nbd उपकरणों को अब 512 के बजाय डिफ़ॉल्ट तार्किक क्षेत्र आकार 1024 से पहले मिलता है (एक बैकवर्ड संगतता बिंदु से बहुत बुरा)।

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