當前位置: 首頁>>代碼示例>>PHP>>正文


PHP unix::KILL_PROCESS方法代碼示例

本文整理匯總了PHP中unix::KILL_PROCESS方法的典型用法代碼示例。如果您正苦於以下問題:PHP unix::KILL_PROCESS方法的具體用法?PHP unix::KILL_PROCESS怎麽用?PHP unix::KILL_PROCESS使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在unix的用法示例。


在下文中一共展示了unix::KILL_PROCESS方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: uninstall

function uninstall()
{
    $unix = new unix();
    $sock = new sockets();
    build_progress("{uninstall}", 15);
    $pid = sealion_pid();
    if ($unix->process_exists($pid)) {
        for ($i = 0; $i < 6; $i++) {
            build_progress("{stop_service} {$i}/5", 30);
            $unix->KILL_PROCESS($pid, 9);
            $pid = sealion_pid();
            if ($unix->process_exists($pid)) {
                break;
            }
        }
    }
    build_progress("{uninstall}", 50);
    chdir("/usr/local/sealion-agent");
    system("cd /usr/local/sealion-agent");
    system("./uninstall.sh");
    chdir("/root");
    system("cd /root");
    $unix = new unix();
    $rm = $unix->find_program("rm");
    if (is_dir("/usr/local/sealion-agent")) {
        shell_exec("rm -rf /usr/local/sealion-agent");
    }
    build_progress("{uninstall} {done}", 100);
}
開發者ID:articatech,項目名稱:artica,代碼行數:29,代碼來源:exec.sealion.php

示例2: reload

function reload()
{
    $unix = new unix();
    $pidfile = "/etc/artica-postfix/pids/" . basename(__FILE__) . "." . __FUNCTION__ . ".pid";
    $pid = $unix->get_pid_from_file($pidfile);
    if ($unix->process_exists($pid, basename(__FILE__))) {
        $time = $unix->PROCCESS_TIME_MIN($pid);
        if ($GLOBALS["OUTPUT"]) {
            echo "Starting......: " . date("H:i:s") . " [INIT]: {$GLOBALS["TITLENAME"]}: Already Artica task running PID {$pid} since {$time}mn\n";
        }
        return;
    }
    @file_put_contents($pidfile, getmypid());
    $pid = PID_NUM();
    if (!$unix->process_exists($pid)) {
        start(true);
        return;
    }
    buildconfig();
    BuildSSLTables();
    if ($GLOBALS["OUTPUT"]) {
        echo "Starting......: " . date("H:i:s") . " [INIT]: {$GLOBALS["TITLENAME"]}: Reloading PID {$pid}\n";
    }
    $unix->KILL_PROCESS($pid, 1);
}
開發者ID:brucewu16899,項目名稱:1.6.x,代碼行數:25,代碼來源:exec.wifidog.php

示例3: KillSquid

function KillSquid()
{
    $unix = new unix();
    $pidof = $unix->find_program("pidof");
    $kill = $unix->find_program("kill");
    if (strlen($pidof) < 4) {
        return;
    }
    exec("{$pidof} {$GLOBALS["SQUIDBIN"]}", $results);
    $f = explode(" ", @implode("", $results));
    while (list($num, $val) = each($f)) {
        $val = trim($val);
        if (!is_numeric($val)) {
            continue;
        }
        echo "Starting......: " . date("H:i:s") . " stopping pid {$val}\n";
        $unix->KILL_PROCESS($val, 9);
        usleep(10000);
    }
}
開發者ID:brucewu16899,項目名稱:1.6.x,代碼行數:20,代碼來源:exec.squid.php

示例4: repair_locks

function repair_locks()
{
    $Myfile = basename(__FILE__);
    $timeFile = "/etc/artica-postfix/pids/{$Myfile}." . __FUNCTION__ . ".time";
    $pidFile = "/etc/artica-postfix/pids/{$Myfile}." . __FUNCTION__ . ".pid";
    $unix = new unix();
    $pid = $unix->get_pid_from_file($pidFile);
    if ($unix->process_exists($pid, $Myfile)) {
        writelogs("Die, already process {$pid} running ", __FUNCTION__, __FILE__, __LINE__);
        return;
    }
    $time = $unix->file_time_min($timeFile);
    if ($time < 5) {
        writelogs("Die, No more than 5mn ", __FUNCTION__, __FILE__, __LINE__);
        return;
    }
    @unlink($timeFile);
    @mkdir(dirname($timeFile), 0755, true);
    @file_put_contents($timeFile, time());
    @file_put_contents($pidFile, getmypid());
    echo "Starting......: " . date("H:i:s") . " Stopping postfix\n";
    shell_exec("{$GLOBALS["postfix"]} stop");
    $daemon_directory = $unix->POSTCONF_GET("daemon_directory");
    $queue_directory = $unix->POSTCONF_GET("queue_directory");
    echo "Starting......: " . date("H:i:s") . " Daemon directory: {$daemon_directory}\n";
    echo "Starting......: " . date("H:i:s") . " Queue directory.: {$queue_directory}\n";
    $pid = $unix->PIDOF("{$daemon_directory}/master", true);
    echo "Starting......: " . date("H:i:s") . " Process \"{$daemon_directory}/master\" PID:\"{$pid}\"\n";
    for ($i = 0; $i < 10; $i++) {
        if (is_numeric($pid)) {
            if ($pid > 5) {
                echo "Starting......: " . date("H:i:s") . " Killing bad pid {$pid}\n";
                $unix->KILL_PROCESS($pid, 9);
                sleep(1);
            }
        } else {
            echo "Starting......: " . date("H:i:s") . " No {$daemon_directory}/master ghost process\n";
            break;
        }
        $pid = $unix->PIDOF("{$daemon_directory}/master");
        echo "Starting......: " . date("H:i:s") . " Process \"{$daemon_directory}/master\" PID:\"{$pid}\"\n";
    }
    if (file_exists("{$daemon_directory}/master.lock")) {
        echo "Starting......: " . date("H:i:s") . " Delete {$daemon_directory}/master.lock\n";
        @unlink("{$daemon_directory}/master.lock");
    }
    if (file_exists("{$queue_directory}/pid/master.pid")) {
        echo "Starting......: " . date("H:i:s") . " Delete {$queue_directory}/pid/master.pid\n";
        @unlink("{$queue_directory}/pid/master.pid");
    }
    if (file_exists("{$queue_directory}/pid/inet.127.0.0.1:33559")) {
        echo "Starting......: " . date("H:i:s") . " {$queue_directory}/pid/inet.127.0.0.1:33559\n";
        @unlink("{$queue_directory}/pid/inet.127.0.0.1:33559");
    }
    echo "Starting......: " . date("H:i:s") . " Starting postfix\n";
    exec("{$GLOBALS["postfix"]} start -v 2>&1", $results);
    while (list($template, $nothing) = each($results)) {
        echo "Starting......: " . date("H:i:s") . " Starting postfix {$nothing}\n";
    }
}
開發者ID:articatech,項目名稱:artica,代碼行數:60,代碼來源:exec.postfix.maincf.php

示例5: mQuotaWebFilter

function mQuotaWebFilter()
{
    $unix = new unix();
    $pidfile = "/etc/artica-postfix/pids/exec.squid.stats.hours.php.mQuotaWebFilter.pid";
    $timefile = "/etc/artica-postfix/pids/exec.squid.stats.hours.php.mQuotaWebFilter.time";
    $sock = new sockets();
    $SquidPerformance = intval($sock->GET_INFO("SquidPerformance"));
    if ($SquidPerformance > 1) {
        die;
    }
    $pid = $unix->get_pid_from_file($pidfile);
    if (!$GLOBALS["FORCE"]) {
        if ($pid < 100) {
            $pid = null;
        }
        $unix = new unix();
        if ($unix->process_exists($pid, basename(__FILE__))) {
            $rpcessTime = $unix->PROCCESS_TIME_MIN($pid);
            if ($GLOBALS["VERBOSE"]) {
                echo "Already executed pid {$pid} since {$rpcessTime}Mn\n";
            }
            if ($rpcessTime < 10) {
                return;
            }
            $unix->KILL_PROCESS($pid, 9);
        }
        $timeexec = $unix->file_time_min($timefile);
        if ($timeexec < 30) {
            return;
        }
        $mypid = getmypid();
        @file_put_contents($pidfile, $mypid);
    }
    build_last_hour();
    $ipClass = new IP();
    if ($GLOBALS["VERBOSE"]) {
        echo "Time File: {$timefile}\n";
    }
    $ARRAY["TIME_BUILD"] = time();
    $q = new mysql_squid_builder();
    $influx = new influx();
    $date_from = InfluxQueryFromUTC(strtotime("-1 hour"));
    $sql = "SELECT SUM(SIZE) as size,USERID,IPADDR,MAC,CATEGORY FROM  access_log GROUP BY time(1h) ,USERID,IPADDR,MAC,CATEGORY WHERE time > {$date_from}s";
    if ($GLOBALS["VERBOSE"]) {
        echo "{$sql}\n";
    }
    $main = $influx->QUERY_SQL($sql);
    foreach ($main as $row) {
        $CATEGORY = $row->CATEGORY;
        $USERID = strtolower($row->USERID);
        $IPADDR = $row->IPADDR;
        $MAC = $row->MAC;
        $size = intval($row->size);
        if ($size == 0) {
            continue;
        }
        if ($CATEGORY != null) {
            if (!isset($ARRAY["categories"][$CATEGORY]["HOUR"][$USERID])) {
                $ARRAY["categories"][$CATEGORY]["HOUR"][$USERID] = $size;
            } else {
                $size_old = intval($ARRAY["categories"][$CATEGORY]["HOUR"][$USERID]);
                $size_old = $size_old + $size;
                $ARRAY["categories"][$CATEGORY]["HOUR"][$USERID] = $size_old;
            }
            if (!isset($ARRAY["categories"][$CATEGORY]["HOUR"][$IPADDR])) {
                $ARRAY["categories"][$CATEGORY]["HOUR"][$IPADDR] = $size;
            } else {
                $size_old = $ARRAY["categories"][$CATEGORY]["HOUR"][$IPADDR];
                $size_old = $size_old + $size;
                if ($size_old == 0) {
                    echo "Warning {$CATEGORY}/{$IPADDR} {$ARRAY["categories"][$CATEGORY]["HOUR"][$IPADDR]} + {$size} = 0\n";
                }
                $ARRAY["categories"][$CATEGORY]["HOUR"][$IPADDR] = $size_old;
            }
            if (!isset($ARRAY["categories"][$CATEGORY]["HOUR"][$MAC])) {
                $ARRAY["categories"][$CATEGORY]["HOUR"][$MAC] = $size;
            } else {
                $size_old = $ARRAY["categories"][$CATEGORY]["HOUR"][$MAC];
                $size_old = $size_old + $size;
                $ARRAY["categories"][$CATEGORY]["HOUR"][$MAC] = $size_old;
            }
        }
        if (!isset($ARRAY["UID"][$USERID]["HOUR"])) {
            $ARRAY["UID"][$USERID]["HOUR"] = $size;
        } else {
            $size_old = $ARRAY["UID"][$USERID]["HOUR"];
            $size_old = $size_old + $size;
            $ARRAY["UID"][$USERID]["HOUR"] = $size_old;
        }
        if (!isset($ARRAY["IPADDR"][$IPADDR]["HOUR"])) {
            $ARRAY["IPADDR"][$IPADDR]["HOUR"] = $size;
        } else {
            $size_old = $ARRAY["IPADDR"][$IPADDR]["HOUR"];
            $size_old = $size_old + $size;
            $ARRAY["IPADDR"][$IPADDR]["HOUR"] = $size_old;
        }
        if ($ipClass->IsvalidMAC($MAC)) {
            if (!isset($ARRAY["MAC"][$MAC]["HOUR"])) {
                $ARRAY["MAC"][$MAC]["HOUR"] = $size;
            } else {
//.........這裏部分代碼省略.........
開發者ID:BillTheBest,項目名稱:1.6.x,代碼行數:101,代碼來源:exec.squid.quotas.php

示例6: logs_urgency

function logs_urgency($aspid = false)
{
    $unix = new unix();
    $TimeFile = "/etc/artica-postfix/pids/" . basename(__FILE__) . "." . __FUNCTION__ . ".time";
    $Pidfile = "/etc/artica-postfix/pids/" . basename(__FILE__) . "." . __FUNCTION__ . ".pid";
    if ($GLOBALS["VERBOSE"]) {
        echo "TimeFile: {$TimeFile}\n";
    }
    if ($GLOBALS["VERBOSE"]) {
        echo "Pidfile: {$Pidfile}\n";
    }
    if (!$GLOBALS["FORCE"]) {
        $timefile = $unix->file_time_min($TimeFile);
        if ($timefile < 60) {
            return;
        }
    }
    if ($aspid) {
        $pid = $unix->get_pid_from_file($Pidfile);
        if ($unix->process_exists($pid, basename(__FILE__))) {
            $timeprc = $unix->PROCCESS_TIME_MIN($pid);
            if ($timeprc > 60) {
                $unix->KILL_PROCESS($pid, 9);
            } else {
                if ($GLOBALS["VERBOSE"]) {
                    echo "Aborting Task already running pid {$pid} " . __FUNCTION__ . "()\n";
                }
                return;
            }
        }
        @file_put_contents($Pidfile, getmypid());
    }
    $df = $unix->find_program("df");
    $php = $unix->LOCATE_PHP5_BIN();
    exec("{$df} -h /var/log 2>&1", $results);
    while (list($index, $line) = each($results)) {
        if (!preg_match("#^(.+?)\\s+([0-9\\.,]+)([A-Z])\\s+([0-9\\.,]+).*?\\s+([0-9\\.,]+)%\\s+#", $line, $re)) {
            continue;
        }
        $purc = $re[5];
        break;
    }
    if ($purc < 100) {
        return;
    }
    $echo = $unix->find_program("echo");
    $logf["artica-router.log"] = true;
    $logf["artica-smtp.log"] = true;
    $logf["auth.log"] = true;
    $logf["daemon.log"] = true;
    $logf["debug"] = true;
    $logf["dpkg.log"] = true;
    $logf["fetchmail.log"] = true;
    $logf["kern.log"] = true;
    $logf["mail.err"] = true;
    $logf["mail.log"] = true;
    $logf["mail.warn"] = true;
    $logf["messages"] = true;
    $logf["syslog"] = true;
    $logf["user.log"] = true;
    $logf["lighttpd/access.log"] = true;
    $logf["squid/store.log"] = true;
    $logf["apache2/unix-varrunnginx-authenticator.sock/nginx.access.log"] = true;
    $logf["apache2/unix-varrunnginx-authenticator.sock/nginx.error.log"] = true;
    $logf["artica-postfix/framework.log"] = true;
    $logf["samba/log.winbindd"] = true;
    $logf["samba/log.winbindd.old"] = true;
    $logf["clamav/clamav.log"] = true;
    $logf["clamav/clamd.log"] = true;
    $logf["clamav/freshclam.log"] = true;
    $sock = new sockets();
    $BaseWorkDirUrgency = "/home/artica/squidlogs_urgency";
    $LogsRotateDefaultSizeRotation = $sock->GET_INFO("LogsRotateDefaultSizeRotation");
    if (!is_numeric($LogsRotateDefaultSizeRotation)) {
        $LogsRotateDefaultSizeRotation = 100;
    }
    $LogRotatePath = $sock->GET_INFO("LogRotatePath");
    if ($LogRotatePath == null) {
        $LogRotatePath = "/home/logrotate";
    }
    $LogRotatePath = "{$LogRotatePath}/work/cache_logs";
    while (list($filname, $line) = each($logf)) {
        $path = "/var/log/{$filname}";
        if (!is_file($path)) {
            continue;
        }
        shell_exec("{$echo} \" \" > {$path} 2>&1");
    }
}
開發者ID:brucewu16899,項目名稱:1.6.x,代碼行數:89,代碼來源:exec.clean.logs.php

示例7: build

function build()
{
    $timefile = "/etc/artica-postfix/pids/exec.squid.rotate.php.build.time";
    $pidfile = "/etc/artica-postfix/pids/" . basename(__FILE__) . "." . __FUNCTION__ . ".pid";
    // /etc/artica-postfix/pids/exec.squid.rotate.php.build.time
    $sock = new sockets();
    $unix = new unix();
    $ls = $unix->find_program("ls");
    $pid = $unix->PIDOF_PATTERN(basename(__FILE__));
    $MyPid = getmypid();
    if ($MyPid != $pid) {
        if ($unix->process_exists($pid)) {
            $timeFile = $unix->PROCESS_TIME_INT($pid);
            $pidCmdline = @file_get_contents("/proc/{$pid}/cmdline");
            if ($timeFile < 30) {
                echo "Already PID {$pid} is running since {$timeFile}Mn\n";
                squid_admin_mysql(1, "[LOG ROTATION]: Skip task, already running {$pid} since {$timeFile}Mn", "Running: {$pidCmdline}", __FILE__, __LINE__);
                die;
            } else {
                squid_admin_mysql(1, "[LOG ROTATION]: Killing old task {$pid} running more than 30mn ({$timeFile}Mn)", "Running: {$pidCmdline}", __FILE__, __LINE__);
                $unix->KILL_PROCESS($pid);
            }
        }
    }
    @file_put_contents($pidfile, getmypid());
    if (!$GLOBALS["FORCE"]) {
        $time = $unix->file_time_min($timefile);
        if ($time < 60) {
            echo "Only each 60mn\n";
            die;
        }
        @unlink($timefile);
        @file_put_contents($timefile, time());
    }
    $syslog = new mysql_storelogs();
    $SquidLogRotateFreq = intval($sock->GET_INFO("SquidLogRotateFreq"));
    if ($SquidLogRotateFreq < 10) {
        $SquidLogRotateFreq = 1440;
    }
    $LastRotate = $unix->file_time_min("/etc/artica-postfix/pids/squid-rotate-cache.time");
    $LogsRotateDefaultSizeRotation = $sock->GET_INFO("LogsRotateDefaultSizeRotation");
    $SquidRotateOnlySchedule = intval($sock->GET_INFO("SquidRotateOnlySchedule"));
    if (!is_numeric($LogsRotateDefaultSizeRotation)) {
        $LogsRotateDefaultSizeRotation = 100;
    }
    $BackupMaxDaysDir = $sock->GET_INFO("BackupMaxDaysDir");
    if ($BackupMaxDaysDir == null) {
        $BackupMaxDaysDir = "/home/logrotate_backup";
    }
    $BackupSquidLogsUseNas = intval($sock->GET_INFO("BackupSquidLogsUseNas"));
    $SquidRotateAutomount = intval($sock->GET_INFO("SquidRotateAutomount"));
    $SquidRotateClean = intval($sock->GET_INFO("SquidRotateClean"));
    $SquidRotateAutomountRes = $sock->GET_INFO("SquidRotateAutomountRes");
    $SquidRotateAutomountFolder = $sock->GET_INFO("SquidRotateAutomountFolder");
    if ($SquidRotateAutomount == 1) {
        shell_exec("{$ls} /automounts/{$SquidRotateAutomountRes} >/dev/null 2>&1");
        if (ifdirMounted("/automounts/{$SquidRotateAutomountRes}")) {
            $BackupSquidLogsUseNas = 0;
            $BackupMaxDaysDir = "/automounts/{$SquidRotateAutomountRes}/{$SquidRotateAutomountFolder}";
        } else {
            $syslog->events("/automounts/{$SquidRotateAutomountRes} not mounted", __FUNCTION__, __LINE__);
            squid_admin_mysql(1, "[ROTATE],Auto-mount {$SquidRotateAutomountRes} not mounted", null, __FILE__, __LINE__);
        }
    }
    $BackupMaxDaysDir = str_replace("//", "/", $BackupMaxDaysDir);
    $BackupMaxDaysDir = str_replace("\\", "/", $BackupMaxDaysDir);
    if (!is_dir($BackupMaxDaysDir)) {
        @mkdir($BackupMaxDaysDir, 0755, true);
    }
    if (!is_dir($BackupMaxDaysDir)) {
        $syslog->events("{$BackupMaxDaysDir} not such directory or permission denied", __FUNCTION__, __LINE__);
        squid_admin_mysql(1, "[ROTATE],{$BackupMaxDaysDir} not such directory or permission denied", null, __FILE__, __LINE__);
        if ($SquidRotateAutomount == 1) {
            $BackupMaxDaysDir = $sock->GET_INFO("BackupMaxDaysDir");
            if ($BackupMaxDaysDir == null) {
                $BackupMaxDaysDir = "/home/logrotate_backup";
            }
            if (!is_dir($BackupMaxDaysDir)) {
                @mkdir($BackupMaxDaysDir, 0755, true);
            }
            $syslog->events("Return back to {$BackupMaxDaysDir}", __FUNCTION__, __LINE__);
        } else {
            return;
        }
    }
    $php = $unix->LOCATE_PHP5_BIN();
    $hostname = $unix->hostname_g();
    $InFluxBackupDatabaseDir = $sock->GET_INFO("InFluxBackupDatabaseDir");
    if ($InFluxBackupDatabaseDir == null) {
        $InFluxBackupDatabaseDir = "/home/artica/influx/backup";
    }
    $LogRotatePath = $sock->GET_INFO("LogRotatePath");
    if ($LogRotatePath == null) {
        $LogRotatePath = "/home/logrotate";
    }
    $LogRotateAccess = "{$LogRotatePath}/access";
    $LogRotateTail = "{$LogRotatePath}/tail";
    $LogRotateCache = "{$LogRotatePath}/cache";
    $syslog->events("Launch rotation only by schedule.: {$SquidRotateOnlySchedule}", __FUNCTION__, __LINE__);
    $syslog->events("SquidLogRotateFreq...............: {$SquidLogRotateFreq}Mn", __FUNCTION__, __LINE__);
//.........這裏部分代碼省略.........
開發者ID:articatech,項目名稱:artica,代碼行數:101,代碼來源:exec.squid.rotate.php

示例8: reload_stats

function reload_stats()
{
    $unix = new unix();
    $sock = new sockets();
    $pidfile = "/etc/artica-postfix/pids/" . basename(__FILE__) . "." . __FUNCTION__ . ".pid";
    $pid = $unix->get_pid_from_file($pidfile);
    if ($unix->process_exists($pid, basename(__FILE__))) {
        $time = $unix->PROCCESS_TIME_MIN($pid);
        if ($GLOBALS["OUTPUT"]) {
            echo "Reloading.....: " . date("H:i:s") . " [INIT]: {$GLOBALS["TITLENAME"]} Already Artica task running PID {$pid} since {$time}mn\n";
        }
        return;
    }
    @file_put_contents($pidfile, getmypid());
    $kavicapserverEnabled = intval($sock->GET_INFO("kavicapserverEnabled"));
    if ($kavicapserverEnabled == 0) {
        if ($GLOBALS["OUTPUT"]) {
            echo "Reloading......: " . date("H:i:s") . " [INIT]: {$GLOBALS["TITLENAME"]} Not enabled,stop it\n";
        }
        stop();
        return;
    }
    $pid = PID_NUM();
    if (!$unix->process_exists($pid)) {
        if ($GLOBALS["OUTPUT"]) {
            echo "Reloading.....: " . date("H:i:s") . " [INIT]: {$GLOBALS["TITLENAME"]} Not running, start it\n";
        }
        start();
        return;
    }
    $timepid = $unix->PROCCESS_TIME_MIN($pid);
    if ($GLOBALS["OUTPUT"]) {
        echo "Reloading.....: " . date("H:i:s") . " [INIT]: {$GLOBALS["TITLENAME"]} TTL of {$timepid}Mn for statistics\n";
    }
    $unix->KILL_PROCESS($pid, 12);
}
開發者ID:brucewu16899,項目名稱:1.6.x,代碼行數:36,代碼來源:exec.kav4proxy.service.php

示例9: unix

     echo @implode("\n", $conf);
     die;
 }
 if ($argv[1] == "--functions") {
     $arr = get_defined_functions();
     print_r($arr);
     die;
 }
 if ($argv[1] == "--all-squid") {
     $unix = new unix();
     $processes = $unix->PIDOF_PATTERN_ALL(basename(__FILE__) . ".*?{$argv[1]}", true);
     events(count($processes) . " Running  " . @implode(";", $processes), "{$argv[1]}", __LINE__);
     if (count($processes) > 2) {
         while (list($num, $pid) = each($processes)) {
             events("Killing pid {$pid}  ", "MAIN", __LINE__);
             $unix->KILL_PROCESS($pid, 9);
         }
         $processes = $unix->PIDOF_PATTERN_ALL(basename(__FILE__) . ".*?{$argv[1]}", true);
         events(count($processes) . " Running  " . @implode(";", $processes), "{$argv[1]}", __LINE__);
     }
     if (count($processes) > 0) {
         events("ALL_SQUID: Processes already exists, aborting", "{$argv[1]}", __LINE__);
         die;
     }
     $cachefile = "/usr/share/artica-postfix/ressources/databases/ALL_SQUID_STATUS";
     $GLOBALS["DISABLE_WATCHDOG"] = true;
     $TimeFile = $cachefile;
     if ($GLOBALS["SCHEDULE_ID"] > 0) {
         if ($unix->file_time_min($TimeFile) > 5) {
             $php = $unix->LOCATE_PHP5_BIN();
             $nohup = $unix->find_program("nohup");
開發者ID:BillTheBest,項目名稱:1.6.x,代碼行數:31,代碼來源:exec.status.php

示例10: reload

function reload()
{
    $unix = new unix();
    $sock = new sockets();
    $pidfile = "/etc/artica-postfix/pids/" . basename(__FILE__) . "." . __FUNCTION__ . ".pid";
    $pid = $unix->get_pid_from_file($pidfile);
    if ($unix->process_exists($pid, basename(__FILE__))) {
        $time = $unix->PROCCESS_TIME_MIN($pid);
        if ($GLOBALS["OUTPUT"]) {
            echo "Reloading.....: " . date("H:i:s") . " [INIT]: {$GLOBALS["TITLENAME"]} Already Artica task running PID {$pid} since {$time}mn\n";
        }
        return;
    }
    @file_put_contents($pidfile, getmypid());
    $pid = PID_NUM();
    if (!$unix->process_exists($pid)) {
        if ($GLOBALS["OUTPUT"]) {
            echo "Reloading.....: " . date("H:i:s") . " [INIT]: {$GLOBALS["TITLENAME"]} Not running, start it\n";
        }
        start();
        return;
    }
    build();
    $timepid = $unix->PROCCESS_TIME_MIN($pid);
    if ($GLOBALS["OUTPUT"]) {
        echo "Reloading.....: " . date("H:i:s") . " [INIT]: {$GLOBALS["TITLENAME"]} TTL of {$timepid}Mn\n";
    }
    $unix->KILL_PROCESS($pid, 1);
    $echo = $unix->find_program("echo");
    $sock = new sockets();
    $ip_queue_maxlen = intval($sock->GET_INFO("ip_queue_maxlen"));
    if ($ip_queue_maxlen == 0) {
        $ip_queue_maxlen = 2048;
    }
    if (is_file("/proc/sys/net/ipv4/ip_queue_maxlen")) {
        shell_exec("{$echo} \"{$ip_queue_maxlen}\" >/proc/sys/net/ipv4/ip_queue_maxlen");
    } else {
        if ($GLOBALS["OUTPUT"]) {
            echo "Starting......: " . date("H:i:s") . " [INIT]: {$GLOBALS["TITLENAME"]} /proc/sys/net/ipv4/ip_queue_maxlen no such file.\n";
        }
    }
}
開發者ID:BillTheBest,項目名稱:1.6.x,代碼行數:42,代碼來源:exec.l7filter.php

示例11: if_process_import_exists

function if_process_import_exists($filename, $killbefore = 0)
{
    $unix = new unix();
    $RESULTS = FALSE;
    $pgrep = $unix->find_program("pgrep");
    exec("{$pgrep} -l -f \"bzip2.*{$filename}\" 2>&1", $results);
    while (list($index, $line) = each($results)) {
        $line = trim($line);
        if ($line == null) {
            continue;
        }
        if (preg_match("#pgrep#", $line)) {
            continue;
        }
        if (!preg_match("#^([0-9]+)#", $line, $re)) {
            continue;
        }
        $TTL = $unix->PROCESS_TTL($re[1]);
        $RESULTS = true;
        if ($GLOBALS["VERBOSE"]) {
            echo "{$re[1]} - {$TTL}Mn\n";
        }
        if ($killbefore > 0) {
            if ($TTL < $killbefore) {
                if ($GLOBALS["VERBOSE"]) {
                    echo "KILL!!! {$re[1]} - {$TTL}Mn\n";
                }
                $unix->KILL_PROCESS($re[1], 9);
            }
        }
        Export_logs("{$filename} is already processed by PID {$re[1]} since {$TTL}Mn");
    }
    return $RESULTS;
}
開發者ID:brucewu16899,項目名稱:1.6.x,代碼行數:34,代碼來源:exec.squid.stats.central.php

示例12: nmap_scan_pingnet

function nmap_scan_pingnet()
{
    nmap_scan_pingnet_progress("{ping_networks}", 5);
    $unix = new unix();
    $sock = new sockets();
    $nmap = $unix->find_program("nmap");
    $nohup = $unix->find_program("nohup");
    $NmapTimeOutPing = intval($sock->GET_INFO("NmapTimeOutPing"));
    $NmapFastScan = intval($sock->GET_INFO("NmapFastScan"));
    if ($NmapTimeOutPing == 0) {
        $NmapTimeOutPing = 30;
    }
    $MaxTime = 10;
    $net = new networkscanner();
    while (list($num, $maks) = each($net->networklist)) {
        if (trim($maks) == null) {
            continue;
        }
        $hash[$maks] = $maks;
    }
    while (list($num, $maks) = each($hash)) {
        if (!$net->Networks_disabled[$maks]) {
            if ($GLOBALS["VERBOSE"]) {
                echo "Network: {$maks} OK\n";
            }
            $cdir[] = $maks;
        }
    }
    if (count($cdir) == 0) {
        nmap_scan_pingnet_progress("No network", 110);
        return;
    }
    $nets = trim(@implode(" ", $cdir));
    nmap_scan_pingnet_progress("Scanning Networks {$nets}", 10);
    echo "Scanning Networks {$nets}\n";
    $TMP = $unix->FILE_TEMP();
    $NmapTimeOutPing++;
    $prc = 10;
    nmap_scan_pingnet_progress("{fast_scan}: {$NmapFastScan}", 6);
    while (list($num, $cd) = each($cdir)) {
        $prc = $prc + 5;
        if ($prc > 99) {
            $prc = 99;
        }
        nmap_scan_pingnet_progress("Scanning Network {$cd}", $prc);
        $CONTINUE = true;
        if ($NmapFastScan == 1) {
            nmap_scan_pingnet_progress("{$cd} -> arp-scan", $prc);
            $f1 = arp_scanner($cdir);
            if (count($f1) > 0) {
                while (list($num, $line) = each($f1)) {
                    $f[] = $line;
                }
                $CONTINUE = false;
            }
        }
        if ($CONTINUE) {
            echo "{$nmap} -T4 -sP -oX {$TMP} {$cd}\n";
            system("{$nohup} {$nmap} -T4 -sP -oX {$TMP} {$cd} >/dev/null 2>&1 &");
            for ($i = 1; $i < $NmapTimeOutPing; $i++) {
                $pid = $unix->PIDOF("{$nmap}");
                if (!$unix->process_exists($pid)) {
                    break;
                }
                echo "Waiting scanner PID {$pid} {$i}/{$NmapTimeOutPing}\n";
                sleep(1);
            }
            $pid = $unix->PIDOF("{$nmap}");
            if ($unix->process_exists($pid)) {
                echo "Timed-Out scanner PID {$pid}\n";
                nmap_scan_pingnet_progress("{$cd} Timed Out!!", $prc);
                sleep(3);
                $unix->KILL_PROCESS($pid, 9);
                continue;
            }
            $date = date("Y-m-d H:i:s");
            $xmlstr = @file_get_contents($TMP);
            @unlink($TMP);
            $XMLZ = new SimpleXMLElement($xmlstr);
            foreach ($XMLZ->host as $Hostz) {
                $ipaddr = mysql_escape_string2($Hostz->address[0]["addr"][0]);
                $mac = mysql_escape_string2($Hostz->address[1]["addr"][0]);
                $vendor = mysql_escape_string2($Hostz->address[1]["vendor"][0]);
                $f[] = "('{$ipaddr}','{$mac}','{$vendor}','{$date}')";
            }
        }
    }
    $prc = $prc + 5;
    if ($prc > 99) {
        $prc = 99;
    }
    nmap_scan_pingnet_progress("Build report", $prc);
    $q = new mysql();
    $sql = "CREATE TABLE IF NOT EXISTS `nmap_scannet` (\n\t`MAC` varchar(90) NOT NULL,\n\t`ipaddr` varchar(90) NOT NULL,\n\t`vendor` varchar(90) NOT NULL DEFAULT '',\n\t`zDate` datetime NOT NULL,\n\tPRIMARY KEY (`MAC`),\n\tKEY `ipaddr` (`ipaddr`),\n\tKEY `vendor` (`vendor`)\n\t) ENGINE=MYISAM;";
    $q->QUERY_SQL($sql, "artica_backup");
    if (!$q->ok) {
        echo $q->mysql_error . "\n";
        nmap_scan_pingnet_progress("MySQL error", "110");
        return;
    }
//.........這裏部分代碼省略.........
開發者ID:BillTheBest,項目名稱:1.6.x,代碼行數:101,代碼來源:exec.nmapscan.php

示例13: stop

function stop()
{
    $unix = new unix();
    $sock = new sockets();
    $masterbin = $unix->find_program("squid27");
    $EnableArticaHotSpot = $sock->GET_INFO("EnableArticaHotSpot");
    $SquidHotSpotPort = $sock->GET_INFO("SquidHotSpotPort");
    $ArticaHotSpotPort = $sock->GET_INFO("ArticaHotSpotPort");
    $ArticaSSLHotSpotPort = $sock->GET_INFO("ArticaSSLHotSpotPort");
    $ArticaSplashHotSpotPort = $sock->GET_INFO("ArticaSplashHotSpotPort");
    $ArticaSplashHotSpotPortSSL = $sock->GET_INFO("ArticaSplashHotSpotPortSSL");
    if (!is_numeric($ArticaHotSpotPort)) {
        $ArticaHotSpotPort = 0;
    }
    if (!is_numeric($ArticaSplashHotSpotPort)) {
        $ArticaSplashHotSpotPort = 16080;
    }
    if (!is_numeric($ArticaSplashHotSpotPortSSL)) {
        $ArticaSplashHotSpotPortSSL = 16443;
    }
    $pid = squid_27_pid();
    if (!is_file($masterbin)) {
        if ($GLOBALS["OUTPUT"]) {
            echo "Stopping......: " . date("H:i:s") . " [INIT]: {$GLOBALS["SERVICE_NAME"]} Not installed\n";
        }
        return;
    }
    if (!$unix->process_exists($pid)) {
        if ($GLOBALS["OUTPUT"]) {
            echo "Stopping......: " . date("H:i:s") . " [INIT]: {$GLOBALS["SERVICE_NAME"]} Already stopped...\n";
        }
        return;
    }
    $nohup = $unix->find_program("nohup");
    $php5 = $unix->LOCATE_PHP5_BIN();
    $kill = $unix->find_program("kill");
    if ($GLOBALS["OUTPUT"]) {
        echo "Stopping......: " . date("H:i:s") . " [INIT]: {$GLOBALS["SERVICE_NAME"]} Shutdown pid {$pid}...\n";
    }
    shell_exec("{$masterbin} -f /etc/squid27/squid.conf -k shutdown");
    for ($i = 0; $i < 5; $i++) {
        $pid = squid_27_pid();
        if (!$unix->process_exists($pid)) {
            break;
        }
        shell_exec("{$masterbin} -f /etc/squid27/squid.conf -k shutdown");
        if ($GLOBALS["OUTPUT"]) {
            echo "Starting......: " . date("H:i:s") . " [INIT]: {$GLOBALS["SERVICE_NAME"]} waiting pid:{$pid} {$i}/5...\n";
        }
        sleep(1);
    }
    $pid = squid_27_pid();
    if (!$unix->process_exists($pid)) {
        if ($GLOBALS["OUTPUT"]) {
            echo "Stopping......: " . date("H:i:s") . " [INIT]: {$GLOBALS["SERVICE_NAME"]} success...\n";
        }
        return;
    }
    if ($GLOBALS["OUTPUT"]) {
        echo "Stopping......: " . date("H:i:s") . " [INIT]: {$GLOBALS["SERVICE_NAME"]} shutdown - force - pid {$pid}...\n";
    }
    shell_exec("{$masterbin} -f /etc/squid27/squid.conf -k kill");
    for ($i = 0; $i < 5; $i++) {
        $pid = squid_27_pid();
        if (!$unix->process_exists($pid)) {
            break;
        }
        if ($GLOBALS["OUTPUT"]) {
            echo "Starting......: " . date("H:i:s") . " [INIT]: {$GLOBALS["SERVICE_NAME"]} waiting pid:{$pid} {$i}/5...\n";
        }
        shell_exec("{$masterbin} -f /etc/squid27/squid.conf -k kill");
        sleep(1);
    }
    if (!$unix->process_exists($pid)) {
        if ($GLOBALS["OUTPUT"]) {
            echo "Stopping......: " . date("H:i:s") . " [INIT]: {$GLOBALS["SERVICE_NAME"]} success stopped...\n";
        }
        return;
    }
    if ($GLOBALS["OUTPUT"]) {
        echo "Stopping......: " . date("H:i:s") . " [INIT]: {$GLOBALS["SERVICE_NAME"]} Killing processes\n";
    }
    for ($i = 0; $i < 5; $i++) {
        $pid = squid_27_pid();
        if (!$unix->process_exists($pid)) {
            break;
        }
        if ($GLOBALS["OUTPUT"]) {
            echo "Starting......: " . date("H:i:s") . " [INIT]: {$GLOBALS["SERVICE_NAME"]} kill pid:{$pid} {$i}/5...\n";
        }
        $unix->KILL_PROCESS($pid, 9);
    }
    $pid = squid_27_pid();
    if (!$unix->process_exists($pid)) {
        if ($GLOBALS["OUTPUT"]) {
            echo "Stopping......: " . date("H:i:s") . " [INIT]: {$GLOBALS["SERVICE_NAME"]} success stopped...\n";
        }
        return;
    }
    if ($GLOBALS["OUTPUT"]) {
//.........這裏部分代碼省略.........
開發者ID:BillTheBest,項目名稱:1.6.x,代碼行數:101,代碼來源:exec.squid27.php

示例14: BUILD_NETWORK

function BUILD_NETWORK()
{
    $SUBNIC = null;
    $unix = new unix();
    $sock = new sockets();
    $nohup = $unix->find_program("nohup");
    $php5 = $unix->LOCATE_PHP5_BIN();
    $savedsettings = unserialize(base64_decode(file_get_contents("/etc/artica-postfix/settings/Daemons/WizardSavedSettings")));
    $KEEPNET = $savedsettings["KEEPNET"];
    if ($KEEPNET == 1) {
        return;
    }
    $netbiosname = $savedsettings["netbiosname"];
    if (strlen($netbiosname) > 15) {
        $netbiosname = substr(0, 15, $netbiosname);
    }
    if (isset($savedsettings["domain"])) {
        $domainname = $savedsettings["domain"];
        $SEARCH_DOMAIN = $domainname;
    }
    $EnableKerbAuth = intval($sock->GET_INFO("EnableKerbAuth"));
    if ($EnableKerbAuth == 1) {
        $array = unserialize(base64_decode($sock->GET_INFO("KerbAuthInfos")));
        if (isset($array["WINDOWS_DNS_SUFFIX"])) {
            $SEARCH_DOMAIN = $array["WINDOWS_DNS_SUFFIX"];
            $domainname = $SEARCH_DOMAIN;
        }
    }
    $Encoded = base64_encode(serialize($savedsettings));
    @file_put_contents("/etc/artica-postfix/settings/Daemons/WizardSavedSettings", $Encoded);
    if (!isset($savedsettings["NIC"])) {
        $savedsettings["NIC"] = "eth0";
    }
    $NIC = $savedsettings["NIC"];
    if (preg_match("#(.+?):([0-9]+)#", $savedsettings["NIC"], $re)) {
        $NIC = trim($re[1]);
        $SUBNIC = $re[2];
    }
    writeprogress(60, "{building_networks}");
    $nics = new system_nic($NIC);
    $nics->CheckMySQLFields();
    $dhclient = $unix->find_program("dhclient");
    if (is_file($dhclient)) {
        $pid = $unix->PIDOF($dhclient);
        if ($unix->process_exists($pid)) {
            $unix->KILL_PROCESS($pid, 9);
        }
    }
    $nics->eth = $NIC;
    if ($SUBNIC != null) {
        $nics->IPADDR = "127.0.0.2";
        $nics->NETMASK = "255.255.255.255";
        $nics->GATEWAY = "0.0.0.0";
        $nics->BROADCAST = "0.0.0.0";
        $nics->DNS1 = $savedsettings["DNS1"];
        $nics->DNS2 = $savedsettings["DNS2"];
        $nics->dhcp = 0;
        $nics->metric = $savedsettings["metric"];
        $nics->enabled = 1;
        $nics->defaultroute = 1;
    } else {
        $nics->IPADDR = $savedsettings["IPADDR"];
        $nics->NETMASK = $savedsettings["NETMASK"];
        $nics->GATEWAY = $savedsettings["GATEWAY"];
        $nics->BROADCAST = $savedsettings["BROADCAST"];
        $nics->DNS1 = $savedsettings["DNS1"];
        $nics->DNS2 = $savedsettings["DNS2"];
        $nics->dhcp = 0;
        $nics->metric = $savedsettings["metric"];
        $nics->enabled = 1;
        $nics->defaultroute = 1;
    }
    writeprogress(60, "{saving_network}");
    $nics->SaveNic();
    if ($SUBNIC != null) {
        $q = new mysql();
        $sql = "INSERT INTO nics_virtuals (ID,nic,org,ipaddr,netmask,cdir,gateway,ForceGateway,failover,metric)\n\t\tVALUES('{$SUBNIC}','{$NIC}','','{$savedsettings["IPADDR"]}','{$savedsettings["NETMASK"]}',\n\t\t'','{$savedsettings["GATEWAY"]}',0,0,1);";
        $q->QUERY_SQL($sql, "artica_backup");
        $sql = "UPDATE nics_virtuals SET nic='{$NIC}',\n\t\torg='',\n\t\tipaddr='{$savedsettings["IPADDR"]}',\n\t\tnetmask='{$savedsettings["NETMASK"]}',\n\t\tcdir='',\n\t\t\t\tgateway='{$savedsettings["GATEWAY"]}',\n\t\t\t\tForceGateway='0',\n\t\t\t\tfailover='0',\n\t\t\t\tmetric='1'\n\t\t\t\tWHERE ID={$SUBNIC}";
        $q->QUERY_SQL($sql, "artica_backup");
    }
    writeprogress(60, "Loading resolv library");
    $resolv = new resolv_conf();
    $arrayNameServers[0] = $savedsettings["DNS1"];
    $arrayNameServers[1] = $savedsettings["DNS2"];
    $resolv->MainArray["DNS1"] = $arrayNameServers[0];
    $resolv->MainArray["DNS2"] = $arrayNameServers[1];
    $resolv->MainArray["DOMAINS1"] = $SEARCH_DOMAIN;
    writeprogress(60, "Saving DNS settings");
    $resolv->save();
    $nic = new system_nic();
    writeprogress(60, "{set_new_hostname} {$netbiosname}.{$domainname}");
    $nic->set_hostname("{$netbiosname}.{$domainname}");
    $php = $unix->LOCATE_PHP5_BIN();
    $nohup = $unix->find_program("nohup");
    writeprogress(60, "{building_resolv_configuration}");
    shell_exec(trim("{$nohup} " . $unix->LOCATE_PHP5_BIN() . " /usr/share/artica-postfix/exec.virtuals-ip.php --resolvconf >/dev/null 2>&1"));
    writeprogress(60, "{building_networks_scripts}");
    shell_exec("{$php5} /usr/share/artica-postfix/exec.virtuals-ip.php >/dev/null 2>&1");
}
開發者ID:BillTheBest,項目名稱:1.6.x,代碼行數:100,代碼來源:exec.wizard-install.php

示例15: reload

function reload()
{
    $scriptlog = null;
    if ($GLOBALS["BYSCRIPT"]) {
        $scriptlog = " by init.d script";
    }
    $unix = new unix();
    $pidfile = "/etc/artica-postfix/pids/" . basename(__FILE__) . "." . __FUNCTION__ . ".pid";
    $pid = $unix->get_pid_from_file($pidfile);
    if ($unix->process_exists($pid, basename(__FILE__))) {
        $time = $unix->PROCCESS_TIME_MIN($pid);
        if ($GLOBALS["OUTPUT"]) {
            echo "Starting......: " . date("H:i:s") . " [INIT]: Already Artica task running PID {$pid} since {$time}mn\n";
        }
        return;
    }
    @file_put_contents($pidfile, getmypid());
    $pid = LIGHTTPD_PID();
    if ($unix->process_exists($pid)) {
        if ($GLOBALS["OUTPUT"]) {
            echo "Starting......: " . date("H:i:s") . " [INIT]: Reloading framework PID:{$pid}...\n";
        }
        FrmToSyslog("Reloading framework{$scriptlog}");
        $unix->KILL_PROCESS($pid, 1);
        return;
    }
    if ($GLOBALS["OUTPUT"]) {
        echo "Starting......: " . date("H:i:s") . " [INIT]: Starting framework...\n";
    }
    start(true);
}
開發者ID:BillTheBest,項目名稱:1.6.x,代碼行數:31,代碼來源:exec.framework.php


注:本文中的unix::KILL_PROCESS方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。