-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtcp_test.sh
85 lines (72 loc) · 1.7 KB
/
tcp_test.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
#!/bin/bash
readonly script_path=$(readlink -f $0)
readonly base_dir=$(dirname $script_path)
# get file name without extension
base_name="${script_path##*/}"
readonly base_name="${base_name%.*}"
readonly cfg="$base_dir/$base_name.cfg"
readonly log_dir="$base_dir/logs"
readonly log_name="$log_dir/$base_name.log"
readonly first_log="$log_name"".0"
# 5M*2
readonly log_limit="5242880"
readonly log_size="2"
readonly log_info=" Info "
readonly log_error=" Error "
readonly log_warn=" Warning "
function is_dir() {
if [ -d "$1" ]; then
echo 0
else
echo -1
fi
}
function is_file() {
if [ -f "$1" ]; then
echo 0
else
echo -1
fi
}
function make_dir() {
if [ ! -d "$1" ]; then
mkdir -pm 755 "$1"
fi
}
function make_file() {
if [ ! -f "$1" ]; then
touch "$1"
chmod 744 "$1"
fi
}
function get_filesize() {
local size=$(stat -c%s "$1")
echo "$size"
}
# roll logs if exceeded limit size
function roll_log() {
local j=$(( $log_size-1 ))
for ((i=$j; i>0; i--)); do
if [ $(is_file "$log_name"".""$(( $i-1 ))") -eq 0 ]; then
mv $log_name"."$(( $i-1 )) $log_name"."$i
fi
done
}
function main() {
$(make_dir "$log_dir")
$(make_file "$first_log")
local host="10.146.4.34"
local port="10001"
local nc_dir="/opt/IBM/tools/tivoli/nc"
printf "%s %-10s %-20s\t%s\n" "$(date +"%F %T:%3N")" $log_info ${FUNCNAME[0]} "tcp test started" >> $first_log
local result=$($nc_dir -zw10 $host $port)
printf "%s %-10s %-20s\t%s\n" "$(date +"%F %T:%3N")" $log_info ${FUNCNAME[0]} "tcp test finished: $result" >> $first_log
local size=$(get_filesize "$first_log")
if [[ "$size" -gt "$log_limit" ]]; then
$(roll_log)
fi
}
while (true); do
$(main)
sleep 1m
done