Проблема с MongoDB GridFS Сохранение файлов с Node.JS - PullRequest
2 голосов
/ 04 августа 2011

У меня есть функция сохранения файла в gridfs. Он как-то перестал работать спорадически после рефакторинга, и я потратил более 2 часов, тупо уставившись на него. Клянусь, это примерно так же, как и было. Кажется, я помню, что сначала он не работал, прежде чем я добавил close, потом он начал работать, но это может быть бессонница. По сути, проблема в том, что в коллекции db.fs.files нет записей, но куски добавляются в db.fs.chunks.

data - это буфер, загружаемый с диска через fs.readFile ()

 31    var gs = new mongodb.GridStore(this.db, filename, "w", {
 32        "chunk_size": 1024*4,
 33        metadata: {
 34          hashpath:gridfs_name,
 35          hash:hash,
 36          name: name
 39        }
 40    });
 41    gs.open(function(err,store) {
 42       gs.write(data,function(err,chunk) {
 43          //cb(err,hash,chunk);
 44          //self.close();
 45       });
 46    });

1 Ответ

6 голосов
/ 04 августа 2011

Есть несколько решений.Вы можете использовать writeBuffer, writeFile или новый простой класс сетки.Ниже приведен пример с учетом факта использования экземпляра буфера.

// You can use an object id as well as filename now
var gs = new mongodb.GridStore(this.db, filename, "w", {
  "chunk_size": 1024*4,
  metadata: {
    hashpath:gridfs_name,
    hash:hash,
    name: name
  }
});

gs.open(function(err,store) {
  // Write data and automatically close on finished write
  gs.writeBuffer(data, true, function(err,chunk) {
    // Each file has an md5 in the file structure
    cb(err,hash,chunk);
  });
});

В общем, лучшее место для начала - это тесты, охватывающие широкий профиль использования классов gridfs.Посмотри.

https://github.com/christkv/node-mongodb-native/tree/master/test/gridstore

...