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 19:55 | Zajímavý článek

Byly zveřejněny (pdf) podrobnosti o kritické bezpečnostní chybě CVE-2017-12542 v HPE iLO 4 (Integrated Lights-Out), tj. v proprietárním řešení společnosti Hewlett Packard Enterprise pro vzdálenou správu jejich serverů. Bezpečnostní chyba zneužitelná k obejití autentizace a k vzdálenému spuštění libovolného kódu byla opravena již v květnu loňského roku ve verzi 2.53.

Ladislav Hagara | Komentářů: 1
dnes 17:55 | Zajímavý projekt

CSIRT.CZ informuje o CTF (Capture the Flag) platformě ZSIS CTF s úlohami pro procvičování praktických dovedností z oblasti kybernetické bezpečnosti a upozorňuje na soutěž Google Capture the Flag 2018, kde je možné vyhrát zajímavé ceny.

Ladislav Hagara | Komentářů: 0
dnes 17:00 | Komunita

Byly zveřejněny prezentace a videozáznamy přednášek z prvního československého setkání síťových operátorů CSNOG konaného 11. a 12. června v Brně a semináře IPv6 2018 uskutečněného 6. června v Praze.

Ladislav Hagara | Komentářů: 0
dnes 16:11 | Komunita

Svobodný unixový operační systém FreeBSD slaví 25 let. Přesně před pětadvaceti lety, tj. 19. června 1993, byl vybrán název FreeBSD.

Ladislav Hagara | Komentářů: 0
dnes 15:11 | Komunita

Oficiální YouTube kanál Blenderu je již několik dní blokován. Nadace Blender Foundation informuje, že od společnosti Google dostala šestistránkový návrh nové smlouvy (pdf). Zdá se, že podmínkou další spolupráce je zapnutí reklam na kanálu, tj. zpeněžení obsahu.

Ladislav Hagara | Komentářů: 21
dnes 01:55 | Nová verze

Byla vydána verze 1.13 multiplatformního open source textového editoru Brackets (Wikipedie, GitHub). Přehled novinek v oficiálním oznámení a v poznámkách k vydání. Brackets je nově dostupný také jako balíček ve formátu Flatpak z oficiálního repozitáře Flathub.

Ladislav Hagara | Komentářů: 3
včera 18:44 | Komunita

Oficiální YouTube kanál Blenderu je již několik dní blokován. Důvody jsou zatím nejasné. Pravděpodobně chyba YouTube. Dění lze sledovat na Twitteru Tona Roosendaala.

Ladislav Hagara | Komentářů: 18
včera 17:55 | Zajímavý software

Na GitHubu byly pod open source licencí LLVM zveřejněny zdrojové kódy překladače programovacího jazyka C++ Zapcc vycházejícího z Clangu/LLVM. Překlad pomocí Zapccu je díky lepšímu kešování obvykle několikrát rychlejší než překlad pomocí Clangu. V březnu loňského roku byl vydán Zapcc ve verzi 1.0.

Ladislav Hagara | Komentářů: 0
včera 17:22 | Pozvánky

Červnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 21. 6. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát na téma: F-Droid, aneb svobodný software do vašeho mobilu. Kromě toho budou k vidění i vývojové desky HiFive1 se svobodným/otevřeným čipem RISC-V.

xkucf03 | Komentářů: 1
15.6. 22:44 | Zajímavý článek

Na blogu projektu NeoPG (GitHub), kryptografického softwaru vycházejícího z GnuPG, byly zveřejněny 4 příspěvky detailně popisující aktuální bezpečnostní problémy v GnuPG a souvisejících softwarových produktech. V prvním příspěvku je ukázáno, že je možné vytvořit zprávu, o které budou Earlybird, Evolution, Mutt nebo Outlook tvrdit, že jí dešifrovali a přitom ale zpráva vůbec zašifrována nebyla. V druhém příspěvku je popsána

… více »
Ladislav Hagara | Komentářů: 8
Jak čtete delší texty z webových stránek?
 (78%)
 (22%)
 (4%)
 (7%)
 (2%)
 (11%)
Celkem 213 hlasů
 Komentářů: 36, poslední včera 21:16
    Rozcestník

    Dotaz: systemd service: ignoruje parametry příkazu?

    24.1.2015 12:43 JanM | skóre: 28
    systemd service: ignoruje parametry příkazu?
    Přečteno: 312×
    Zdravím,

    nedaří se mi vyřešit situaci, kdy proces démona spuštěný z CLI funguje ok, zatímco při spuštění skrze systemd s týmiž parametry jsou tyto parametry ignorovány a démon běží s výchozími nastaveními.

    Nejprve z CLI:
    $ sudo /usr/bin/ebusd --configpath /etcWRONG/ebusd --logfile /var/log/ebusd-remote/ebusd.log --dumpfile /var/log/ebusd-remote/ebusd.dump --dumpsize 100000 --dump
    $ ps aux | grep /usr/bin/ebusd
    root      5832  0.0  0.2  38392  1080 ?        Ssl  11:23   0:00 /usr/bin/ebusd --configpath /etcWRONG/ebusd --logfile /var/log/ebusd-remote/ebusd.log --dumpfile /var/log/ebusd-remote/ebusd.dump --dumpsize 100000 --dump
    $ cat /var/log/ebusd-remote/ebusd.log
    2015-01-24 11:23:09.646 [bas event] ebusd started
    2015-01-24 11:23:09.647 [bas trace] path to ebus configuration files: /etcWRONG/ebusd
    2015-01-24 11:23:09.648 [bas error] error reading templates: ERR: file/element not found or not readable
    2015-01-24 11:23:09.648 [bas error] error reading config files: ERR: file/element not found or not readable
    A nyní systemd:
    $ cat ebusd.service
    [Unit]
    Description=Communication interface to the energy bus (ebus)
    After=local-fs.target
    ConditionPathExists=/var/log
    
    [Service]
    Type=forking
    EnvironmentFile=-/etc/conf.d/ebusd
    ExecStart=/usr/bin/ebusd ${EBUSD_ARGS}
    PIDFile=/run/ebusd.pid
    
    [Install]
    WantedBy=multi-user.target
    Mohu-li soudit, tak parametry procesu jsou shodné:
    $ ps aux | grep /usr/bin/ebusd
    root      5774  0.0  0.2  46584  1260 ?        Ssl  10:47   0:00 /usr/bin/ebusd --configpath /etcWRONG/ebusd --logfile /var/log/ebusd-remote/ebusd.log --dumpfile /var/log/ebusd-remote/ebusd.dump --dumpsize 100000 --dump
    Jenže jsou ignorovány; log leží jinde, výchozí konfiguraci to čte z /etc/ebusd místo /etcWRONG/ebusd:
    $ cat /var/log/ebusd.log
    2015-01-24 10:47:39.898 [bas event] ebusd started
    2015-01-24 10:47:39.899 [bas trace] path to ebus configuration files: /etc/ebusd
    2015-01-24 10:47:39.935 [bas trace] read templates
    2015-01-24 10:47:39.938 [bas trace] read config files
    2015-01-24 10:47:39.939 [bas event] message DB: 4
    2015-01-24 10:47:39.940 [bas event] updates DB: 0
    2015-01-24 10:47:39.940 [bas event] polling DB: 0
    Co je to za podivnost? Vyžaduje systemd od démona nějaké specifické vlastnosti? (/usr/bin/ebusd sám forkuje a běží na pozadí, což by mělo být klasické chování a odpovídá tomu "Type=forking".) Arch Linux, ARM.

    Řešení dotazu:


    Odpovědi

    24.1.2015 14:34 rastos | skóre: 61 | blog: rastos
    Rozbalit Rozbalit vše Re: systemd service: ignoruje parametry příkazu?
    Posledný parameter commandline-u sa líši. Alebo si to zle pastol.

    To tam vážne máš "/etcWRONG/ebusd" ?

    Skúsil by som porovnať veci pod /proc (cmdline, environment, mounts, ...) v jednom a druhom prípade.

    Je sranda googliť slovné spojenie "systemd wrong" ;-) Mno ... vyzerá to tak, že sa zábava so systemd rozbieha.
    24.1.2015 15:03 vasek
    Rozbalit Rozbalit vše Re: systemd service: ignoruje parametry příkazu?
    No je to pěkně blbá sranda. Nevzpomínám si, že bych v před-systemd době musel některé špatně nabíhající či nenabíhající služby restartovat v /etc/rc.local nebo startovat manuálně a v systemd je zakázat. Doufat v brzké vyřešení bug reportů fakt nehodlám ... Na druhou stranu takhle mohu identifikovat systémy se systemd nebo upstartem jen na základě nadávek v rc.local ... No co buďme rádi za to, že nám server nabíhá 8 sekund a ne těch hrozných 10 sekund.
    24.1.2015 15:13 JanM | skóre: 28
    Rozbalit Rozbalit vše Re: systemd service: ignoruje parametry příkazu?
    Poslední parametr je "--dump", ale na tom až zase tak nesejde. Ona je totiž v systemd ignorována celá ta řádka s parametry, můžu tam psát, co chci.

    Vážně tam mám /etcWRONG/ebusd, abych viděl, že to při akceptaci "path to ebus configuration files: /etcWRONG/ebusd" následně vyhodní chybovou hlášku "error reading templates: ERR: file/element not found or not readable", protože ten adresář neexistuje.
    24.1.2015 18:44 JanM | skóre: 28
    Rozbalit Rozbalit vše Re: systemd service: ignoruje parametry příkazu?
    /proc/PID/... jsem porovnával, nic zvláštního, ale to může být mojí neznalostí.
    24.1.2015 16:30 JanM | skóre: 28
    Rozbalit Rozbalit vše Re: systemd service: ignoruje parametry příkazu?
    Při "systemctl start ebusd" to v systémovém logu hodí hlášku "Failed to reset devices.list on /system.slice: Invalid argument", chvíli jsem hledal, zda by to mohlo souviset, zatím žádný výsledek.
    25.1.2015 08:08 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: systemd service: ignoruje parametry příkazu?
    A jste si jistý, že systemd opravdu používá vás změněný /etc/systemd/system/ebusd.service?
    25.1.2015 09:42 JanM | skóre: 28
    Rozbalit Rozbalit vše Re: systemd service: ignoruje parametry příkazu?
    Celkem ano, k problému jsem se dostal při snaze vytvořit PKGBUILD pro Arch. V contribu zdrojáků jsou jen init skripty pro Debian, systemd na ARMech asi ještě moc rozšířen není :-)

    Modifikací proměnných v /etc/conf.d/ebusd dosáhnu změny parametrů procesu (/proc/PID/cmdline). Jinou binárku v PATH na systému nemám. Mohu ty parametry natvrdo napsat do /usr/lib/systemd/system/ebusd.service (třeba i s jinou modifikací, abych si byl jist), ale stejně jsou při běhu ignorovány.

    Vyzkouším totéž na x86, abych zúžil množinu sprostých podezřelých.
    25.1.2015 11:40 JanM | skóre: 28
    Rozbalit Rozbalit vše Re: systemd service: ignoruje parametry příkazu?
    Cvičně jsem to vyzkoušel na Lubuntu 12.04 arm, init skript spouští démona, jak má, vč. parametrů a démon také dělá co má.

    Pak ještě totéž na Archu x86_64, tam to blbne stejně jako na ARMu. Napsal jsem autorovi a optal se na archlinuxARM, tak uvidíme.
    Řešení 1× (JanM (tazatel))
    25.1.2015 12:05 NemamRadSystemD
    Rozbalit Rozbalit vše Re: systemd service: ignoruje parametry příkazu?
    Mas u prirazeni EBUSD_ARGS uvozovky? Dej je pryc. I like that logic.
    25.1.2015 12:36 JanM | skóre: 28
    Rozbalit Rozbalit vše Re: systemd service: ignoruje parametry příkazu?
    vyhodil jsem je, ale výsledek je stejný, :-(
    $ cat /etc/conf.d/ebusd
    # /etc/conf.d/ebusd: config file for ebusd.service
    # Options to pass to the ebusd.
    # See the ebusd -h for more info.
    
    EBUSD_ARGS=--configpath /etcNONEXISTENT/ebusd --logfile /tmp/ebusd.log
    tak jsem je tam pro další testování zase vrátil

    Navedlo mne to ovšem správným směrem. V ebusd.service jsem změnil ExecStart=/usr/bin/ebusd ${EBUSD_ARGS} na ExecStart=/usr/bin/ebusd $EBUSD_ARGS et voilà, funguje to!

    Manuál systemd říká, že je to feature a ne bug:

    Basic environment variable substitution is supported. Use "${FOO}" as part of a word, or as a word of its own, on the command line, in which case it will be replaced by the value of the environment variable including all whitespace it contains, resulting in a single argument. Use "$FOO" as a separate word on the command line, in which case it will be replaced by the value of the environment variable split at whitespace resulting in zero or more arguments. For this type of expansion, quotes and respected when splitting into words, and afterwards removed.

    V každém případě velmi děkuji za nakopnutí, škoda, že jsem na tom strávil tolik času.

    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.