❗️Toto je původní verze internetového fóra ISPforum.cz do února 2020 bez možnosti registrace nových uživatelů. Aktivní verzi fóra naleznete na adrese https://telekomunikace.cz

Parsovani v bash

Příspěvky, které nespadají do žádného z vytvořených fór.
Rudolf Dvořák
Příspěvky: 421
Registrován: 15 years ago
antispam: Ano
Bydliště: Czech Republic
Kontaktovat uživatele:

Parsovani v bash

Příspěvekod Rudolf Dvořák » 12 years ago

Pekny den muze mi nekdo prosim poradit jak mam vyparsovat ip adresu ktera se vzdy nachazi za "address=" v nasledujicim kodu?

diky ruda

Kód: Vybrat vše

#!/bin/bash

ssh_out=$(ssh -i /root/keys/ssl/id_dsa admin@1.1.1.1 /ip firewall address-list print terse where list=black_list)

IFS="\n"
for line in $ssh_out
do
        echo $line
done
Naposledy upravil(a) Rudolf Dvořák dne 14 Nov 2012 15:15, celkem upraveno 1 x.
0 x

ocior
Příspěvky: 481
Registrován: 19 years ago

Příspěvekod ocior » 12 years ago

Bylo by fajn sem dat ukazku toho vystupu. Co cut?
0 x
Dan Skoupý

Rudolf Dvořák
Příspěvky: 421
Registrován: 15 years ago
antispam: Ano
Bydliště: Czech Republic
Kontaktovat uživatele:

Příspěvekod Rudolf Dvořák » 12 years ago

Kód: Vybrat vše

 0   list=black_list address=109.110.227.250
 1   list=black_list address=208.77.208.91
 3   list=black_list address=212.195.253.156
 4   list=black_list address=212.45.25.230
 5   list=black_list address=183.62.48.57
 6   list=black_list address=83.14.83.110
 7   list=black_list address=210.16.202.1
 8   list=black_list address=184.98.103.196
 9   list=black_list address=192.168.168.1
10   list=black_list address=61.78.164.250
11   list=black_list address=211.195.225.145
12   list=black_list address=125.88.98.23
13   list=black_list address=111.74.82.33
14   list=black_list address=67.190.11.61
15   list=black_list address=189.26.255.11
16   list=black_list address=124.188.70.244
17   list=black_list address=125.88.128.5
18   list=black_list address=189.134.115.227
19   list=black_list address=63.143.57.27
20   list=black_list address=175.107.48.114
21   list=black_list address=176.9.225.170
22   list=black_list address=192.168.168.2
23   list=black_list address=218.50.2.114
24   list=black_list address=125.211.196.248
25   list=black_list address=182.243.164.158
26   list=black_list address=221.13.104.162
27   list=black_list address=177.183.46.22
28   list=black_list address=213.186.118.211
29   list=black_list address=117.21.208.26
30   list=black_list address=114.80.108.196
31   list=black_list address=31.214.43.117
32   list=black_list address=218.92.75.130
0 x

ocior
Příspěvky: 481
Registrován: 19 years ago

Příspěvekod ocior » 12 years ago

Kód: Vybrat vše

cut -d = -f 3
0 x
Dan Skoupý

Rudolf Dvořák
Příspěvky: 421
Registrován: 15 years ago
antispam: Ano
Bydliště: Czech Republic
Kontaktovat uživatele:

Příspěvekod Rudolf Dvořák » 12 years ago

ocior píše:

Kód: Vybrat vše

cut -d = -f 3

Diky to by slo, muzu jeste poprosit o info jak dokazat aby to v tom cyklu pridavalo query a potom je provedlo, ted mi to totiz do $ip hodi vsechny ip najednou, diky moc

Kód: Vybrat vše

#!/bin/bash

ssh_out=$(ssh -i /root/keys/aaa/id_dsa admin@aaa /ip firewall address-list print terse where list=black_list)

q=""
IFS="\n"
for line in $ssh_out
do
        ip=$(echo $line | cut -d = -f 3)
        echo $ip line
        q="$q INSERT INTO general_blacklist (ip) VALUES (\"$ip\") ON DUPLICATE KEY UPDATE ip=ip;"
done
mysql --host=10.1.16.12 --user=ruda --password=123 ip_lists <<< $q
0 x

Uživatelský avatar
LaCosta
Příspěvky: 168
Registrován: 20 years ago
Kontaktovat uživatele:

Příspěvekod LaCosta » 12 years ago

Mozno prasarna :) ale tak ako priklad postaci ...

Kód: Vybrat vše

#!/bin/bash

ssh -i /root/keys/aaa/id_dsa admin@aaa /ip firewall address-list print terse where list=black_list > /tmp/sql_import
sed -i -e 's/^.*\ address=/INSERT INTO general_blacklist (ip) VALUES=/g' -e 's/$/ ON DUPLICATE KEY UPDATE ip=ip;/g' /tmp/sql_import
mysql --host=10.1.16.12 --user=ruda --password=123 ip_lists < /tmp/sql_import



Nemam to ako vyskusat, takze v pripade potreby to treba upravit (opravit) ...
0 x