From: xchaos Date: Sun, 13 May 2012 10:48:13 +0000 (+0000) Subject: further optimalizations (less calls to ipcalc) X-Git-Url: http://git.harvie.cz/?p=svn%2FPrometheus-QoS%2F.git;a=commitdiff_plain;h=143c9a45519eac0098099a0920a6d1d4f3e6d787 further optimalizations (less calls to ipcalc) git-svn-id: https://dev.arachne.cz/repos/prometheus/trunk@167 251d49ef-1d17-4917-a970-b30cf55b089b --- diff --git a/optional-tools/make-iptables-restore b/optional-tools/make-iptables-restore index 3e33fb2..bc047d9 100755 --- a/optional-tools/make-iptables-restore +++ b/optional-tools/make-iptables-restore @@ -4,6 +4,7 @@ iptablesrestore="/sbin/iptables-restore" ifconfig="/sbin/ifconfig" grep="/bin/grep" cut="/usr/bin/cut" +ipcalc="/usr/bin/ipcalc" #pimp files must be generated by optional-tools/make-pimp utility pimp_2way_nat="/dev/shm/pimp-2way-nat.tmp" @@ -21,6 +22,7 @@ czfthirdbitmask="25" czffourthbitmask="28" pubfirstbitmask="26" pubsecondbitmask="29" +chaintrack="_" echo "*nat" > $restoretmp echo ":PREROUTING ACCEPT [0:0]" >> $restoretmp @@ -30,71 +32,82 @@ echo ":OUTPUT ACCEPT [0:0]" >> $restoretmp # =============================================================== # Symetrical SNAT-DNAT using indexed iptables # =============================================================== - echo -n "Generating new iptables-restore data - two way SNAT/DNAT " for czfip in `$grep -v ^# $pimp_2way_nat|$cut -f 1 -d " "` do pubip=`$grep "$czfip " $pimp_2way_nat|$cut -f 2 -d " "` - czffirstindex=priv_`ipcalc -n $czfip/$czffirstbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` - czfsecondindex=priv_`ipcalc -n $czfip/$czfsecondbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` - czfthirdindex=priv_`ipcalc -n $czfip/$czfthirdbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` - czffourthindex=priv_`ipcalc -n $czfip/$czffourthbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` - pubfirstindex=pub_`ipcalc -n $pubip/$pubfirstbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` - pubsecondindex=pub_`ipcalc -n $pubip/$pubsecondbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` - - if ! $grep $czffirstindex $restoretmp > /dev/null + czffirstindex=priv_`$ipcalc -n $czfip/$czffirstbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` + czfsecondindex=priv_`$ipcalc -n $czfip/$czfsecondbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` + czfthirdindex=priv_`$ipcalc -n $czfip/$czfthirdbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` + czffourthindex=priv_`$ipcalc -n $czfip/$czffourthbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` + pubfirstindex=pub_`$ipcalc -n $pubip/$pubfirstbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` + pubsecondindex=pub_`$ipcalc -n $pubip/$pubsecondbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` + + if ! [[ "$chaintrack" == *"$czffirstindex"* ]] then echo :$czffirstindex "- [0:0]" >> $restoretmp - echo -A POSTROUTING -d ! 10.0.0.0/8 -s `ipcalc -n $czfip/$czffirstbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan1 -j $czffirstindex >> $restoretmp - echo -A POSTROUTING -d ! 10.0.0.0/8 -s `ipcalc -n $czfip/$czffirstbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan2 -j $czffirstindex >> $restoretmp - echo -A POSTROUTING -d ! 10.0.0.0/8 -s `ipcalc -n $czfip/$czffirstbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan3 -j $czffirstindex >> $restoretmp - echo -A POSTROUTING -d ! 10.0.0.0/8 -s `ipcalc -n $czfip/$czffirstbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan4 -j $czffirstindex >> $restoretmp + s=`$ipcalc -n $czfip/$czffirstbitmask|$grep Network|$cut -f 4 -d \ ` + echo -A POSTROUTING -d ! 10.0.0.0/8 -s $s -o $wan1 -j $czffirstindex >> $restoretmp + echo -A POSTROUTING -d ! 10.0.0.0/8 -s $s -o $wan2 -j $czffirstindex >> $restoretmp + echo -A POSTROUTING -d ! 10.0.0.0/8 -s $s -o $wan3 -j $czffirstindex >> $restoretmp + echo -A POSTROUTING -d ! 10.0.0.0/8 -s $s -o $wan4 -j $czffirstindex >> $restoretmp + chaintrack=\ ${czffirstindex}\ ${chaintrack} fi - if ! $grep $czfsecondindex $restoretmp > /dev/null + if ! [[ "$chaintrack" == *"$czfsecondindex"* ]] then echo :$czfsecondindex "- [0:0]" >> $restoretmp - echo -A $czffirstindex -s `ipcalc -n $czfip/$czfsecondbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan1 -j $czfsecondindex >> $restoretmp - echo -A $czffirstindex -s `ipcalc -n $czfip/$czfsecondbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan2 -j $czfsecondindex >> $restoretmp - echo -A $czffirstindex -s `ipcalc -n $czfip/$czfsecondbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan3 -j $czfsecondindex >> $restoretmp - echo -A $czffirstindex -s `ipcalc -n $czfip/$czfsecondbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan4 -j $czfsecondindex >> $restoretmp + s=`$ipcalc -n $czfip/$czfsecondbitmask|$grep Network|$cut -f 4 -d \ ` + echo -A $czffirstindex -s $s -o $wan1 -j $czfsecondindex >> $restoretmp + echo -A $czffirstindex -s $s -o $wan2 -j $czfsecondindex >> $restoretmp + echo -A $czffirstindex -s $s -o $wan3 -j $czfsecondindex >> $restoretmp + echo -A $czffirstindex -s $s -o $wan4 -j $czfsecondindex >> $restoretmp + chaintrack=\ ${czfsecondindex}\ ${chaintrack} fi - if ! $grep $czfthirdindex $restoretmp > /dev/null + if ! [[ "$chaintrack" == *"$czfthirdindex"* ]] then echo :$czfthirdindex "- [0:0]" >> $restoretmp - echo -A $czfsecondindex -s `ipcalc -n $czfip/$czfthirdbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan1 -j $czfthirdindex >> $restoretmp - echo -A $czfsecondindex -s `ipcalc -n $czfip/$czfthirdbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan2 -j $czfthirdindex >> $restoretmp - echo -A $czfsecondindex -s `ipcalc -n $czfip/$czfthirdbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan3 -j $czfthirdindex >> $restoretmp - echo -A $czfsecondindex -s `ipcalc -n $czfip/$czfthirdbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan4 -j $czfthirdindex >> $restoretmp + s=`$ipcalc -n $czfip/$czfthirdbitmask|$grep Network|$cut -f 4 -d \ ` + echo -A $czfsecondindex -s $s -o $wan1 -j $czfthirdindex >> $restoretmp + echo -A $czfsecondindex -s $s -o $wan2 -j $czfthirdindex >> $restoretmp + echo -A $czfsecondindex -s $s -o $wan3 -j $czfthirdindex >> $restoretmp + echo -A $czfsecondindex -s $s -o $wan4 -j $czfthirdindex >> $restoretmp + chaintrack=\ ${czfthirdindex}\ ${chaintrack} fi - if ! $grep $czffourthindex $restoretmp > /dev/null + if ! [[ "$chaintrack" == *"$czffourthindex"* ]] then echo :$czffourthindex "- [0:0]" >> $restoretmp - echo -A $czfthirdindex -s `ipcalc -n $czfip/$czffourthbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan1 -j $czffourthindex >> $restoretmp - echo -A $czfthirdindex -s `ipcalc -n $czfip/$czffourthbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan2 -j $czffourthindex >> $restoretmp - echo -A $czfthirdindex -s `ipcalc -n $czfip/$czffourthbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan3 -j $czffourthindex >> $restoretmp - echo -A $czfthirdindex -s `ipcalc -n $czfip/$czffourthbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan4 -j $czffourthindex >> $restoretmp + s=`$ipcalc -n $czfip/$czffourthbitmask|$grep Network|$cut -f 4 -d \ ` + echo -A $czfthirdindex -s $s -o $wan1 -j $czffourthindex >> $restoretmp + echo -A $czfthirdindex -s $s -o $wan2 -j $czffourthindex >> $restoretmp + echo -A $czfthirdindex -s $s -o $wan3 -j $czffourthindex >> $restoretmp + echo -A $czfthirdindex -s $s -o $wan4 -j $czffourthindex >> $restoretmp + chaintrack=\ ${czffourthindex}\ ${chaintrack} fi - if ! $grep $pubfirstindex $restoretmp > /dev/null + if ! [[ "$chaintrack" == *"$pubfirstindex"* ]] then echo :$pubfirstindex "- [0:0]" >> $restoretmp - echo -A PREROUTING -i $wan1 -d `ipcalc -n $pubip/$pubfirstbitmask|$grep Network|$cut -f 4 -d \ ` -j $pubfirstindex >> $restoretmp - echo -A PREROUTING -i $wan2 -d `ipcalc -n $pubip/$pubfirstbitmask|$grep Network|$cut -f 4 -d \ ` -j $pubfirstindex >> $restoretmp - echo -A PREROUTING -i $wan3 -d `ipcalc -n $pubip/$pubfirstbitmask|$grep Network|$cut -f 4 -d \ ` -j $pubfirstindex >> $restoretmp - echo -A PREROUTING -i $wan4 -d `ipcalc -n $pubip/$pubfirstbitmask|$grep Network|$cut -f 4 -d \ ` -j $pubfirstindex >> $restoretmp + s=`$ipcalc -n $pubip/$pubfirstbitmask|$grep Network|$cut -f 4 -d \ ` + echo -A PREROUTING -i $wan1 -d $s -j $pubfirstindex >> $restoretmp + echo -A PREROUTING -i $wan2 -d $s -j $pubfirstindex >> $restoretmp + echo -A PREROUTING -i $wan3 -d $s -j $pubfirstindex >> $restoretmp + echo -A PREROUTING -i $wan4 -d $s -j $pubfirstindex >> $restoretmp + chaintrack=\ ${pubfirstindex}\ ${chaintrack} fi - if ! $grep $pubsecondindex $restoretmp > /dev/null + if ! [[ "$chaintrack" == *"$pubsecondindex"* ]] then echo :$pubsecondindex "- [0:0]" >> $restoretmp - echo -A $pubfirstindex -i $wan1 -d `ipcalc -n $pubip/$pubsecondbitmask|$grep Network|$cut -f 4 -d \ ` -j $pubsecondindex >> $restoretmp - echo -A $pubfirstindex -i $wan2 -d `ipcalc -n $pubip/$pubsecondbitmask|$grep Network|$cut -f 4 -d \ ` -j $pubsecondindex >> $restoretmp - echo -A $pubfirstindex -i $wan3 -d `ipcalc -n $pubip/$pubsecondbitmask|$grep Network|$cut -f 4 -d \ ` -j $pubsecondindex >> $restoretmp - echo -A $pubfirstindex -i $wan4 -d `ipcalc -n $pubip/$pubsecondbitmask|$grep Network|$cut -f 4 -d \ ` -j $pubsecondindex >> $restoretmp + s=`$ipcalc -n $pubip/$pubsecondbitmask|$grep Network|$cut -f 4 -d \ ` + echo -A $pubfirstindex -i $wan1 -d $s -j $pubsecondindex >> $restoretmp + echo -A $pubfirstindex -i $wan2 -d $s -j $pubsecondindex >> $restoretmp + echo -A $pubfirstindex -i $wan3 -d $s -j $pubsecondindex >> $restoretmp + echo -A $pubfirstindex -i $wan4 -d $s -j $pubsecondindex >> $restoretmp + chaintrack=\ ${pubsecondindex}\ ${chaintrack} fi echo -A $pubsecondindex -i $wan1 -d $pubip/32 -j DNAT --to-destination $czfip >> $restoretmp @@ -108,57 +121,65 @@ do echo -A $czffourthindex -s $czfip/32 -o $wan4 -j SNAT --to-source $pubip >> $restoretmp echo -n . + done echo " done." -echo -n "Generating new iptables-restore data - one way SNAT " - # =============================================================== # SNAT only using indexed iptables (should be rather function, hmm) # =============================================================== +echo -n "Generating new iptables-restore data - one way SNAT " for czfip in `$grep -v ^# $pimp_snat|$cut -f 1 -d " "` do pubip=`$grep "$czfip " $pimp_snat|$cut -f 2 -d " "` - czffirstindex=priv_`ipcalc -n $czfip/$czffirstbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` - czfsecondindex=priv_`ipcalc -n $czfip/$czfsecondbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` - czfthirdindex=priv_`ipcalc -n $czfip/$czfthirdbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` - czffourthindex=priv_`ipcalc -n $czfip/$czffourthbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` + czffirstindex=priv_`$ipcalc -n $czfip/$czffirstbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` + czfsecondindex=priv_`$ipcalc -n $czfip/$czfsecondbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` + czfthirdindex=priv_`$ipcalc -n $czfip/$czfthirdbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` + czffourthindex=priv_`$ipcalc -n $czfip/$czffourthbitmask|$grep Network|$cut -f 4 -d \ |tr [./] _` - if ! $grep $czffirstindex $restoretmp > /dev/null + if ! [[ "$chaintrack" == *"$czffirstindex"* ]] then echo :$czffirstindex "- [0:0]" >> $restoretmp - echo -A POSTROUTING -d ! 10.0.0.0/8 -s `ipcalc -n $czfip/$czffirstbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan1 -j $czffirstindex >> $restoretmp - echo -A POSTROUTING -d ! 10.0.0.0/8 -s `ipcalc -n $czfip/$czffirstbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan2 -j $czffirstindex >> $restoretmp - echo -A POSTROUTING -d ! 10.0.0.0/8 -s `ipcalc -n $czfip/$czffirstbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan3 -j $czffirstindex >> $restoretmp - echo -A POSTROUTING -d ! 10.0.0.0/8 -s `ipcalc -n $czfip/$czffirstbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan4 -j $czffirstindex >> $restoretmp + s=`$ipcalc -n $czfip/$czffirstbitmask|$grep Network|$cut -f 4 -d \ ` + echo -A POSTROUTING -d ! 10.0.0.0/8 -s $s -o $wan1 -j $czffirstindex >> $restoretmp + echo -A POSTROUTING -d ! 10.0.0.0/8 -s $s -o $wan2 -j $czffirstindex >> $restoretmp + echo -A POSTROUTING -d ! 10.0.0.0/8 -s $s -o $wan3 -j $czffirstindex >> $restoretmp + echo -A POSTROUTING -d ! 10.0.0.0/8 -s $s -o $wan4 -j $czffirstindex >> $restoretmp + chaintrack=\ ${czffirstindex}\ ${chaintrack} fi - if ! $grep $czfsecondindex $restoretmp > /dev/null + if ! [[ "$chaintrack" == *"$czfsecondindex"* ]] then echo :$czfsecondindex "- [0:0]" >> $restoretmp - echo -A $czffirstindex -s `ipcalc -n $czfip/$czfsecondbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan1 -j $czfsecondindex >> $restoretmp - echo -A $czffirstindex -s `ipcalc -n $czfip/$czfsecondbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan2 -j $czfsecondindex >> $restoretmp - echo -A $czffirstindex -s `ipcalc -n $czfip/$czfsecondbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan3 -j $czfsecondindex >> $restoretmp - echo -A $czffirstindex -s `ipcalc -n $czfip/$czfsecondbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan4 -j $czfsecondindex >> $restoretmp + s=`$ipcalc -n $czfip/$czfsecondbitmask|$grep Network|$cut -f 4 -d \ ` + echo -A $czffirstindex -s $s -o $wan1 -j $czfsecondindex >> $restoretmp + echo -A $czffirstindex -s $s -o $wan2 -j $czfsecondindex >> $restoretmp + echo -A $czffirstindex -s $s -o $wan3 -j $czfsecondindex >> $restoretmp + echo -A $czffirstindex -s $s -o $wan4 -j $czfsecondindex >> $restoretmp + chaintrack=\ ${czfsecondindex}\ ${chaintrack} fi - if ! $grep $czfthirdindex $restoretmp > /dev/null + if ! [[ "$chaintrack" == *"$czfthirdindex"* ]] then echo :$czfthirdindex "- [0:0]" >> $restoretmp - echo -A $czfsecondindex -s `ipcalc -n $czfip/$czfthirdbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan1 -j $czfthirdindex >> $restoretmp - echo -A $czfsecondindex -s `ipcalc -n $czfip/$czfthirdbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan2 -j $czfthirdindex >> $restoretmp - echo -A $czfsecondindex -s `ipcalc -n $czfip/$czfthirdbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan3 -j $czfthirdindex >> $restoretmp - echo -A $czfsecondindex -s `ipcalc -n $czfip/$czfthirdbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan4 -j $czfthirdindex >> $restoretmp + s=`$ipcalc -n $czfip/$czfthirdbitmask|$grep Network|$cut -f 4 -d \ ` + echo -A $czfsecondindex -s $s -o $wan1 -j $czfthirdindex >> $restoretmp + echo -A $czfsecondindex -s $s -o $wan2 -j $czfthirdindex >> $restoretmp + echo -A $czfsecondindex -s $s -o $wan3 -j $czfthirdindex >> $restoretmp + echo -A $czfsecondindex -s $s -o $wan4 -j $czfthirdindex >> $restoretmp + chaintrack=\ ${czfthirdindex}\ ${chaintrack} fi - if ! $grep $czffourthindex $restoretmp > /dev/null + if ! [[ "$chaintrack" == *"$czffourthindex"* ]] then echo :$czffourthindex "- [0:0]" >> $restoretmp - echo -A $czfthirdindex -s `ipcalc -n $czfip/$czffourthbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan1 -j $czffourthindex >> $restoretmp - echo -A $czfthirdindex -s `ipcalc -n $czfip/$czffourthbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan2 -j $czffourthindex >> $restoretmp - echo -A $czfthirdindex -s `ipcalc -n $czfip/$czffourthbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan3 -j $czffourthindex >> $restoretmp - echo -A $czfthirdindex -s `ipcalc -n $czfip/$czffourthbitmask|$grep Network|$cut -f 4 -d \ ` -o $wan4 -j $czffourthindex >> $restoretmp + s=`$ipcalc -n $czfip/$czffourthbitmask|$grep Network|$cut -f 4 -d \ ` + echo -A $czfthirdindex -s $s -o $wan1 -j $czffourthindex >> $restoretmp + echo -A $czfthirdindex -s $s -o $wan2 -j $czffourthindex >> $restoretmp + echo -A $czfthirdindex -s $s -o $wan3 -j $czffourthindex >> $restoretmp + echo -A $czfthirdindex -s $s -o $wan4 -j $czffourthindex >> $restoretmp + chaintrack=\ ${czffourthindex}\ ${chaintrack} fi echo -A $czffourthindex -s $czfip/32 -o $wan1 -j SNAT --to-source $pubip >> $restoretmp @@ -171,4 +192,5 @@ done echo " done." echo COMMIT >> $restoretmp -mv $restoretmp $restoredata \ No newline at end of file +echo -n "Writing $restoredata" +mv $restoretmp $restoredata