Nodejs Методы 'fs' работают асинхронно - PullRequest
1 голос
/ 28 января 2020

Используя пакет fs в Node.js, я получаю неожиданные результаты, которые я надеюсь получить здесь.

У меня есть следующий код:

client.on('fileChannel', function(data){
        console.log(data);

        fs.writeFile('/sys/kernel/config/usb_gadget/kvm-gadget/UDC', "", (err) => {
            if (err) {console.log(err)};
            console.log('UDC Halted');
        });

        fs.readFile('/sys/kernel/config/usb_gadget/kvm-gadget/UDC', (err, data) => {
            if (err) {console.log(err)};
            console.log(data.toString('utf8'));
        });


        // Attach file to libcomposite
        if (data.Command === "Attach") {

            numAttachedFiles = Object.keys(fileTracker).length;

            lunNum = 'lun.'+numAttachedFiles;
                fileTracker[lunNum] = data.Argument;
                editFile = '/sys/kernel/config/usb_gadget/kvm-gadget/functions/mass_storage.usb/'+lunNum+'/file';
                fs.writeFile(editFile, __dirname+'/uploads/'+data.Argument, (err) => {
                    if (err) {console.log(err)};
                    console.log('File Attached');
                });
        }

        // Reconnect UDC
        fs.readdir('/sys/class/udc', function(err, dirContents) {
            console.log(dirContents);
                if (err) {console.log(err)};

                fs.writeFile('/sys/kernel/config/usb_gadget/kvm-gadget/UDC', dirContents[0], (err) => {
                    if (err) {console.log(err)};
                    console.log('UDC Reconnected');
                });
        });

    });

, что приводит к (вызывая ввод после //):

{ Command: 'Attach', Argument: 'jsmpeg-master.zip' } // console.log(data);
[ 'fe980000.usb' ] // console.log(dirContents);
UDC Halted // console.log('UDC Halted');
File Attached // console.log('File Attached');
[Error: EBUSY: resource busy or locked, write] {
  errno: -16,
  code: 'EBUSY',
  syscall: 'write'
} // fs.writeFile('/sys/kernel/config/usb_gadget/kvm-gadget/UDC'...if (err) {console.log(err)};
UDC Reconnected // console.log('UDC Reconnected');
fe980000.usb // console.log(data.toString('utf8'));

Сначала я подумал, что это проблема с правами доступа, вызывающая ошибку EBUSY, но затем я заметил, что порядок выводов было все не в порядке. Кроме того, я могу писать в файл просто отлично, используя echo (без sudo - и я запускаю файл app.js, используя sudo node...) в оболочке.

Любые идеи, почему все может работать асинхронно, если это действительно что происходит? Заранее спасибо

1 Ответ

1 голос
/ 28 января 2020

fs writeFile и readFile узла являются асинхронными функциями. Если вам нужны синхронные функции, вы должны использовать fs.writeFileSyn c и fs.readFileSyn c.

Обратите внимание, что это означает, что вам придется удалить существующие функции обратного вызова, которые у вас отключены, от writeFile и readFile. .

Вы можете узнать разницу между функциями syn c и non-syn c в документах Node.js здесь: https://nodejs.org/api/fs.html#fs_fs_readfilesync_path_options

...