NodeJS fs.watch没有对Docker容器内的更改做出反应

时间:2017-02-26 20:02:54

标签: javascript node.js docker fs

以下代码的想法是对文件夹内文件的更改做出反应。当我在我的macOS上运行此代码时,一切都按原样执行。

let fs = require("fs");

let options = {
    encoding: 'buffer'
}

fs.watch('.', options, function(eventType, filename) {

    if(filename)
    {
        console.log(filename.toString());
    }

});

另一方面,在Docker容器内,代码不会对文件更改做出反应。我按以下方式运行代码:

docker run -it --rm --name $(basename $(pwd)) -v $(pwd):/app -w /app node:slim sh -c 'node index'

是否可以选择使用Docker来允许系统通知文件更改?

1 个答案:

答案 0 :(得分:5)

新答案

最初我建议Gulp(请参阅更新后的帖子底部的旧答案)。它没有用,因为你试图以编程方式使用它,当Gulp是任务运行器并且拥有自己的使用模式时,我没有描述。由于您需要特定的东西,我会为您提供非常简单,可靠的解决方案。

它使用gulp使用的模块之一gaze - 模块,每周下载量约为170万。它确实适用于每个系统。

npm install gaze --save

要使其工作,可以在根文件夹中创建index.js(它将被挂载到docker内的app文件夹中,然后按照模块README中给出的基本指令进行操作:

 var gaze = require('gaze');

 // Watch all .js files/dirs in process.cwd() 
 gaze('**/*.js', function(err, watcher) {
 // Files have all started watching 
 // watcher === this 
 console.log('Watching files...');

 // Get all watched files 
 var watched = this.watched();

 // On file changed 
 this.on('changed', function(filepath) {
  console.log(filepath + ' was changed');
 });

 // On file added 
 this.on('added', function(filepath) {
   console.log(filepath + ' was added');
 });

  // On file deleted 
 this.on('deleted', function(filepath) {
  console.log(filepath + ' was deleted');
 });

 // On changed/added/deleted 
 this.on('all', function(event, filepath) {
  console.log(filepath + ' was ' + event);
 });

  // Get watched files with relative paths 
   var files = this.relative();
  });

现在让我们运行你的命令:

docker run -it --rm --name $(basename $(pwd)) -v $(pwd):/app -w /app node sh -c 'node index'

我们所做的改变 - Linux outpud,但这也适用于Mac OS。

   blackstork@linux-uksg:~/WebstormProjects/SO/case1> docker run -it --rm --name $(basename $(pwd)) -v $(pwd):/app -w /app node sh -c 'node index'
   Watching files...
   /app/bla was changed
   /app/foobar.js was changed

旧答案。

  

你可以用gulp来做。    Gulpfile.js

 const gulp = require('gulp');

 gulp.task( 'watch' , ()=>{
    return gulp.watch(['app/**'], ['doStuff']);
 });

 gulp.task( 'doStuff', cb => {
   console.log('stuff');
   //do stuff
   cb();
  });
     

到目前为止,这种方法对我有用(当然,你可以建立更多   复杂的事情,但如果找到使用gulp confortient为不同   文件系统任务)。