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í
×
včera 04:00 | Komunita

S ukončením podpory Windows 7 spustila Nadace pro svobodný software (FSF) kampaň Upcycle Windows 7 s peticí žádající Microsoft, aby zveřejnil zdrojové kódy tohoto již nepodporovaného operačního systému pod svobodnou licencí. S uvedením Windows 7 v roce 2009 byla spuštěna kampaň Windows 7 Sins.

Ladislav Hagara | Komentářů: 18
včera 03:00 | Komunita

Sedmý ročník největší české konference o redakčním systému WordPress WordCamp Praha 2020 se uskuteční v sobotu 29. února v pražském Cubex Centru na Pankráci. Na účastníky letos čekají tři tracky přednášek českých i zahraničních řečníků, několik workshopů, případových studií a samozřejmě i Happiness bar, kam se můžete přijít poradit s odborníky. Je to také ideální příležitost potkat stovky dalších WordPress nadšenců i profesionálů.

… více »
smíťa | Komentářů: 0
včera 02:00 | IT novinky

Společnost Proton Technologies stojící za virtuální privátní sítí ProtonVPN otevřela všechny aplikace ProtonVPN pod licenci GPLv3. Současně oznámila, že tyto aplikace prošly bezpečnostním auditem. Také díky spolupráci s organizací Mozilla.

Fair | Komentářů: 0
25.1. 04:00 | Komunita

Na Youtube byl zveřejněn videozáznam jednání odvolacího soudu ve sporu Grsecurity (Open Source Security) vs. Bruce Perens [reddit].

Ladislav Hagara | Komentářů: 5
25.1. 03:00 | Komunita

Byl vyhlášen vítězný wallpaper soutěže o nejlepší wallpaper pro KDE Plasmu LTS 5.18. Vítězným a tedy výchozím wallpaperem je Volna. Autor wallpaperu Nikita Babin získává notebook od TUXEDO Computers.

Ladislav Hagara | Komentářů: 12
25.1. 02:00 | Nová verze

Nová verze ODF 1.3 (Open Document Format), výchozího formátu dokumentů LibreOffice, byla schválena standardizační komisí OASIS. Mezi novinky ve formátu patří digitální podpis a XML šifrování dokumentů založené na OpenPGP, plus několik vylepšení funkcí již dostupných v ODF 1.2, jako jsou nové typy regresních křivek pro grafy, nová specifikace počtu desetinných míst ve formátování čísel, speciální styl záhlaví/zápatí pro první

… více »
Zdeněk Crhonek | Komentářů: 0
24.1. 09:00 | Komunita

V Brně na FIT VUT probíhá DevConf.CZ 2020, již dvanáctý ročník jedné z největších akcí zaměřených na Linux a open source ve střední Evropě. Na programu je celá řada zajímavých přednášek a workshopů. Aktuální dění lze sledovat například na Twitteru.

Ladislav Hagara | Komentářů: 0
23.1. 23:44 | Komunita

Společnost Psyonix, v květnu 2019 koupena společností Epic Games, oznámila konec podpory počítačové hry Rocket League na Linuxu a macOS. Poslední aktualizace pro tyto operační systémy vyjde v březnu a odstraní možnost hrát tento automobilový fotbal online.

Ladislav Hagara | Komentářů: 13
23.1. 14:33 | Zajímavý článek

Nová čísla časopisů od nakladatelství Raspberry Pi: MagPi 89 (pdf), HackSpace 26 (pdf) a 27 (pdf) a Wireframe 28 (pdf), 29 (pdf) a 30 (pdf).

Ladislav Hagara | Komentářů: 0
23.1. 14:11 | Nová verze

Byla vydána nová verze 12.7 open source alternativy GitHubu, tj. softwarového nástroje s webovým rozhraním umožňujícího spolupráci na zdrojových kódech, GitLab (Wikipedie). Představení nových vlastností v příspěvku na blogu.

Ladislav Hagara | Komentářů: 3
Zdají se vám sny s IT tématikou?
 (9%)
 (1%)
 (13%)
 (17%)
 (54%)
 (7%)
Celkem 271 hlasů
 Komentářů: 10, poslední 18.1. 16:18
Rozcestník

www.AutoDoc.Cz

Dotaz: Jak nastavit po restartu ip route

otula avatar 21.4.2017 09:53 otula | skóre: 44 | blog: otakar | Adamov
Jak nastavit po restartu ip route
Přečteno: 424×
Aktualizoval jsem po nějakém roce jistý server a nejsem schopen přijít na to, jak po startu systému spustit automaticky nějaký příkaz. Dříve to bylo prosté a jednoduché – stačilo ho zadat do /etc/rc.local. Nyní to nejde a po celém internetu je spousta dalších zoufalců, kterým se to nedaří. Obecně se radí vytvořit si pro systemd službu rc-local.service, jenže ono její spuštění (pokud rc.local obsahuje požadovaný příkaz) jaksi během bootování neprojde (pokud je rc.local prázdný, spuštní proběhne v pořádku). Přičemž pokud danou službu zkusím nastartovat ručně po přihlášení, tak se normálně nastartuje (i s požadovaným příkazem v rc.local). Ale automatické spuštění selže.

Nejvíce mne tedy momentálně trápí automatické spuštění příkazu
ip route add a.b.c.d/e via w.x.y.z dev ethX
případně jiný způsob, jak docílit stejného výsledku.

Používám aktuální archlinux, síť spouštím přes systemd-networkd.service.
Kdo vám tvrdí, že jste paranoidní, ten v tom spiknutí s největší pravděpodobností jede taky.

Řešení dotazu:


Odpovědi

21.4.2017 10:20 MP
Rozbalit Rozbalit vše Re: Jak nastavit po restartu ip route
Nevim v cem ma arch definovanou sit, ale v klasickym /etc/network/interfaces se to delalo pomoci "up ip route...". Pokud je sit nadefinovana jako systemd unita (.network, .netdev atd), tak se da pouzit parametr Gateway u konkretniho interface/site.
Řešení 1× (otula (tazatel))
21.4.2017 10:55 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
Rozbalit Rozbalit vše Re: Jak nastavit po restartu ip route
Nebude problém v tom že se rc.local spustí a ještě neexistuje zařízení dev ethX ?

Já jsem na začátek skriptu musel dát příkaz pro čekání několik sekund pak mi to funguje.

Skus k příkazům přidat přesměrování do souboru aby jsi si mohl přečíst na čem to zhavarovalo.
otula avatar 21.4.2017 11:23 otula | skóre: 44 | blog: otakar | Adamov
Rozbalit Rozbalit vše Re: Jak nastavit po restartu ip route
Petře, děkuji, bylo to ono. Přihodil jsem na začátek sleep 15s, zkusil pro jistotu dvakrát zrestartovat, a pokaždé to naběhlo OK.
Kdo vám tvrdí, že jste paranoidní, ten v tom spiknutí s největší pravděpodobností jede taky.
21.4.2017 11:29 Michal Kubeček | skóre: 71 | Luštěnice
Rozbalit Rozbalit vše Re: Jak nastavit po restartu ip route

Řešení race conditions pomocí náhodně přidaných sleepů je cesta do pekel. Když potřebujete něco spustit, až se to rozhraní objeví a bude nakonfigurované, tak si buď počkejte na příslušný event, nebo na to aspoň počkejte smyčkou. Vyhnete se pak nepříjemným a velmi obtížně debugovatelným překvapením v budoucnosti.

Jinak je IMHO chyba tohle vůbec řešit vlastním skriptem. Když už jste se jednou rozhodl svou konfiguraci sítě svěřit systemd-networkd, není dobrý nápad se v ní vrtat za jeho zády, ale měl byste tu routu přidat jeho prostřednictvím.

otula avatar 21.4.2017 11:41 otula | skóre: 44 | blog: otakar | Adamov
Rozbalit Rozbalit vše Re: Jak nastavit po restartu ip route
Díky za info. Už jsem předtím zkoušel spustit ještě jiný příkaz, a i když jsem si vyjel celý strom posloupnosti a nechal umístit spuštění rc-local až za ten poslední, kam mne to pustilo, stejně se mi nespustil. Tak jsem dál laboroval s parametry toho .service skriptu, ale bez úspěchu. Takže ač není sleep ideální, dokáže pomoci ven z problému.

Každopádně máte naprostou pravdu, že nejkrásnější a nejčistší řešení tohoto konkrétního případu je to, co mi poradil Heron. Ačkoliv jsem hledal dost dlouho, nepodařilo se mi právě tohle nikde najít. Asi jsem nezadal správné parametry pro hledání. Všude jsou návody pro distribuce, které to řeší jinak. A v ArchWiki je nefunkční řešení (stejně jako v jiných situacích, kdy se na ni nedá moc spolehnout)...
Kdo vám tvrdí, že jste paranoidní, ten v tom spiknutí s největší pravděpodobností jede taky.
Heron avatar 21.4.2017 12:01 Heron | skóre: 52 | blog: root_at_heron | Olomouc
Rozbalit Rozbalit vše Re: Jak nastavit po restartu ip route
No já se celkem divím, že tohle na archwiki není. Ač jsem uživatel Debianu, tak při hledání věcí týkající se zejména systemd, tak archwiki často poradí. (Pokud se nepletu, byla to první distribuce, která na sd přešla.)

Přidání statické routy bych tedy právě v této wiki očekával.

Ono to může být matoucí, protože systemd.network připouští víc způsobů nastavení téhož.

Můžete mít sekci [Network], kde se nastaví vše (tj Address a Gateway a DNS). Nebo taky můžete mít sekce [Address] a [Route] a mít to (tedy IP a GW) nastaveno ve dvou sekcích. No jenže sekcí [Route] tam může být víc a to včetně uvedení Destination - to ovšem nenastavuje default gw, ale routu pro danou sít. Takže se může plést nastavení default gw s nastavením statických rout.

Osobně si život zjednodušuju tak, že mám jednu sekci [Network], kde mám adresy a default gw a potom více sekcí [Route], kam si strkám statické routy. A nic se mi neplete.

Ukázka:
[Match]
Name=br0

[Network]
Address=xxx/29
Gateway=xxx

Address=192.168.xx/24

[Route]
Destination=10.0.0.0/24
Gateway=yyy

[Route]
Destination=10.8.0.0/24
Gateway=zzz
Ale chápu, že i samostatné sekce Address a Route mají svůj význam, protože tam toho jde nastavit mnohem víc.
otula avatar 21.4.2017 12:22 otula | skóre: 44 | blog: otakar | Adamov
Rozbalit Rozbalit vše Re: Jak nastavit po restartu ip route
On to není jen problém ArchWiki. Včera jsem ze starého serveru kopíroval nastavení iptables (není nikam připojen, slouží jen na vnitřní síti, takže si už spoustu let v klidu běžel se zastaralým sw). A měl jsem jako jeden z parametrů -i ! eth1. To už ovšem nyní použít nelze. Na tom by nebylo nic až tak divného, kdyby v manuálových stránkách (aktuálního) iptables nebylo psáno: When the "!" argument is used before the interface name, the sense is inverted. Jenže on nemá být před interface name, ale ještě před parametrem -i.

Každopádně ještě jednou díky za radu.
Kdo vám tvrdí, že jste paranoidní, ten v tom spiknutí s největší pravděpodobností jede taky.
21.4.2017 12:44 Michal Kubeček | skóre: 71 | Luštěnice
Rozbalit Rozbalit vše Re: Jak nastavit po restartu ip route

Tahle matoucí věta tam sice zůstala, ale jinak je tam (od roku 2008)

    [!] -i, --in-interface name

místo původního

    -i, --in-interface [!] name
otula avatar 21.4.2017 19:45 otula | skóre: 44 | blog: otakar | Adamov
Rozbalit Rozbalit vše Re: Jak nastavit po restartu ip route
Jasně, mohlo mě to trknout, jenže zřejmě tím, že [!] stojí na začátku řádku, či tím, že manuálové stránky čtu jednou za x let a nejsem zběhlý v jejich syntaxi, mne to trklo až ve chvíli, když už jsem věděl, že to tak má být. Prostě jsem našel -i a přečetl si doprovodný text. To je jedno, každopádně jsem to nakonec vyřešil :)
Kdo vám tvrdí, že jste paranoidní, ten v tom spiknutí s největší pravděpodobností jede taky.
21.4.2017 12:01 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
Rozbalit Rozbalit vše Re: Jak nastavit po restartu ip route
Jasně souhlasím s tím že pokud nastavuje síť pomocí systemd tak by i kompletní konfigurace měla být zapsána na jednom místě a né to přenastavovat v rc.local.

Jediné co jsem nepochopil proč rc.local není spuštěný až jako uplně poslední, pak by se nemuselo různě čekat vše by mělo už běžet....
21.4.2017 12:36 Michal Kubeček | skóre: 71 | Luštěnice
Rozbalit Rozbalit vše Re: Jak nastavit po restartu ip route

Nejsem znalec systemd (spíš se snažím zkoumání jeho detailů v mezích možností vyhýbat), ale nejsem si jistý, jestli jde takový okamžik v jeho koncepci dost dobře definovat. A pokud ano, může to být o dost později, než byste čekal.

Nedávno jsem třeba narazil na to, že jsem potřeboval udělat crash dump s ladícím jádrem, problém byl snadno reprodukovatelný, takže zdánlivě žádný problém. A byl jsem překvapený, že se dump se nevytvořil. Ukázalo se, že ve chvíli, kdy jsem chybu vyvolal, ještě pořád nestihla doběhnout služba, která při startu natáhne kdump kernel a v případě potřeby předtím k němu ještě vygeneruje initrd (pokud neexistuje). Takže by se vám klidně mohlo stát, že už se úspěšně nalogujete, napíšete pár příkazů a ta routa tam pořád ještě nebude. Případně na serveru už poběží služby, které na tu routu budou spoléhat.

IMHO není obecně moc šťastné spoléhat na nějaký "úplně nakonec" skript, ale je lepší si ujasnit, na čem konkrétně má váš skript záviset (a co má případně záviset na něm). Koneckonců i za starých dobrých časů před systemd šlo takové závislosti pro vlastní init script definovat. (Ale má to samozřejmě všechno smysl jen pro věci, které nelze zapsat do standardní systémové konfigurace.)

pepe_ avatar 21.4.2017 11:09 pepe_ | skóre: 47
Rozbalit Rozbalit vše Re: Jak nastavit po restartu ip route

Nezaručuju že to pojede naprosto všude ale :

A co si vytvořit pomocný script třeba

 

sudo touch /root/iproute.sh

sudo chmod +x /root/iproture.sh

echo 'ip route add a.b.c.d/e via w.x.y.z dev ethX' | sudo tee --append /root/iproute.sh > /dev/null

 

pak dát

 

sudo crontab -e

 

napsat tento řádek

 

@reboot root /root/iproute.sh

 

a uložit     (podle editoru , např ve vi   dát    :wq     ) .

 

 

Otestuj pak restartem.

pepe_ avatar 21.4.2017 11:12 pepe_ | skóre: 47
Rozbalit Rozbalit vše Re: Jak nastavit po restartu ip route

 

sudo chmod +x /root/iproture.sh            změnit na    iproute.sh

 

 

Po 2000 letech stále nefunguje editace přízpěvku ... (fuj)

21.4.2017 11:24 Michal Kubeček | skóre: 71 | Luštěnice
Rozbalit Rozbalit vše Re: Jak nastavit po restartu ip route
/root/iproute.sh

Po jednom takovém jako vy jsem kdysi zdědil systém. Všude neskutečný bordel, klíčové skripty rozházené v naprosto náhodně zvolených adresářích, člověk se musel bát cokoli smazat, jakákoli nevinná změna způsobila, že se někde úplně jinde něco sesypalo…

pepe_ avatar 21.4.2017 11:30 pepe_ | skóre: 47
Rozbalit Rozbalit vše Re: Jak nastavit po restartu ip route

Jj , máte pravdu. Systemd jde ale stejným směrem že se nikdo nevyzná v té evoluci takže je to vlastně trendy.

Řešení 2× (Michal Kubeček, otula (tazatel))
Heron avatar 21.4.2017 11:16 Heron | skóre: 52 | blog: root_at_heron | Olomouc
Rozbalit Rozbalit vše Re: Jak nastavit po restartu ip route
Pokud používáš systemd-networkd.service, tak si routu nastav přímo v .network souboru (kde máš definici adresy, default gw apod.). Stačí přidat sekci:
[Route]
Destination=a.b.c.d/e
Gateway=w.x.y.z
a je to.
otula avatar 21.4.2017 11:30 otula | skóre: 44 | blog: otakar | Adamov
Rozbalit Rozbalit vše Re: Jak nastavit po restartu ip route
Super, mockrát díky, tohle je pro tento případ krásně čisté řešení.
Kdo vám tvrdí, že jste paranoidní, ten v tom spiknutí s největší pravděpodobností jede taky.

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.