溫馨提示×

如何通過Debian readdir實現文件同步

小樊
49
2025-03-22 14:54:09
欄目: 智能運維

在Debian系統中,readdir 是一個用于讀取目錄內容的系統調用。如果你想要通過 readdir 實現文件同步,你需要編寫一個程序來遍歷源目錄和目標目錄,比較它們的內容,并根據需要復制或刪除文件以使它們保持同步。

以下是一個簡單的示例,展示了如何使用 readdir 在C語言中實現基本的文件同步功能:

#include <stdio.h>
#include <stdlib.h>
#include <dirent.h>
#include <sys/stat.h>
#include <string.h>
#include <unistd.h>

// 函數聲明
void sync_directories(const char *src, const char *dest);
int is_directory(const char *path);
void copy_file(const char *src, const char *dest);
void delete_file(const char *path);
void delete_directory(const char *path);

int main(int argc, char *argv[]) {
    if (argc != 3) {
        fprintf(stderr, "Usage: %s <source_directory> <destination_directory>\n", argv[0]);
        return EXIT_FAILURE;
    }

    const char *src_dir = argv[1];
    const char *dest_dir = argv[2];

    sync_directories(src_dir, dest_dir);

    return EXIT_SUCCESS;
}

void sync_directories(const char *src, const char *dest) {
    DIR *src_dir = opendir(src);
    if (!src_dir) {
        perror("opendir");
        return;
    }

    struct dirent *entry;
    while ((entry = readdir(src_dir)) != NULL) {
        if (strcmp(entry->d_name, ".") == 0 || strcmp(entry->d_name, "..") == 0) {
            continue;
        }

        char src_path[PATH_MAX];
        char dest_path[PATH_MAX];
        snprintf(src_path, sizeof(src_path), "%s/%s", src, entry->d_name);
        snprintf(dest_path, sizeof(dest_path), "%s/%s", dest, entry->d_name);

        struct stat st;
        if (stat(src_path, &st) == -1) {
            perror("stat");
            continue;
        }

        if (S_ISDIR(st.st_mode)) {
            if (!is_directory(dest_path)) {
                printf("Creating directory %s\n", dest_path);
                mkdir(dest_path, st.st_mode);
            }
            sync_directories(src_path, dest_path);
        } else {
            if (!is_directory(dest_path)) {
                printf("Copying file %s to %s\n", src_path, dest_path);
                copy_file(src_path, dest_path);
            } else {
                printf("File %s exists in destination, skipping copy\n", dest_path);
            }
        }
    }

    closedir(src_dir);

    // 刪除目標目錄中存在而源目錄中不存在的文件
    src_dir = opendir(dest_dir);
    if (!src_dir) {
        perror("opendir");
        return;
    }

    while ((entry = readdir(src_dir)) != NULL) {
        if (strcmp(entry->d_name, ".") == 0 || strcmp(entry->d_name, "..") == 0) {
            continue;
        }

        char dest_path[PATH_MAX];
        snprintf(dest_path, sizeof(dest_path), "%s/%s", dest, entry->d_name);

        struct stat st;
        if (stat(dest_path, &st) == -1) {
            perror("stat");
            continue;
        }

        char src_path[PATH_MAX];
        snprintf(src_path, sizeof(src_path), "%s/%s", src, entry->d_name);

        if (!access(src_path, F_OK)) {
            printf("Deleting file %s as it does not exist in source\n", dest_path);
            delete_file(dest_path);
        }
    }

    closedir(src_dir);
}

int is_directory(const char *path) {
    struct stat st;
    if (stat(path, &st) == -1) {
        return 0;
    }
    return S_ISDIR(st.st_mode);
}

void copy_file(const char *src, const char *dest) {
    FILE *src_file = fopen(src, "rb");
    FILE *dest_file = fopen(dest, "wb");
    if (!src_file || !dest_file) {
        perror("fopen");
        return;
    }

    char buffer[4096];
    size_t bytes_read;
    while ((bytes_read = fread(buffer, 1, sizeof(buffer), src_file)) > 0) {
        fwrite(buffer, 1, bytes_read, dest_file);
    }

    fclose(src_file);
    fclose(dest_file);
}

void delete_file(const char *path) {
    if (remove(path) != 0) {
        perror("remove");
    }
}

void delete_directory(const char *path) {
    if (rmdir(path) != 0) {
        perror("rmdir");
    }
}

這個程序接受兩個命令行參數:源目錄和目標目錄。它會遞歸地遍歷源目錄,并在目標目錄中創建相應的文件和子目錄。如果目標目錄中存在而源目錄中不存在的文件,程序會刪除它們。

請注意,這個示例程序沒有處理所有可能的邊緣情況,例如符號鏈接、權限問題、錯誤處理等。在實際使用中,你可能需要根據具體情況對其進行擴展和改進。此外,對于大型文件或大量文件的同步,可能需要考慮更高效的文件傳輸方法。

0
亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女