Chinaunix

标题: keepalived中调用perl脚本,perl脚本取不到keepalived传过来的命令行参数 [打印本页]

作者: 草中宝    时间: 2015-09-01 11:56
标题: keepalived中调用perl脚本,perl脚本取不到keepalived传过来的命令行参数
perl脚本代码如下

[root@master log]# cat /tmp/JudgeWorker.pl
#!/usr/bin/perl -w

use strict;
use DBI;
use IO::Socket;

my $dest_ip;
my $dest_port;

# print @ARGV;
$dest_ip = $ARGV[0];
$dest_port = $ARGV[1];

my $log_output = "/tmp/debug.log";
open(FILE,">> $log_output");
print(FILE $dest_ip,"\t",$dest_port,"\n");
close(FILE);

exit 0;

这个JudgeWorker.pl perl脚本,在shell中单独运行是没有任何问题的,如下
[root@master tmp]# /tmp/JudgeWorker.pl 90.0.12.81 6078
[root@master tmp]# /tmp/JudgeWorker.pl 90.0.12.82 6078

运行的结果也正确,即$ARGV[0]和$ARGV[1]可以取得正确的命令行参数,详见后面的debug.log日志。但如果把这个JudgeWorker.pl perl脚本,放到keepalived中调用,
virtual_server 90.0.12.78 6078 {
    delay_loop 6
    lb_algo wlc
    lb_kind DR
    nat_mask 255.255.0.0
    persistence_timeout 600
    protocol TCP

    real_server 90.0.12.81 6078 {
        weight 100
        MISC_CHECK {
           misc_path /tmp/JudgeWorker.pl 90.0.12.81 6078
           misc_timeout 10
           misc_dynamic
        }
    }

    real_server 90.0.12.82 6078 {
        weight 100
        MISC_CHECK {
           misc_path /tmp/JudgeWorker.pl 90.0.12.82 6078
           misc_timeout 10
           misc_dynamic
        }
    }
}

然后JudgeWorker.pl 中的$ARGV[0]和$ARGV[1],就不能取得正确的命令行参数了,都是空值,参看下面的debug.log日志。
[root@master tmp]# cat debug.log
                                      <= 空值都是keepalived自动调用产生的,即$ARGV[0]和$ARGV[1]取到的值都是空
                                      <= 空值都是keepalived自动调用产生的,即$ARGV[0]和$ARGV[1]取到的值都是空
                                      <= 空值都是keepalived自动调用产生的,即$ARGV[0]和$ARGV[1]取到的值都是空
                                      <= 空值都是keepalived自动调用产生的,即$ARGV[0]和$ARGV[1]取到的值都是空
                                      <= 空值都是keepalived自动调用产生的,即$ARGV[0]和$ARGV[1]取到的值都是空
                                      <= 空值都是keepalived自动调用产生的,即$ARGV[0]和$ARGV[1]取到的值都是空
90.0.12.81      6078         <= 这个是在shell中手动执行产生的
                                      <= 空值都是keepalived自动调用产生的,即$ARGV[0]和$ARGV[1]取到的值都是空
                                      <= 空值都是keepalived自动调用产生的,即$ARGV[0]和$ARGV[1]取到的值都是空
90.0.12.82      6078         <=  这个是在shell中手动执行产生的
                                      <= 空值都是keepalived自动调用产生的,即$ARGV[0]和$ARGV[1]取到的值都是空
                                      <= 空值都是keepalived自动调用产生的,即$ARGV[0]和$ARGV[1]取到的值都是空

咋回事呢,perl脚本哪里有问题呢?还请各位高手多多指导啊。
作者: MMMIX    时间: 2015-09-01 12:28
回复 1# 草中宝


    你还是再检查下你的 keepalived 用的对不对吧
作者: 草中宝    时间: 2015-09-01 14:19
MMMIX 发表于 2015-09-01 12:28
回复 1# 草中宝


谢谢提醒,粗心啊,竟然是因为keepalived调用处少了双引号。




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2