2

/proc/mounts を使用せずにマウントされたファイルシステムのテーブルを解析する必要があります。これは、proc ファイルシステムがマウントされている場所を特定するために解析しているためです。どうすればいいですか?

私はそれをグーグルで検索しましたが、すべての答えは /proc を使用することでした

そして、人々はなぜprocfsがデフォルトの場所にマウントされていると確信しているのですか?


好奇心から聞いています。/proc は事実上の標準であることを理解しています。多くのツールがそれを使用しているため、 /proc はかなり適切に固定されています。

Linux API はファイルシステム パスに対して一貫性があり、本当に必要な情報はすべて環境変数を介して渡されるため、ライブラリと実行可能ファイル、構成ファイルなどを変更できます。

私は興味がありますPROC_PATHが、事前の知識がなくても検出できますか? statvfs をコールバックとして使用して ftw を実行することもできますが、これは非常に見苦しいです。間違いなくもっとまっすぐな道があるはずです。

4

2 に答える 2

2

どうdf -kですか?グーグルも私をこれに導きます。

Mac ではdiskutil list.

cコードで実行する必要があるシステムコールを把握したい場合は、straceそれを見つけるために使用します。


/ルート ディレクトリにアクセスできると仮定した別のアプローチでは、Peteshコードと llolydmコードを使用します。

#include <stdlib.h>
#include <mntent.h>
#include <unistd.h>
#include <sys/types.h>
#include <dirent.h>
#include <stdio.h>


   void listdir(const char *name, int level)
{
    DIR *dir;
    struct dirent *entry;
    struct mntent *ent;
    FILE *aFile;

    if (!(dir = opendir(name)))
        return;
    if (!(entry = readdir(dir)))
        return;

    do {
        if (entry->d_type == DT_DIR) {
            char path[1024];
            int len = snprintf(path, sizeof(path)-1, "%s/%s", name, entry->d_name);
            path[len] = 0;
            if (strcmp(entry->d_name, ".") == 0 || strcmp(entry->d_name, "..") == 0)
                continue;
            printf("%*s[%s]\n", level*2, "", entry->d_name);
            listdir(path, level + 1);

        }
        else {
            printf("%*s- %s\n", level*2, "", entry->d_name);
            aFile = setmntent(entry);
            while (NULL != (ent = getmntent(aFile))) {
                 printf("%s %s\n", ent->mnt_fsname, ent->mnt_dir);
            }
            endmntent(aFile);

        }
    } while (entry = readdir(dir));
    closedir(dir);
}

int main(void)
{
    listdir("/", 0);
    return 0;
}
于 2013-05-15T12:51:55.627 に答える