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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
|
#!/usr/bin/perl -w use DBI; use POSIX qw(strftime); my $dbh = DBI-> connect (“DBI:mysql:shencan:111.1.32.153:3306″,”shencan”,”shencan”); #my $sql = “select * from shencan.LVS”; #my $sth = $dbh->prepare($sql); #$sth->execute(); my $HOSTNAME =`hostname`; chomp ( $HOSTNAME ); my $type ; my $hostinfo ; #while($hostname = $sth->fetchrow_hashref()) #{ # print “$hostname->{hostname} $hostname->{hostip}\n”; #} #my @value; #while(@value = $sth->fetchrow_array()) #{ # print “@value\n”; #} #my $SQL = “update shencan.LVS set node='CBN_CQ' where hostname='CBN-CQ-1-3Z2′”; #my $STH = $dbh->prepare($SQL); #$STH->execute(); #####MYSQL UPDATE SUB START ##### sub update{ my $sql = shift @_ ; my $mysqlupdate = $dbh ->prepare( $sql ); $mysqlupdate ->execute(); } #####MYSQL UPDATE SUB END ##### #sub SCselect { # my $sql = shift @_; # my $myselect = $dbh->prepare($sql); # $myselect->execute(); # while($hostinfo = $myselect->fetchrow_hashref()) { print “$type\n” ;print “$hostinfo->{$type} \n” ;} #} #####MYSQL SELECT SUB START##### sub shencan { my @shencan = @_ ; foreach $type ( @shencan ){ my $sql = “ select * from shencan.FC where hostname= '$HOSTNAME' ”; my $myselect = $dbh ->prepare( $sql ); $myselect ->execute(); while ( $hostinfo = $myselect ->fetchrow_hashref()) { return “ $hostinfo ->{ $type }” ; } } } #####MYSQL SELECT SUB END###### #####MYSQL SELECT START ####### my $FC =shencan “fcversion”; chomp ( $FC ); my $os = shencan “OS”; chomp ( $os ); my $arch = shencan “arch”; chomp ( $arch ); my $fdns =shencan “fdnsversion”; chomp ( $fdns ); my $ng = shencan “ngversion”; chomp ( $ng ); my $amr =shencan “amrversion”; chomp ( $amr ); my $oh =shencan “ohversion”; chomp ( $oh ); my $dm = shencan “dmversion”; chomp ( $dm ); my $cpisbin = shencan “cpisbinversion”; chomp ( $cpisbin ); my $node = shencan “node”; chomp ( $node ); my $type1 =shencan “type”; chomp ( $type1 ); #####MYSQL SELECT END###### ####CHECK NG VERSION START##### my $NG =`rpm -q NG`; chomp ( $NG ); ####CHECK NG VERSION END##### ####CHECK AMR VERSION START##### my $AMR =`rpm -q AMR`; chomp ( $AMR ); ####CHECK AMR VERSION END##### ####CHECK OH VERSION START##### my $OH =`rpm -q OH`; chomp ( $OH ); ####CHECK OH VERSION END##### ####CHECK DM VERSION START##### my $DM =`rpm -q DM`; chomp ( $DM ); ####CHECK DM VERSION END##### ####CHECK MFTT VERSION START##### my $MFTT =`rpm -q MFTT`; chomp ( $MFTT ); ####CHECK MFTT VERSION END##### ####CHECK CPISBIN VERSION START##### my $CPISBIN = `rpm -q CPISBIN`; chomp ( $CPISBIN ); ####CHECK CPISBIN VERSION END##### ####CHECK NODE START##### my @NODE = split (/-/, $HOSTNAME ); $NODE = “ $NODE [0]_ $NODE [1]“; ####CHECK NODE END##### ####CHECK ARCH STAR ##### my $ARCH =`arch`; chomp ( $ARCH ); #####CHECK ARCH END ##### ####CHECK EP53 STATUS AND UPDATE START##### my $ep53 =`dig \ @127 .0.0.1 www.qq.com >/dev/null && echo ok||echo bad`; chomp ( $ep53 ); update “update shencan.FC set ep53= '$ep53′ where hostname=' $HOSTNAME '”; ####CHECK EP53 STATUS AND UPDATE END##### ####CHECK EP80 STATUS AND UPDATE START##### my $GW =`route -n |awk ‘\ $1 ==”0.0.0.0″{ print \ $2 } '|awk -F”.” ‘{print \$1″.”\$2″.”\$3}' `; chomp ( $GW ); my $IP =`ip a| grep inet| grep $GW |awk -F”[ /]” ‘{ print \ $6 }'`; chomp ( $IP ); my $ep80 =`curl -H “Host:www.qq.com” -o /dev/null -s -w “%{http_code}” http:// $IP `; chomp ( $ep80 ); update “update shencan.FC set ep80= '$ep80′ where hostname=' $HOSTNAME '”; ####CHECK EP80 STATUS AND UPDATE END##### print “NG: $NG ARM: $AMR OH: $OH DM: $DM MFTT: $MFTT CPISBIN: $CPISBIN \n”; print “ $HOSTNAME NODE: $NODE OS: $os arch: $arch FC: $FC fdns: $fdns ng: $ng \n”; #####CHECK OS START###### sub OS { open (OS,”</etc/issue”); @line =<OS>; $line = $line [0]; chomp ( $line ); my @os = split (/\s+|\(|\)/, $line ); if ( $os [0] ge “Red”){ $SC = “REHL $os [6]. $os [10]“; } else { $SC = “ $os [0] $os [2]“; } } OS; close (OS); #####CHECK OS END###### ######CHECK FDNS OR NAME VERSION START###### open (FDNS,”</etc/ChinaCache/app.d/cpisbm.amr”); while (<FDNS>){ if (/RestartCmd/){ my @fc1 = split (/\s+/, $_ ); my $FC =” $fc1 [2]“; if ( $FC ge “named”){ $FCVER =`/usr/sbin/named -v`; chomp ( $FCVER ); my @FC1 = split (/\s+/, $FCVER ); $FCVER1 =” $FC1 [0] $FC1 [1]“; } else { $FCVER =`/FlexiDNS/application/sbin/fdns -v`; chomp ( $FCVER ); my @FC1 = split (/\s+/, $FCVER ); $FCVER1 =” $FC1 [0] $FC1 [1]“; } } } close (FDNS); ######CHECK FDNS OR NAME VERSION END###### #####CHECK FCVERSION AND TYPE START###### open (FC,”</etc/ChinaCache/app.d/cpisfc.amr”); while (<FC>){ if (/RestartCmd/){ my @squid = split (/\s+/, $_ ); my $SQUID =” $squid [2]“; if ( $SQUID ge “squid”){ $SQUIDVER =`/usr/ local /squid/sbin/squid -v|head -n 1 |awk ‘{ print “V”\ $4 }'`; chomp ( $SQUIDVER ); $TYPE =”FC5″; } else { $SQUIDVER =`/usr/ local /flexicache/sbin/flexicache -v|awk ‘{ print \ $3 }'`; chomp ( $SQUIDVER ); $TYPE =”FC6″; } } } close (FC); #####CHECK FCVERSION AND TYPE END###### ####Change MYSQL ####### if ( $SQUIDVER eq $FC ){ } else { update “update shencan.FC set fcversion= '$SQUIDVER' where hostname= '$HOSTNAME' ”; } if ( $NG eq $ng ){ } else { update “update shencan.FC set ngversion= '$NG' where hostname= '$HOSTNAME' ”; } if ( $DM eq $dm ){ } else { update “update shencan.FC set dmversion= '$DM' where hostname= '$HOSTNAME' ”; } if ( $AMR eq $amr ){ } else { update “update shencan.FC set amrversion= '$AMR' where hostname= '$HOSTNAME' ”; } if ( $OH eq $oh ){ } else { update “update shencan.FC set ohversion= '$OH' where hostname= '$HOSTNAME' ”; } if ( $CPISBIN eq $cpisbin ){ } else { update “update shencan.FC set cpisbinversion= '$CPISBIN' where hostname= '$HOSTNAME' ”; } if ( $NODE eq $node ){ } else { update “update shencan.FC set node= '$NODE' where hostname= '$HOSTNAME' ”; } if ( $TYPE eq $type1 ){ } else { update “update shencan.FC set type= '$TYPE' where hostname= '$HOSTNAME' ”; } if ( $FCVER1 eq $fdns ){ } else { update “update shencan.FC set fdnsversion= '$FCVER1′ where hostname=' $HOSTNAME '”; } if ( $SC eq $os ){ } else { update “update shencan.FC set OS= '$SC' where hostname= '$HOSTNAME' ”; } if ( $ARCH eq $arch ){ } else { update “update shencan.FC set arch= '$ARCH' where hostname= '$HOSTNAME' ”; } my $time = strftime “ %Y - %m - %d_ %H : %M : %S ”, localtime ; chomp ( $time ); update “update shencan.FC set lmtime= '$time' where hostname= '$HOSTNAME' ”; |
perl 采集入庫腳本分享
2020-06-20 10:58perl教程網 perl
這篇文章主要介紹了perl 采集入庫腳本分享,本文是以前自己用的腳本,使用的Mysql數據庫,需要的朋友可以參考下
延伸 · 閱讀
- 2022-03-07unity學習教程之定制腳本模板示例代碼
- 2022-03-05CocosCreator學習之模塊化腳本
- 2022-03-05Linux expect實現自動登錄腳本實例代碼
- 2022-03-03英雄聯盟手游腳本怎么用 英雄聯盟手游腳本會被
- 2022-03-03Python手機與電腦游戲腳本的編寫方法
- 2022-03-02Python 實現 PD 文字識別、提取并寫入 CSV 文件腳本
- perl
perl命令行參數內建數組@ARGV淺析
這篇文章主要介紹了perl命令行參數內建數組@ARGV淺析,本文重點在于講解@ARGV的用法,并通過實例來說明,需要的朋友可以參考下 ...
- perl
Perl的經典用法分享
Perl的經典用法分享,學習perl的朋友可以參考下 ...
- perl
Perl從文件中讀取字符串的兩種實現方法
有時候我們需要從文件中讀取字符串,這里簡單介紹下, 需要的朋友可以參考下 ...
- perl
perl pop push shift unshift實例介紹
perl的pop跟push操作數組的最右邊,shift跟unshift操作數組的最左邊 ...
- perl
perl use vars pragma使用技巧
perl 中的vars是perl中的一個pragma(預編譯指示符),專門用來預定義全局變量,這些預定義后的全局變量在qw()列表中,在整個引用perl文件中皆可使用,即便使...
- perl
perl常見問題集合之二
哪些平臺上有 Perl?要到哪里去找? Perl的標準發行版(由 perl 發展小組負責維護)僅以原始碼形式發行。您可在 http: //www.perl.com/CPAN/src/latest.tar.gz處取得。這個檔...
- perl
Perl List::Util模塊使用實例
這篇文章主要介紹了Perl List::Util模塊使用實例,本文給出掃描符合條件的某個列表并取出第一個符合條件的、求1到1000之間的和 、求一組數字的最大值與最小...
- perl
Perl使用nginx FastCGI環境做WEB開發實例
這篇文章主要介紹了Perl使用nginx FastCGI環境做WEB開發實例,實現了路由系統和模板系統,需要的朋友可以參考下...