【问题标题】:Intermittent EPERM error in renaming folder重命名文件夹时出现间歇性 EPERM 错误
【发布时间】:2019-09-08 14:13:24
【问题描述】:


我正在使用 Multer 在我的 fs 中上传图像。 Multer 不允许您在 fs 中动态设置位置,因此我总是在同一个文件夹中上传,然后使用 fs.renamesynch 更改文件夹的名称。
我使用的是同步版本,因为我觉得我必须等待任务结束,否则我在后面的任务中会出现需要与重命名功能同步的问题。
但是,我有间歇性错误,我不知道如何解决它
这是我的代码:

router.post("/changeprofile", ensureAuthenticated, (req, res) => {
  upload(req, res, err => {
    if (err) {
      res.render("changeprofile", { msg: err });
    } else {
      if (req.file == undefined) {
        res.render("changeprofile", { msg: "Error: No file Selected!" });
      } else {
        res.render("changeprofile", {
          msg: "File Uploaded!",
          file: `uploads/${req.file.filename}`
        });
        fsextra.removeSync("./public/profile" + id);
        if (err) console.log(err);
        else console.log("Deleted old folder");
        glob("./public/uploads/profile.*", (err, matches) => {
          if (err) console.log(err);
          else {
            console.log("renaming folder...");
            fs.renameSync("./public/uploads", "./public/profile/" + id);
            if (err) console.log(err);
            else {
              fs.mkdir("./public/uploads", err => {
                if (err) console.log(err);
                else
                  console.log(
                    "------------------FOLDER RECREATED---------------------------"
                  );
              });
            }
          }
        });
      }
    }
  });
});



这是我得到的错误:
错误:EPERM:不允许操作,重命名 './public/uploads' -> './public/profile/21' 在 Object.renameSync (fs.js:593:3) 在 glob (C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\routes\users.js:558:19) 在 f (C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\once\once.js:25:25) 在全球。 (C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\glob\glob.js:151:7) 在 Glob.emit (events.js:189:13) 在 Glob._finish (C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\glob\glob.js:197:8) 完成(C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\glob\glob.js:182:14) 在 Glob._processReaddir2 (C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\glob\glob.js:434:12) 在 C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\glob\glob.js:371:17 在 RES (C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\inflight\inflight.js:31:16) 在 f (C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\once\once.js:25:25) 在 Glob._readdirEntries (C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\glob\glob.js:578:10) 在 C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\glob\glob.js:555: 12 在 go$readdir$cb (C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\graceful-fs\graceful-fs.js:162:14) 在 FSReqWrap.args [as oncomplete] (fs.js:140:20)

【问题讨论】:

    标签: node.js file-permissions fs multer


    【解决方案1】:

    即使我没有得到答案,我认为我已经找到了解决方案: 我认为问题是这样的。当您使用同步方法时,您可能认为该节点也将与操作系统同步,以删除和重命名文件系统中的文件夹。但似乎不是:它会用一些内核函数调用操作系统,但是 fs 的管理是由 os 进行的,并且节点不会等待函数的返回,即使您使用的是同步模式。例如,可能会发生所有 I/O 操作都将被缓冲然后一起执行以提高操作系统性能的情况。 正确的想法是在执行 fs 操作之后刷新 os 缓存。但是,使用 fs-extra 和 graceful-fs 我认为它现在可以工作了:

    
    
    
    var fs = require("graceful-fs");
    const fsextra = require("fs-extra");
    fs.gracefulify(realfs);
    
    router.post("/changeprofile", ensureAuthenticated, (req, res) => {
      upload(req, res, err => {
        if (err) {
          res.render("changeprofile", { msg: err });
        } else {
          if (req.file == undefined) {
            res.render("changeprofile", { msg: "Error: No file Selected!" });
          } else {
            res.render("changeprofile", {
              msg: "File Uploaded!",
              file: `uploads/${req.file.filename}`
            });
            var path = "./public/profile/" + id;
            if (fsextra.existsSync(path)){
              fsextra.removeSync(path);
            }
            if (err) console.log(err);
            else console.log("Deleted old folder");
            glob("./public/uploads/profile.*", (err, matches) => {
              if (err) console.log(err);
              else {
                console.log("renaming folder...");
                fs.renameSync("./public/uploads", "./public/profile/" + id);
                if (err) console.log(err);
                else {
                  fs.mkdir("./public/uploads", err => {
                    if (err) console.log(err);
                    else
                      console.log(
                        "------------------FOLDER RECREATED---------------------------"
                      );
                  });
                }
              }
            });
          }
        }
      });
    });
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    

    【讨论】:

      猜你喜欢
      • 2021-04-10
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2021-05-16
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2019-01-04
      相关资源
      最近更新 更多