我设置了一个Node.js服务器,我正在尝试停止在满足某些条件时启动的进程。
这是我的服务器脚本:
var app = require('express')();
var server = require('http').Server(app);
var io = require('socket.io')(server);
var fs = require('fs');
var sys = require('sys')
var exec = require('child_process').exec;
var child;
var musicDirectory = __dirname + '/music/';
var musicFiles = [];
fetchMusic();
server.listen(80);
app.get('/', function (req, res) {
res.sendfile(__dirname + '/views/index.html');
});
io.on('connection', function (socket) {
console.log("We have a new visitor.");
socket.emit('music', {files: musicFiles} );
socket.on('File to play', function (fileToPlay) {
exec("ls " + musicDirectory, function (error, stdout, stderr) {
var filesInMusicDirectory = stdout.split("n");
for (var i = 0; i < filesInMusicDirectory.length; i++) {
if (filesInMusicDirectory[i] == fileToPlay) {
if (typeof child !== "undefined") {
child.kill();
console.log("Killing process");
}
child = exec("mplayer " + "'" + musicDirectory + fileToPlay + "'");
console.log(fileToPlay + " is in directory.");
break;
}
}
if (error !== null) {
console.log('exec error: ' + error);
}
});
});
});
function fetchMusic()
{
fs.readdir(musicDirectory, function(err,data) {
for (var i = 0; i < data.length; i++) {
musicFiles.push(data[i]);
};
});
}
如您所见,我已经在第 8 行声明了一个名为 child
的变量,我像这样使用它:child = exec("mplayer " + "'" + musicDirectory + fileToPlay + "'");
.
现在,我想做的就是在满足某些条件时停止此过程,所以我正在尝试与child.kill()
一起执行此操作。
我的小实验的功能一直到我想杀死子进程的地步。它没有这样做,child.kill()
函数似乎失败了,可能是因为我误解了什么。
任何人都可以尝试帮助我理解为什么这个过程不会结束。我在写这篇文章时正在阅读文档,但有很多事情要经历。
我的问题是:为什么 kill() 函数不停止我的代码进程,我能做些什么来实现我想要的?
更新
好的,我已经摆弄了一下。我添加了树杀,因为 child.kill() 功能不起作用,并尝试将其与从子进程中提取的 Pid 一起使用,我知道该进程不是空的或未定义的,如下所示:kill = require('tree-kill')
和kill(child.pid)
。
现在这个过程,或者更确切地说,当满足相同的条件时,音乐停止了,但它不会与其余部分一起播放另一首歌。相反,在服务器控制台中输出以下内容:
Baby (metal cover by Leo Moracchioli).mp3 fed to mPlayer
undefined
STDOUT: MPlayer2 2.0-728-g2c378c7-4+b1 (C) 2000-2012 MPlayer Team
Cannot open file '/root/.mplayer/input.conf': No such file or directory
Failed to open /root/.mplayer/input.conf.
Cannot open file '/etc/mplayer/input.conf': No such file or directory
Failed to open /etc/mplayer/input.conf.
Playing /home/danlevi/Documents/NodeServer/music/Bad Blood (metal cover by Leo Moracchioli).mp3.
Detected file format: MP2/3 (MPEG audio layer 2/3) (libavformat)
[mp3 @ 0xb62803a0]max_analyze_duration 5000000 reached
[lavf] stream 0: audio (mp3), -aid 0
Clip info:
major_brand: dash
minor_version: 0
compatible_brands: iso6mp41
creation_time: 2015-09-29 08:04:29
encoder: Lavf54.20.4
Load subtitles in /home/danlevi/Documents/NodeServer/music/
Selected audio codec: MPEG 1.0/2.0/2.5 layers I, II, III [mpg123]
AUDIO: 44100 Hz, 2 ch, s16le, 128.0 kbit/9.07% (ratio: 16000->176400)
AO: [pulse] 44100Hz 2ch s16le (2 bytes per sample)
Video: no video
Starting playback...
MPlayer interrupted by signal 15 in module: unknown
Exiting... (Quit)
A: 9.1 (09.0) of 281.8 (04:41.7) 0.2%
A: 9.1 (09.0) of 281.8 (04:41.7) 0.2%
所以我觉得我已经朝着正确的方向前进了,现在我知道我有正确的过程,mPlayer确实被打断了,但新歌没有播放。
这不起作用的原因是因为没有发送正确的终止信号。
SIGTERM信号是默认信号,是用于导致程序终止的通用信号。与SIGQUIT不同,该信号可以被阻止,处理和忽略。这是礼貌地要求程序终止的正常方式。
由于应用程序应该立即终止进程,因此我们使用SIGQUIT。
调整子进程的超时和缓冲区以使其完成也很重要。