set user id for service ?

Havoc Pennington hp at redhat.com
Fri Sep 15 19:54:33 BST 2006


Scott James Remnant wrote:
> 
> As for the own IPC system, the answer is simply that dbus isn't yet
> stable enough or ubiquitous enough to be a dependency of the one process
> that causes the kernel to PANIC! if it goes away <g>

I don't see this ever making sense really. Code sharing just isn't as 
important as modularity and avoiding circular module dependencies, and 
it would be nice to be able to log in to single user mode and fix dbus 
if it breaks ;-)

However, at the same time afaik upstart need not consist solely of the 
init process, it could have an init process that bootstraps and does 
certain tasks that need to be in process 1, and then communicate with 
other helper or related processes to do other tasks. I can imagine an 
architecture where process 1 is essentially a "spawn server" that 
exports an API for running fork/exec and then monitoring/killing the 
resulting processes; intelligence beyond that (such as config file 
parsing and event monitoring) could live in another process. (David, 
perhaps in this setup the spawn helper you were talking about for dbus 
is just a service file parser, that then tells init what to launch ? I 
don't know)

The important thing I think is that app and daemon developers are clear 
on which API and mechanism to use for each specific case where they want 
to accomplish task XYZ. I don't think "it's all configurable! there's a 
big sea of IPC proxies and bridges!" is a good answer for that.

So maybe someone should list some use-cases here. There's the ipod 
thing, and the "network interface came up"/NetworkManager thing, power 
management stuff, and whatever else.

For example if I want to notify other daemons and apps about a system 
event, how do I normally do that.

>  - dbus daemon must be able to be restarted without losing client
>    connections  (upgrade dbus and be unable to tell your machine to
>    reboot?  OOPS! :p)

I have no idea how this could even theoretically be done ;-) right now 
the system dbus is effectively like init or the kernel; if you want to 
restart it, you have to reboot. I suppose we could somehow stash all the 
file descriptors and then exec() a new daemon over the old one, but it's 
just scary as hell.

Oh, one thing I should mention is that (if appropriate) dbus can be used 
without any daemon at all; i.e. you can use just the protocol. So e.g. 
say you want to talk to a child process, you can just socketpair() to 
get a pipe to the child, fork/exec, and then send dbus protocol over the 
pipe. Some of the dbus docs call this "peer to peer" (meaning there's no 
intermediate "hub" in the form of the bus daemon). I don't know that 
this is very relevant to the current conversation though.

Havoc




More information about the Upstart-devel mailing list