আমি কেন বিড়াল / দেব?


41

আমি পারি cat /dev, পারি ls /dev, পারি না less /devcatআমাকে catএই ডিরেক্টরিটি ছাড়া অন্য কোনও ডিরেক্টরি কেন দেয় ?

Zsh এ এই আচরণের চিত্র।


@ কামিলম্যাসিওরওস্কি, আপনার ফলাফল এবং ফলাফলের neofetchজন্য এখানে :) i.imgur.com/3azpnDt.png
হাবাউন্নাহ

উত্তর:


43

Icallyতিহাসিকভাবে (ভি 7 ইউএনআইএক্স অবধি বা প্রায় 1979) readসিস্টেম কলটি ফাইল এবং ডিরেক্টরি উভয় ক্ষেত্রেই কাজ করে। readডিরেক্টরিতে কোনও সাধারণ প্রোগ্রাম কাঠামো ফিরে আসে যা কোনও ব্যবহারকারী প্রোগ্রাম ডিরেক্টরি এন্ট্রিগুলি পাওয়ার জন্য বিশ্লেষণ করে। প্রকৃতপক্ষে, ভি 7 lsসরঞ্জামটি ঠিক এটি করেছিল - readকোনও ডিরেক্টরিতে ফলাফলের কাঠামোগুলি, কাঠামোগত তালিকা বিন্যাসে আউটপুট পার্স করে।

ফাইল সিস্টেমগুলি আরও জটিল হয়ে উঠার সাথে সাথে, এই "সাধারণ" ডেটা কাঠামোটি আরও জটিল হয়ে উঠল, যেখানে readdirপ্রোগ্রামগুলির আউটপুটকে বিশ্লেষণে সহায়তা করার জন্য একটি লাইব্রেরি ফাংশন যুক্ত করা হয়েছিল read(directory)। বিভিন্ন সিস্টেমে এবং ফাইল-সিস্টেমে বিভিন্ন ডিস্ক ফর্ম্যাট থাকতে পারে, যা জটিল হয়ে উঠছিল।

যখন সান নেটওয়ার্ক ফাইল সিস্টেম (এনএফএস) প্রবর্তন করল, তারা অন ডিস্ক ডিরেক্টরি কাঠামো পুরোপুরি বিমূর্ত করতে চেয়েছিল। তাদের read(directory)প্রত্যাবর্তনকে ডিরেক্টরিটির প্ল্যাটফর্ম-স্বতন্ত্র প্রতিনিধিত্ব করার পরিবর্তে , তারা একটি নতুন সিস্টেম কল যুক্ত করেছে getdirents- এবং readনেটওয়ার্ক-মাউন্টড ডিরেক্টরিতে নিষিদ্ধ । এই সিস্টেম কলটি বিভিন্ন ইউনিক্স স্বাদে সমস্ত ডিরেক্টরিতে কাজ করার জন্য দ্রুত রূপান্তরিত হয়েছিল, এটি ডিরেক্টরিগুলির বিষয়বস্তু প্রাপ্তির জন্য এটি ডিফল্ট উপায়। ( Https://utcc.utoronto.ca/~cks/space/blog/unix/ReaddirHistory থেকে ইতিহাস বিমৃত )

কারণ readdirএখন ডিফল্ট ভাবে নির্দেশিকা পড়া হয়, read(directory)সাধারণত অধিকাংশ আধুনিক অপারেটিং সিস্টেমের উপর বাস্তবায়িত হয়নি (ফিরে -EISDIR) (QNX, উদাহরণস্বরূপ, একটি উল্লেখযোগ্য ব্যতিক্রম যা কার্যকরী হয় readdirযেমন read(directory))। তবে বেশিরভাগ আধুনিক কার্নেলগুলিতে "ভার্চুয়াল ফাইল সিস্টেম" ডিজাইনের সাহায্যে ডিরেক্টরিটি পড়া কাজ করে কি না তা প্রকৃতপক্ষে পৃথক ফাইল সিস্টেমের উপর নির্ভর করে।

এবং প্রকৃতপক্ষে, ম্যাকোস-এ, devfsমাউন্টপয়েন্টের অন্তর্নিহিত ফাইল সিস্টেমটি /devসত্যই পড়ার সমর্থন করে ( https://github.com/apple/darwin-xnu/blob/xnu-4570.1.46/bsd/miscfs/devfs/devfs_vnops.c#L629 ) :

static int
devfs_read(struct vnop_read_args *ap)
{
        devnode_t * dn_p = VTODN(ap->a_vp);

    switch (ap->a_vp->v_type) {
      case VDIR: {
          dn_p->dn_access = 1;

          return VNOP_READDIR(ap->a_vp, ap->a_uio, 0, NULL, NULL, ap->a_context);

READDIRযদি আপনি /devপড়ার চেষ্টা করেন তবে এটি স্পষ্টভাবে কল করে (অধীন ফাইলগুলি /devপৃথক ফাংশন দ্বারা পরিচালিত হয় devfsspec_read)। সুতরাং, যদি কোনও প্রোগ্রাম readসিস্টেমে কল কল করে /dev, এটি সফল হবে এবং একটি ডিরেক্টরি তালিকা প্রাপ্ত করবে!

এটি কার্যকরভাবে এমন একটি বৈশিষ্ট্য যা ইউনিক্সের খুব প্রথম দিন থেকেই হোল্ডওভার এবং এটি খুব দীর্ঘ সময়ে স্পর্শ করা হয়নি। আমার একটি অংশ সন্দেহ করে যে এটি কিছু পিছনের সামঞ্জস্যতার কারণে রাখা হয়েছিল, তবে এটি সহজেই সত্য হতে পারে যে কেউ আসলেই কোনও ক্ষতি করছে না বলে বৈশিষ্ট্যটি সরাতে যথেষ্ট পাত্তা দেয় না।


সম্ভবত পরবর্তীকালে, বেশিরভাগ ডিরেক্টরি থেকে এটি সরিয়ে ফেলা হয়েছে বলে দেখে।
ব্যবহারকারী 253751

36

কম কোনও পাঠ্য ফাইল ভিউয়ার, বিড়াল সালিসী ডেটা অনুলিপি করার একটি সরঞ্জাম। তাই আপনি এমন কিছু খোলেন না যাতে প্রচুর পরিমাণে ডেটা থাকবে বা খুব আশ্চর্যের সাথে আচরণ করবে তা নিশ্চিত করার জন্য কম এটি নিজের পরীক্ষা করে। অন্যদিকে, বিড়ালটির তেমন কোনও চেকিং নেই - কার্নেলটি যদি আপনাকে কিছু খুলতে দেয় (এমনকি এটি পাইপ বা ডিভাইস বা আরও খারাপ কিছু হলেও), বিড়াল এটি পড়বে।

তাহলে ওএস কেন বিড়ালকে ডিরেক্টরি খুলতে দেয় ? BSতিহ্যগতভাবে বিএসডি-স্টাইল সিস্টেমগুলিতে সমস্ত ডিরেক্টরি ফাইল হিসাবে পঠিত হতে পারে এবং প্রোগ্রামগুলি প্রথম স্থানে একটি ডিরেক্টরি তালিকাবদ্ধ করে: কেবলমাত্র ডিস্কে সঞ্চিত ডাইরেক্ট স্ট্রাকচারের ব্যাখ্যা দিয়ে।

পরবর্তী সময়ে, সেই অন-ডিস্ক স্ট্রাকচারগুলি কার্নেলের দ্বারা ব্যবহৃত নির্দেশ থেকে আলাদা হতে শুরু করে: যেখানে আগে ডিরেক্টরিটি একটি রৈখিক তালিকা ছিল, পরে ফাইল সিস্টেমগুলি হ্যাশ টেবিল, বি-ট্রি ইত্যাদি ব্যবহার শুরু করে। সুতরাং ডিরেক্টরিগুলি সরাসরি পড়া আর সোজা ছিল না - কার্নেল এটির জন্য উত্সর্গীকৃত ফাংশন বৃদ্ধি করে। (আমি নিশ্চিত নই যে এটির মূল কারণ ছিল বা তারা মূলত অন্যান্য কারণে যেমন ক্যাশিংয়ের জন্য যুক্ত করা হয়েছিল))

কিছু বিএসডি সিস্টেম আপনাকে পড়ার জন্য সমস্ত ডিরেক্টরি খুলতে দেয়; আমি জানি না যে তারা আপনাকে ডিস্ক থেকে কাঁচা ডেটা দেয়, অথবা তারা পরিবর্তে কোনও এমুলেটেড ডায়রেন্টের তালিকা ফিরিয়ে দেয় কিনা, বা তারা ফাইল-সিস্টেম চালককে সিদ্ধান্ত নিতে দেয় কিনা।

সুতরাং সম্ভবত ম্যাকোস হ'ল সেই অপারেটিং সিস্টেমগুলির মধ্যে একটি যেখানে ফাইল সিস্টেম ডেটা সরবরাহ করবে ততক্ষণ কার্নেল এটিকে অনুমতি দেয় । এবং পার্থক্যটি হ'ল এটি /devএমন একটি devfsফাইল সিস্টেমে যা প্রথম দিনগুলিতে এটির অনুমতি দেওয়ার জন্য লেখা হয়েছিল, যখন /একটি এপিএফএস ফাইল সিস্টেমে রয়েছে যা আধুনিক সময়ে এই বৈশিষ্ট্যটিকে অপ্রয়োজনীয় হিসাবে বাদ দিয়েছে।

দাবি অস্বীকার: আমি আসলে বিএসডি বা ম্যাকোস নিয়ে কোনও গবেষণা করিনি। আমি শুধু এটি ডানা।


এটি বোধগম্য মনে হয়। স্টোরেজের এমন কোনও বিভাগ আছে যা স্ট্যান্ডার্ড ওএস ফাইল সিস্টেম থেকে পৃথক? আমি ধরে নিলাম /etc, তাই আমি এটি আমার মানদণ্ড হিসাবে ব্যবহার করেছি।
হাবাউন্নাহ

2
বিপরীতে, সাধারণত / ইত্যাদি হ'ল নিয়মিত ফাইলযুক্ত একটি নিয়মিত ফোল্ডার। সেখানে পারে রান - অন্য ভার্চুয়াল ফাইল সিস্টেম যদিও হতে mountবা /sbin/mountতা দেখতে বর্তমানে যেখানে মাউন্ট হচ্ছে।
মাধ্যাকর্ষণ

তুমি ঠিক বলছো! এটি দেখুন: i.imgur.com/pcVpo1o.png
haboutnnah

এটি সত্যিই ঝরঝরে @ গ্রায়েটি, i.imgur.com/8QuR0FK.png
হাবাউত্তনাহ

6
@haboutnnah আপনার স্ক্রিনশটটির নিশ্চিত করে যে /devএকটি ভার্চুয়াল ফাইল ব্যবহার করে সিস্টেম devfsচালক যেহেতু /etcঅংশ /ব্যবহার ফাইল সিস্টেম apfsড্রাইভার। সুতরাং কারণটি catএকটি পড়বে এবং অন্যটি না হ'ল apfsএবং devfsচালকদের মধ্যে পার্থক্য ।
ক্যাস্পারড
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.