Jump to content
funtoo forums


  • Content count

  • Joined

  • Last visited

  1. Also, simply putting the symlink from /etc/init.d/unbound to openrc/started/unbound got the service to be able to be restarted again. The openrc/daemons/unbound/001 was not required.
  2. I am still debugging this. So, I went through my logs and found I have this issue for both init scripts that I wrote and that were prepackaged with Gentoo/Funtoo. That said, I am investigating one that I wrote for argus. One issue is that the pidfile was not created; however, I even manually created it and the start-stop-daemon doesn't seem to be recognizing that it is started. I'm going through the source for openrc to try to piece together what's going on: https://github.com/OpenRC/openrc/blob/90d9ea656ff7c6b5d618df4e4261ebfa4033f1a8/src/rc/start-stop-daemon.c Line 690 appears to be where it is finding that an existing PID exists. Lastly, I did something more interesting. Unbound was running and I could restart it with no issues. I did the following: 1. rename the pid file from /run/unbound.pid to /run/unbound.pid.bak 2. issued service unbound restart 3. got what I expected, socket already in use, failed to start unbound 3. rename the pid file from /run/unbound.pid.bak to /run/unbound.pid 4. issue service unbound restart 5. got what I did NOT expect, same issue I have above. When I purposely screw up the state of the the daemon, the files under /run/openrc/daemons disappear. These files appear to be critical in determining the state of the daemon EVEN IF I PUT THE PIDFILE BACK. So, I started unbound and got it running, then backed up those files under openrc: openrc/daemons/unbound openrc/daemons/unbound/001 openrc/started/unbound I then screwed up the state of it by moving the pidfile. At this point, I could not restart unbound as predicted. So, I restored the state files under /run/openrc and voila, I was able to start/stop unbound again. Hmm, so with all of that, it seems that if the pidfile fails to be created for whatever reason, openrc is unable to correctly determine the state of the daemon. So, why is the pidfile failing to be created if I get a successful status when this stuff starts up? Lastly, if it fails to be created, I need to check, but openrc should return an error if it isn't already doing so.
  3. Thanks - I'm still thinking on how exactly I could debug this. I think it is one of 2 things, a configuration I'm doing or something with OpenRC. Since many people use OpenRC and haven't reported this such issue, I suspect it is more of a configuration I'm doing.
  4. Thanks for the reply - NetworkManager is merely acting as a catalyst to tell OpenRC to start the service. The process is like this: 1. NetworkManager starts (part of the default runlevel) 2. NetworkManager joins a specific network and fires an event, invokes dispatcher script 3. The NetworkManager dispatcher script calls a bunch of stuff which ends up calling service <service name> restart. I call restart because the service may already be running and was just reconfigured for a given network. These services are not part of the default or boot runlevels. OpenRC is still starting/stopping the services. They're just invoked via NetworkManager.
  5. Thanks - I am still debugging and am guessing I need to dig into /sbin/openrc-run. /var/log/messages capture the output from running service <service name> start and shows the service started The pidfile for that service exists (and has the correct PID for that service) The output of ps aux --forest | grep <service name> shows that PID and the same cmdline that the init script has I am starting these services through a NetworkManager dispatcher script that executes through the at daemon (since it takes some time to complete). No, zapping does not work because the process is still running. When issuing a restart, I get the same problem. I must kill that PID and then restart the service. At that point, rc-status and service <service name> work fine. I tested this for privoxy, but was previously also having the same problem for sshd, shorewall, and unbound.
  6. I updated my systems and my recent builds are having this issue both on desktops and servers. When running rc-status, some services are reported as stopped even though they are running and when I try to either do a service <service name> start or service <service name> restart, it reports that the service is already running. I am only starting my services through the /usr/sbin/service command. The only thing I can think of is checking the permissions at /run, and that seems fine. What else / where else should I look to sort this out? Thanks in advance, Walter
  7. My openresolvconf configuration was invalid: # Use the local name server name_servers= # added for dnscrypt + dnssec #options edns0 The last line had the bug in it and that caused openresolvconf to crash. Walter
  8. Hi all, This one has been bugging me for a while. At first, I thought it might be related to running a hardened system, so I decided to migrate to a more vanilla install, but I get the same thing repeatably. I' running gentoo sources 4.13.9 and NetworkManager 1.4.4-r1. I can reproduce this problem on any of my machines as long as I restart NetworkManager when an interface is up. The workaround for me is to bring down the interface (ifconfig eth0 down) before restarting NetworkManager. Short of running strace, what else can I do to sort this out? Walter