<p dir="ltr"><br>
On May 20, 2015 9:48 AM, "Tom Gundersen" <<a href="mailto:teg@jklm.no">teg@jklm.no</a>> wrote:<br>
><br>
> On Tue, Apr 21, 2015 at 11:59 PM, Nick Owens <<a href="mailto:mischief@offblast.org">mischief@offblast.org</a>> wrote:<br>
> > hello tom,<br>
> ><br>
> > On Mon, Apr 20, 2015 at 2:32 PM, Tom Gundersen <<a href="mailto:teg@jklm.no">teg@jklm.no</a>> wrote:<br>
> >> On Fri, Apr 3, 2015 at 12:48 AM, Michael Marineau<br>
> >> <<a href="mailto:michael.marineau@coreos.com">michael.marineau@coreos.com</a>> wrote:<br>
> >>> On Thu, Apr 2, 2015 at 3:08 PM, Nick Owens <<a href="mailto:mischief@offblast.org">mischief@offblast.org</a>> wrote:<br>
> >>>> hi, sorry for the delay.<br>
> >>>><br>
> >>>> from <a href="http://www.freedesktop.org/software/systemd/man/systemd-networkd-wait-online.service.html">http://www.freedesktop.org/software/systemd/man/systemd-networkd-wait-online.service.html</a>:<br>
> >>>><br>
> >>>> "By default, it will wait for all links it is aware of and which are<br>
> >>>> managed by systemd-networkd.service(8) to be fully configured or<br>
> >>>> failed, *and for at least one link to gain a carrier.*".<br>
> >>>><br>
> >>>> the import part here is the end of the sentence. without this patch,<br>
> >>>> systemd-networkd-wait-online will block until all configured<br>
> >>>> interfaces have carrier.. you can reproduce this by running<br>
> >>>> systemd-networkd in qemu with two ethernet interfaces, and issue 'info<br>
> >>>> network' and then 'set_link <if> down' to simulate no carrier. then<br>
> >>>> you can run systemd-networkd-wait-online, and observe that it will<br>
> >>>> block until both interfaces are up, not just one.<br>
> >>>><br>
> >>>> nick<br>
> >>>><br>
> >>>> On Wed, Mar 25, 2015 at 10:53 PM, Andrei Borzenkov <<a href="mailto:arvidjaar@gmail.com">arvidjaar@gmail.com</a>> wrote:<br>
> >>>>> On Wed, Mar 25, 2015 at 11:49 PM,  <<a href="mailto:mischief@offblast.org">mischief@offblast.org</a>> wrote:<br>
> >>>>>> From: mischief <<a href="mailto:mischief@offblast.org">mischief@offblast.org</a>><br>
> >>>>>><br>
> >>>>>> when checking interface status, systemd-networkd-wait-online<br>
> >>>>>> will continue to wait if any interface is still configuring or<br>
> >>>>>> being processed by udev. this patch allows it to return if any<br>
> >>>>>> one interface is degraded/routable, as per the manual.<br>
> >>>>><br>
> >>>>> But current behavior is exactly what manual says: "By default, it will<br>
> >>>>> wait for all links it is aware of and which are managed by<br>
> >>>>> systemd-networkd.service(8) to be fully configured or failed". Or do I<br>
> >>>>> miss something?<br>
> >>><br>
> >>> It is worth noting that there may be some issues with tracking<br>
> >>> interface states in networkd, there appear to be ways to get an<br>
> >>> interface stuck in a 'configuring' state despite the fact that the<br>
> >>> interface has no network config and/or has no carrier.<br>
> >><br>
> >> Do you have any more info on this? Can you reproduce with current git?<br>
> >> There was a fix after the last release which should fix a problem with<br>
> >> enumerating devices.<br>
> ><br>
> > the original issue was discussed at<br>
> > <a href="https://github.com/coreos/bugs/issues/279">https://github.com/coreos/bugs/issues/279</a>. i just tested commit<br>
> > cffacc741cb79f63999720525ceaa65aae01a542.<br>
> ><br>
> > <a href="https://github.com/coreos/init/blob/master/systemd/network/zz-default.network">https://github.com/coreos/init/blob/master/systemd/network/zz-default.network</a><br>
> > is our default for networkd. it seems logical that given this config,<br>
> > systemd-networkd-wait-online would wait for all of the dhcp<br>
> > interfaces, no matter how many.<br>
> ><br>
> > however, i'm not sure what use case there is for this. it seems like<br>
> > there's no way to wait for any one nic to be routeable/configured<br>
> > without knowing its name ahead of time.<br>
><br>
> Correct. I mean, waiting for the system coming online like this is<br>
> mostly a legacy thing, so we support this in a relatively limited way.<br>
> Anything modern better explicitly listen for rtnl events and act<br>
> accordingly.<br>
><br>
> > another instance of this problem is having a bridge like<br>
> ><br>
> > [NetDev]<br>
> > Name=br0<br>
> > Kind=bridge<br>
> ><br>
> > and run 'systemctl restart systemd-networkd;<br>
> > /usr/bin/systemd-networkd-wait-online'. systemd-networkd-wait-online<br>
> > will not return. is this intended behavior?<br>
><br>
> Hm, I'm not able to reproduce this. Can you still reproduce with git<br>
> HEAD? If so what are the other config files that are applied, and what<br>
> is the output of networkctl whilst wait-online is hanging?</p>
<p dir="ltr">I haven't retested HEAD yet but up through 219 it would report 'no-carrier configuring' which seems bogus since it shouldn't be configuring an interface in such a state and there is no .network config to apply to the interface either. We have seen similar looking networkctl output for physical interfaces too but since several different states get squashed into 'configuring' I'm not sure if it is the same situation, it was just easier to demo with a .netdev and bridge. Interestingly no other mechanism for creating a bridge (ip or brctl) got it into the same state but I'm not sure why.<br>
</p>