-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathqs_cron.sh
executable file
·89 lines (86 loc) · 3.43 KB
/
qs_cron.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
#!/bin/bash
export PATH="/usr/local/bin:/usr/local/sbin:$PATH:/bin:/usr/bin:/sbin:/usr/sbin"
export base="$(readlink -f "$(dirname "$0")")";
export url=https://my-web-3.interserver.net/qs_queue.php
export dir=${base};
export log=$dir/cron.output;
export old_cron=1;
function age() {
local filename=$1
local changed=`stat -c %Y "$filename"`
local now=`date +%s`
local elapsed
let elapsed=now-changed
echo $elapsed
}
if [ "$SHELL" = "/bin/sh" ] && [ -e /cron.vps.disabled ]; then
exit;
fi;
if [ -f /dev/shm/lock ]; then
exit;
fi;
if [ -e $dir/.enable_workerman ]; then
export old_cron=0;
if [ $($dir/workerman/start.php status 2>/dev/null|grep "PROCESS STATUS"|wc -l) -eq 0 ]; then
$dir/workerman/update.sh >> $log 2>&1;
$dir/workerman/start.php restart -d >> $log 2>&1;
fi;
sleep 2s;
if [ $($dir/workerman/start.php status 2>/dev/null|grep "PROCESS STATUS"|wc -l) -eq 0 ]; then
echo "$HOSTNAME cannot start workerman" | mail [email protected]
export old_cron=1;
fi;
fi
if [ $old_cron -eq 1 ]; then
export pslog=$dir/cron.psoutput;
ps ux |grep "/bin/bash $0"|grep -v -e grep -e " $(($$ + 1)) " > $pslog
count=$(cat $pslog|wc -l)
if [ $count -ge 2 ]; then
echo "Got count $count" >> $log
cat $pslog >> $log;
# kill a get list older than 2 hours
if [ $(age .cron.age) -gt 7200 ]; then
if [ "$(ps uax|grep qs_get_list |grep -v grep)" != "" ]; then
kill -9 $(ps uax|grep qs_get_list |grep -v grep | awk '{ print $2 }')
fi
fi
else
rm -f cron.age
touch .cron.age
echo "[$(date "+%Y-%m-%d %H:%M:%S")] Crontab Startup" >> $log;
if [ -e /proc/vz ]; then
#$dir/cpu_usage_updater.sh 2>$dir/cron.cpu_usage >&2 &
$dir/provirted.phar cron cpu-usage 2>$dir/cron.cpu_usage >&2 &
fi;
#$dir/qs_update_info.php >> $log 2>&1
$dir/provirted.phar cron host-info -a >> $log 2>&1
#curl -s --connect-timeout 60 --max-time 600 -k -d action=get_new_qs $url 2>/dev/null > $dir/cron.cmd;
curl -s --connect-timeout 60 --max-time 600 -k -d action=get_new_qs http://my-web-3.interserver.net:55151/queue.php 2>/dev/null > $dir/cron.cmd;
if [ "$(cat $dir/cron.cmd)" != "" ] && [ "$(grep "Session halted." $dir/cron.cmd)" = "" ]; then
echo "Get New VPS Running: $(cat $dir/cron.cmd)" >> $log;
. $dir/cron.cmd >> $log 2>&1;
fi;
if [ ! -e /root/_disableqstraffic ]; then
#$dir/qs_traffic.php >> $log 2>&1
$dir/provirted.phar cron bw-info -a >> $log 2>&1
fi
#$dir/vps_traffic_new.php quickservers >> $log 2>&1
curl -s --connect-timeout 10 --max-time 15 -d action=map http://my-web-3.interserver.net:55151/queue.php | bash
#curl -s --connect-timeout 60 --max-time 600 -k -d action=get_queue $url 2>/dev/null > $dir/cron.cmd;
curl -s --connect-timeout 60 --max-time 600 -k -d action=get_qs_queue http://my-web-3.interserver.net:55151/queue.php 2>/dev/null > $dir/cron.cmd;
if [ "$(cat $dir/cron.cmd)" != "" ] && [ "$(grep "Session halted." $dir/cron.cmd)" = "" ]; then
echo "Get Queue Running: $(cat $dir/cron.cmd)" >> $log;
. $dir/cron.cmd >> $log 2>&1;
fi;
#$dir/qs_get_list.php >> $log 2>&1
$dir/provirted.phar cron vps-info -a >> $log 2>&1
# if [ ! -e .cron_daily.age ] || [ $(age .cron_daily.age) -ge 86400 ]; then
# if [ "$(ps uax|grep -e update_virtuozzo -e qs_cron_daily|grep -v grep)" = "" ]; then
# touch .cron_daily.age
# php qs_cron_daily.php >> cron.output 2>&1
# fi
# fi
/bin/rm -f $dir/cron.cmd;
fi
rm -f $pslog
fi;