abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 04:22 | Nová verze

    Byla vydána nová verze 9.5 multiplatformní digitální pracovní stanice pro práci s audiem (DAW) Ardour. Přehled novinek, vylepšení a oprav v poznámkách k vydání a na YouTube.

    Ladislav Hagara | Komentářů: 0
    včera 21:00 | IT novinky

    Dnes a zítra probíhá vývojářská konference Google I/O 2026. Sledovat lze na YouTube a na síti 𝕏 (#GoogleIO).

    Ladislav Hagara | Komentářů: 0
    včera 19:00 | Nová verze

    Canonical vydal Ubuntu Core 26. Vychází z Ubuntu 26.04 LTS a podporováno bude 15 let. Ubuntu Core je minimální neměnný operační systém určený pro vestavěné systémy.

    Ladislav Hagara | Komentářů: 0
    včera 16:22 | Nová verze

    Bylo vydáno OpenBSD 7.9. Po dlouhé době opět se songem: Diamond in the Rough.

    Ladislav Hagara | Komentářů: 0
    včera 16:00 | Nová verze

    Byl vydán Mozilla Firefox 151.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 151 bude brzy k dispozici také na Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    včera 12:22 | IT novinky

    Elon Musk prohrál soudní spor se společností OpenAI, která se podle jeho žaloby odchýlila od původně uváděného cíle vyvíjet umělou inteligenci (AI) ku prospěchu lidstva. Porota včera po necelých dvou hodinách dospěla k jednomyslnému závěru, že Musk žalobu podal příliš pozdě. Musk byl jedním ze spoluzakladatelů společnosti OpenAI, která vznikla v roce 2015 a vyvinula populární chatovací systém ChatGPT. V roce 2018 na svůj post ve vedení

    … více »
    Ladislav Hagara | Komentářů: 0
    včera 10:22 | Nová verze

    Byla vydána nová verze 10.4 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Opraveny jsou zranitelnosti Copy Fail a Dirty Frag. Přibyl nový obraz pro Orange Pi 5B.

    Ladislav Hagara | Komentářů: 0
    včera 07:44 | Zajímavý software

    Pokud je zranitelnost Linuxu v nepoužívaném jaderném modulu, lze ji jednoduše vyřešit zakázáním automatického načítání tohoto konkrétního zranitelného modulu. Projekt ModuleJail si klade za cíl zvýšit bezpečnost Linuxu zakázáním automatického načítání všech nepoužívaných jaderných modulů. Jedná se o skript, který dá všechny nepoužívané jaderné moduly na blacklist (/etc/modprobe.d/modulejail-blacklist.conf).

    Ladislav Hagara | Komentářů: 1
    18.5. 16:11 | Zajímavý článek

    Odborníci z Penn State University zkoumají způsob ukládání informací na lepicí pásku. Principiálně by podle nich bylo možné kombinací odlepení a zpětného přilepení dosáhnout uložení informace, kterou opětovným odlepením dokážou přečíst. Výhodou je, že způsob uložení i přečtení je čistě mechanický. Zde o tom referují ve volně dostupném článku. Zajímavé bude sledovat zda se jim v rámci výzkumu podaří prokázat použitelnost i v jiné než

    … více »
    karkar | Komentářů: 10
    18.5. 13:00 | Zajímavý projekt

    Na GitHubu byl publikován reprodukovatelný návod, jak rozchodit Adobe Lightroom CC na Linuxu a Wine. Návod byl vytvořený pomocí AI Claude Code.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (13%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (6%)
     (3%)
     (16%)
     (26%)
    Celkem 1669 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: BASH a pomaly prubeh skriptu

    26.9.2006 16:31 Chap
    BASH a pomaly prubeh skriptu
    Přečteno: 150×
    Ahoj, jsem v bashi zacatecnik (resp jsem jen potreboval prepsat neco z PHP). Mam nasledujici problem: Po spusteni skriptu s IP adresou externe predanou skriptu ($1).

    U skriptu jsou dva soubory a to tt.txt - ve kterem jsou prvni cisla z IP adres ,je jich 20 ktere se vyskytuji u ceskych rozsahu (X.0.0.0), cislo v tomto souboru je ulozeno ve tvaru +213+, abych zamezil moznosti napr grep 13 muze vratit 213.

    v souboru rozsahy.txt jsou vsechny ceske rozsahy ve formatu: 1-10znak zacatek rozsahu a 11-20 konec rozsahu ve tvaru ip2long.

    tudiz provadim nasledujici: GREP prvniho cisla IP v tt.txt pokud se zde nenachazi, automaticky se jedna o zahranicni IP. Pokud se v tt.txt nachazi zacnu prohledavat rozsahy.txt a porovnavat zda ip2long(ip) je v intervalu z nektereho z rozsahu.

    No a problem je ze prohledani 1 adresy trva radove 2-20s a potrebuji aby to zjistovalo radove v ms. Doufam ze jsem problem popsal dostatecne a ze je to jen nejaka moje lamerina. Predem dik za odpovedi.

    a zde je kod
    
    #!/bin/bash
    
    function ip2long(){
    	local IP="${1:?Missing ip in $FUNCNAME}"
    	local IP_SUM=0
    	local COUNT=3
    	for i in `echo "$IP"|sed 's:\.: :g'`; do
    		let IP_SUM+=$(($i<<($COUNT*8)))
    		let COUNT--
    	done
    	echo "$IP_SUM"
    }
    
    
    function najdiCZIP(){
    	ret="N"
    	long=`ip2long $1`
    	ipzac=`echo $1|cut -d. -f1`
    	if [ -n `cat tt.txt|grep +$ipzac+` ]
    	then 
    	  for k in `cat rozsahy.txt` 
    		do
    			start=`echo $k|cut -c1-10`
    			stop=`echo $k|cut -c11-20`
    			#echo "$start $long $stop"
    			if [ $long -ge $start ] && [ $long -le $stop ]
    				then
    				ret="C"
    				break
    			fi
    		done
    	fi
    	echo $ret
    }
    
    najdiCZIP $1
    

    Odpovědi

    26.9.2006 20:21 Jan Martinek | skóre: 43 | blog: johny | Brno
    Rozbalit Rozbalit vše Re: BASH a pomaly prubeh skriptu
    Nevím, jestli správně chápu zadání, ale jednotlivě (pod)sítě by bylo lepší definovat klasicky jako
    n.n.n.n/m.m.m.m
    eventuelně
    n.n.n.n/b (b je počet jedničkových bitů v masce)
    Kvůli obecnosti se budu držet první varianty zápisu. Jestliže chci zjistit, zda daná IP adresa patří do nějaké sítě, tak na ni aplikuju masku a musí mi vyjít to číslo před lomítkem. Pokud vyjde něco jiného, pak IP adresa do sítě nepatří. Takže kdybych měl soubor "site.txt", ve kterém budou řádky ve tvaru n.n.n.n/m.m.m.m pak můžu napsat třeba tento program:
    #!/usr/bin/env python
    import socket, struct, sys
    
    def ascii_ip_ton(ascii_quad):
        return struct.unpack('!L',socket.inet_aton(ascii_quad))[0]
    
    tested_ip_a = sys.argv[1]
    tested_ip = ascii_ip_ton(tested_ip_a)
    
    for pair in file('site.txt'):
        pair = pair.strip()
        network_a, mask_a = pair.split('/')
        network = ascii_ip_ton(network_a)
        mask = ascii_ip_ton(mask_a)
        if tested_ip & mask == network:
            print tested_ip_a, 'belongs to', pair
    
    Za sekundu zvládne zkontrolovat příslušnost ke 100 000 sítím. Ani trochu jsem se nesnažil to optimalizovat. Kdyby to bylo pořád málo, je zde možnost kešovat IP adresy převedené do numerického formátu.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.