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í
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
dnes 06:00 | Zajímavý software

OMG! Ubuntu! představuje emulátor terminálu Hyper (GitHub) postavený na webových technologiích (HTML, CSS a JavaScript). V diskusi k článku je zmíněn podobný emulátor terminálu Black Screen. Hyper i Black Screen používají framework Electron, stejně jako editor Atom nebo vývojové prostředí Visual Studio Code.

Ladislav Hagara | Komentářů: 23
dnes 06:00 | Zajímavý článek

I letos vychází řada ajťáckých adventních kalendářů. QEMU Advent Calendar 2016 přináší každý den nový obraz disku pro QEMU. Programátoři se mohou potrápit při řešení úloh z kalendáře Advent of Code 2016. Kalendáře Perl Advent Calendar 2016 a Perl 6 Advent Calendar přinášejí každý den zajímavé informace o programovacím jazyce Perl. Stranou nezůstává ani programovací jazyk Go.

Ladislav Hagara | Komentářů: 4
3.12. 16:24 | Nová verze

Byla vydána Mageia 5.1. Jedná se o první opravné vydání verze 5, jež vyšla v červnu loňského roku (zprávička). Uživatelům verze 5 nepřináší opravné vydání nic nového, samozřejmě pokud pravidelně aktualizují. Vydání obsahuje všechny aktualizace za posledního téměř půldruhého roku. Mageia 5.1 obsahuje LibreOffice 4.4.7, Linux 4.4.32, KDE4 4.14.5 nebo GNOME 3.14.3.

Ladislav Hagara | Komentářů: 14
3.12. 13:42 | Pozvánky

V Praze probíhá konference Internet a Technologie 16.2, volné pokračování jarní konference sdružení CZ.NIC. Konferenci lze sledovat online na YouTube. K dispozici je také archiv předchozích konferencí.

Ladislav Hagara | Komentářů: 0
2.12. 22:44 | Komunita

Joinup informuje, že Mnichov používá open source groupware Kolab. V srpnu byl dokončen dvouletý přechod na toto řešení. V provozu je asi 60 000 poštovních schránek. Nejenom Kolabu se věnoval Georg Greve ve své přednášce Open Source: the future for the European institutions (SlideShare) na konferenci DIGITEC 2016, jež proběhla v úterý 29. listopadu v Bruselu. Videozáznam přednášek z hlavního sálu je ke zhlédnutí na Livestreamu.

Ladislav Hagara | Komentářů: 25
2.12. 15:30 | Zajímavý projekt

Společnost Jolla oznámila v příspěvku Case study: Sailfish Watch na svém blogu, že naportovala Sailfish OS na chytré hodinky. Využila a inspirovala se otevřeným operačním systémem pro chytré hodinky AsteroidOS. Použita je knihovna libhybris. Ukázka ovládání hodinek na YouTube.

Ladislav Hagara | Komentářů: 15
2.12. 14:15 | Nová verze

Byla vydána verze 7.1.0 skriptovacího jazyka PHP používaného zejména k vývoji dynamických webových stránek. Jedná se o první stabilní verzi nejnovější větvě 7.1. Přehled novinek v dokumentaci. Podrobnosti v ChangeLogu. K dispozici je také příručka pro přechod z PHP 7.0.x na PHP 7.1.x.

Ladislav Hagara | Komentářů: 4
2.12. 12:55 | Nová verze

Google Chrome 55 byl prohlášen za stabilní. Nejnovější stabilní verze 55.0.2883.75 tohoto webového prohlížeče přináší řadu oprav a vylepšení (YouTube). Opraveno bylo také 36 bezpečnostních chyb. Mariusz Mlynski si například vydělal 22 500 dolarů za 3 nahlášené chyby (Universal XSS in Blink).

Ladislav Hagara | Komentářů: 4
2.12. 11:55 | Pozvánky

Máte rádi svobodný software a hardware nebo se o nich chcete něco dozvědět? Přijďte na 135. sraz spolku OpenAlt, který se bude konat ve čtvrtek 8. prosince od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Sraz bude tentokrát tématický. Bude retro! K vidění budou přístroje jako Psion 5mx nebo Palm Z22. Ze svobodného hardwaru pak Openmoko nebo čtečka WikiReader. Přijďte se i vy pochlubit svými legendami, nebo alespoň na pivo. Moderní hardware má vstup samozřejmě také povolen.

xkucf03 | Komentářů: 1
2.12. 00:10 | Nová verze

Byla vydána verze 3.2 svobodného systému pro detekci a prevenci průniků a monitorování bezpečnosti počítačových sítí Suricata. Z novinek lze zmínit například podporu protokolů DNP3 a CIP/ENIP, vylepšenou podporu TLS a samozřejmě také aktualizovanou dokumentaci.

Ladislav Hagara | Komentářů: 0
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (24%)
 (29%)
 (7%)
 (5%)
 (3%)
Celkem 773 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama

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: 284×
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: 60 | 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.