Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

cli: drop python-netifaces (LP: #2065870, LP: #2017585) #503

Merged
merged 3 commits into from
Aug 28, 2024

Conversation

daniloegea
Copy link
Contributor

@daniloegea daniloegea commented Aug 13, 2024

netifaces doesn't return the permanent MAC address of physical interfaces.

This causes a problem with bonds for example where all the interfaces in the bond will share the same MAC address. When netplan apply tries to find a unique matching based on the MAC returned by netifaces and the MAC set in the YAML, it will not be found.

# netplan apply
[]
Cannot find unique matching interface for nic0

The is_composite_member() method wasn't working properly as well. It was always returning False. In the end I stopped using it.

Regarding skipping bond/bridge members during renames, that seems to be put in place as a workaround for LP: #1802322. The problem it fixed was happening because the code was matching interfaces by their non-permanent MAC address. When they are added to a bond, they will share the same MAC. The code was confusing one interface with another and trying to rename them.

By not renaming them the backend will "forget" about the interface. We will emit the new name to the backend config files but keep the interface with the old name in the system so it will not be found anymore. This is worse than causing a quick disconnection during the rename process as further changes to the interface will not be applied. The user would need to either rename it manually (which will cause a disconnection anyway) or reboot. I also found that networkd <= 255 was triggering a rename anyway when we called udevadm test from netplan apply so we've been unintentionally allowing renames anyway...

Fixes: LP#2065870

Description

Checklist

  • Runs make check successfully.
  • Retains 100% code coverage (make check-coverage).
  • New/changed keys in YAML format are documented.
  • (Optional) Adds example YAML for new feature.
  • (Optional) Closes an open bug in Launchpad. LP#2065870, LP#2017585

@daniloegea daniloegea changed the title [WIP] cli: drop python-netifaces [WIP] cli: drop python-netifaces (LP#2065870) Aug 13, 2024
@daniloegea daniloegea force-pushed the get_rid_of_netifaces branch 2 times, most recently from 31ec163 to 79d1b6a Compare August 14, 2024 09:34
@daniloegea daniloegea changed the title [WIP] cli: drop python-netifaces (LP#2065870) cli: drop python-netifaces (LP#2065870) Aug 15, 2024
@daniloegea daniloegea force-pushed the get_rid_of_netifaces branch 2 times, most recently from 4e39aee to 6a93964 Compare August 15, 2024 11:01
@daniloegea daniloegea marked this pull request as ready for review August 15, 2024 12:22
@daniloegea daniloegea requested a review from slyon August 15, 2024 12:22
@slyon
Copy link
Collaborator

slyon commented Aug 21, 2024

@slyon slyon changed the title cli: drop python-netifaces (LP#2065870) cli: drop python-netifaces (LP: #2065870, LP: #2017585) Aug 21, 2024
Copy link
Collaborator

@slyon slyon left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you very much. I generally like those changes, especially as netifaces is not maintained upstream anymore: al45tair/netifaces#78

I left a bunch of inline comments, some asking for some additional work (nothing big).

Also note, that after this change Netplan grows a new runtime dependency on ethtool.

netplan_cli/cli/commands/apply.py Outdated Show resolved Hide resolved
netplan_cli/cli/commands/apply.py Outdated Show resolved Hide resolved
netplan_cli/cli/utils.py Show resolved Hide resolved
netplan_cli/cli/utils.py Outdated Show resolved Hide resolved
netplan_cli/cli/utils.py Outdated Show resolved Hide resolved
tests/cli/test_units.py Outdated Show resolved Hide resolved
@daniloegea daniloegea force-pushed the get_rid_of_netifaces branch 4 times, most recently from 734b363 to 8f6d9a8 Compare August 23, 2024 09:29
netifaces doesn't return the permanent MAC address of physical
interfaces. This is causing issues when we try to find interfaces that
are matched by MAC address but their MACs changed (because they were
added to a bond for example).

We only use it to retrieve the list of interfaces and their MACs so
let's drop it and implement this functionalities in the CLI.

get_interfaces() will simply call "ip link" and return a list with the
interface names.

get_interface_macaddress() will try to get the permanent MAC address and
fallback to the transient address if it can't be found.
Skipping members of bonds when searching for interfaces that need to
be renamed was done as a workaround for LP: #1802322.

The actual problem was that members of bonds will have their MAC
addresses changed to a common address when they are added as members.
The renaming process looked for interfaces based on their transient MAC
addresses not the permanent one. Because of that, it would confuse one
interface by another and try to rename it.

The process was changed to look for the permanent MAC address so this
problem shouldn't happen. It also searches only for physical interfaces,
which should have a permanent MAC address.

Skipping the renaming of members of bonds will cause the backend to
"forget" about it. Once the configuration is generated with a different
name, the backend will look for the new name. As the interface will
continue to have the previous name, it will not be managed anymore.

Lets fix this by allowing the renaming these interfaces. If the system
administrator changed the "set-name" setting, they probably want to get
the interface renamed. This might cause a quick loss of connectivity on
the interface being renamed.

Drop is_composite_member(). This method is not needed anymore.
@daniloegea daniloegea force-pushed the get_rid_of_netifaces branch from 8f6d9a8 to 6bcae2f Compare August 23, 2024 09:48
@daniloegea
Copy link
Contributor Author

Thanks, Lukas. I addressed your comments and added some extra unit tests.

@daniloegea daniloegea requested a review from slyon August 23, 2024 12:42
Copy link
Collaborator

@slyon slyon left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Kudos! LGTM. Let's get it merged.

I prepared the new ethtool dependency in the Debian packaging, so we won't forget about it: https://salsa.debian.org/debian/netplan.io/-/commit/d6405858d585b833eb5d1c58cf43eff8568a16ed

(We still need to remember python-netifaces, though.)

@slyon slyon merged commit 150090a into canonical:main Aug 28, 2024
16 checks passed
@slyon slyon mentioned this pull request Sep 4, 2024
5 tasks
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants