ALT Linux Sisyphus discussions
 help / color / mirror / Atom feed
* [sisyphus] не отрабатывает нормально start-stop-deamon (имя процесса содержит пробелы)
@ 2014-05-07 16:00 Denis G. Samsonenko
  2014-05-07 16:47 ` Dmitry V. Levin
  0 siblings, 1 reply; 14+ messages in thread
From: Denis G. Samsonenko @ 2014-05-07 16:00 UTC (permalink / raw)
  To: sisyphus

День добрый!

Разбираясь с ddclient обнаружил, что не отрабатывает останов сервиса.
Процесс продолжает работать после останова. Соответственно повторный
запуск запускает ещё один процесс. То же самое происходит при рестарте
сервиса.

Покопавшись в /rc.d/init.d/ddclientd и /rc.d/init.d/functions понял,
что start-stop-daemon не находит процесс ddclient.

$ ps ax |grep ddclient
8562 ?        S      0:00 ddclient - sleeping for 30 seconds

$ cat /proc/8562/cmdline
ddclient - sleeping for 30 seconds

$ cat /proc/8562/stat
8562 (ddclient - slee) S 1 8481 8481 0 -1 1077944384 999 3150 0 0 2 0
0 1 20 0 1 0 5329363 30277632 1811 18446744073709551615 4194304
4198956 140736794566528 140736794565432 140013415770624 0 0 128 16385
18446744071579414165 0 0 17 2 0 0 0 0 0 6299072 6299804 6303744
140736794570065 140736794570112 140736794570112 140736794570725 0

На сколько я понял, start-stop-daemon сверяет заданное имя процесса с
тем, что находит в /proc/[pid]/stat, а там оно оказывается таким:
"ddclient - slee".

Ручной запуск start-stop-daemon с параметром --name "ddclient - slee"
отрабатывает нормально:

# start-stop-daemon --stop --test --name "ddclient - slee" --pidfile
/var/run/ddclient/ddclient.pid
Would send signal 15 to 8562.


Если же запустить с --name ddclient, то отработает с ошибкой:

# start-stop-daemon --stop --test --name ddclient --pidfile
/var/run/ddclient/ddclient.pid
No ddclient found running; none killed.


Попытка подсунуть --name "ddclient - slee" в /rc.d/init.d/ddclientd не
приводит к успеху. По видимому где-то по дороге к вызову
start-stop-daemon теряются кавычки. Пытался по всякому их вкладывать и
экранировать -- не помогло.

Можно как-нибудь с этим справиться?

-- 
Всего доброго,

Денис.

^ permalink raw reply	[flat|nested] 14+ messages in thread

end of thread, other threads:[~2014-05-12 10:24 UTC | newest]

Thread overview: 14+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2014-05-07 16:00 [sisyphus] не отрабатывает нормально start-stop-deamon (имя процесса содержит пробелы) Denis G. Samsonenko
2014-05-07 16:47 ` Dmitry V. Levin
2014-05-07 20:35   ` Alexei V. Mezin
2014-05-07 21:10     ` Michael Shigorin
2014-05-07 21:29       ` Alexei V. Mezin
2014-05-07 21:44         ` Dmitry V. Levin
2014-05-08 12:19           ` Denis G. Samsonenko
2014-05-08 12:47             ` Denis G. Samsonenko
2014-05-08 12:53               ` Denis G. Samsonenko
2014-05-09 18:17                 ` Michael Shigorin
2014-05-09 18:41                   ` Paul Wolneykien
2014-05-12 10:24                     ` Rinat Bikov
2014-05-08 12:50             ` Alexei V. Mezin
2014-05-08 12:55               ` Denis G. Samsonenko

ALT Linux Sisyphus discussions

This inbox may be cloned and mirrored by anyone:

	git clone --mirror http://lore.altlinux.org/sisyphus/0 sisyphus/git/0.git

	# If you have public-inbox 1.1+ installed, you may
	# initialize and index your mirror using the following commands:
	public-inbox-init -V2 sisyphus sisyphus/ http://lore.altlinux.org/sisyphus \
		sisyphus@altlinux.ru sisyphus@altlinux.org sisyphus@lists.altlinux.org sisyphus@lists.altlinux.ru sisyphus@lists.altlinux.com sisyphus@linuxteam.iplabs.ru sisyphus@list.linux-os.ru
	public-inbox-index sisyphus

Example config snippet for mirrors.
Newsgroup available over NNTP:
	nntp://lore.altlinux.org/org.altlinux.lists.sisyphus


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git