ssh2 nodejsモジュールを使用してUNIXアプリケーションに接続し、スクリプトを実行すると成功です。 今、私は複数のサーバーに1つずつ接続し、出力を取得して保存したいと考えています。 私はssh2への入力としてjsonからサーバーを1つずつ渡すためにforループを使用しようとすると、forループはサーバーからの出力を取得するブロックよりもはるかに高速に完了します。 これはまた私にハンドシェークエラーを引き起こしています。親切にここssh2が複数のサーバーに接続して出力ノードを取得
を助ける は約束の工場を使用して... SSH2で正しく非同期問題を処理するようにしてください、あなたのコードを見ずにコード
inc_cron.schedule("*/20 * * * * *", function(id) {
});
//inc_cron.js
var cronFunction = function(inputStr) {
if(appNames['applications'].length>0){
for (i = 0; i < appNames["applications"].length; i++) {
getDataFromServer(appNames["applications"][i].Name,appNames["applications"][i].hostname, appNames["applications"][i].username, appNames["applications"][i].password, appNames["applications"][i].log_path, function(err, data) {
if(err) {
logger.info("Error is in cronFunction = ", err);
} else if(data) {
output_data +=data;
} ssh.close_second();
});
}
}
}
var getDataFromServer = function(Name,hostname, username, password, log_path, cb) {
ssh.close_second();
ssh.connect_second({
host: hostname,
username: username,
password: password
}, function(err) {
if(err) {
logger.error('Err: ', err);
} else {
ssh.sftp("",'grep -o "ERROR" '+log_path+'.log.'+yr+'-'+mnth+'-* | wc -l', function(err, data) {
cb(err, data);
}); } }); }
//connect.js
SSHConnection.prototype.sftp = function(type, path, cb) {
var self = this;
var log_data = '';
self.connection2.exec(path +' ' + type, { pty: true }, function(err, stream) {
if (err) {
logger.log('SECOND :: exec error: ' + err);
}
stream.on('end', function() {
self.connection2.end(); // close parent (and this) connection
}).on('data', function(data) {
logger.info(data.toString());
});
});
};
あなたはこれまでのコードを私たちに教えてください。 –
@Holger私は今コードを追加しました... – Shashank