[Bug 1655447] Re: IEEE indexes in netaddr package may not match data in ieee-data package
Andres Rodriguez
andreserl at ubuntu-pe.org
Fri Mar 16 17:42:43 UTC 2018
** Changed in: maas
Importance: Critical => High
** Changed in: maas/2.3
Importance: Critical => High
--
You received this bug notification because you are a member of Ubuntu
OpenStack, which is subscribed to python-netaddr in Ubuntu.
https://bugs.launchpad.net/bugs/1655447
Title:
IEEE indexes in netaddr package may not match data in ieee-data
package
Status in MAAS:
Triaged
Status in MAAS 2.3 series:
Triaged
Status in python-netaddr package in Ubuntu:
Confirmed
Bug description:
Before reading further, note that this bug report is for the bug in
the Debian package for `netaddr`. Bug #1655452 is for the bug in
upstream `netaddr` code (related to cached index coherency).
---
The Debian package for `netaddr` ships with a pre-calculated index for
entries in the IEEE OUI and IAB files, which the `ieee-data` package
places here:
$ dpkg -L python-netaddr | grep idx$
/usr/lib/python2.7/dist-packages/netaddr/eui/oui.idx
/usr/lib/python2.7/dist-packages/netaddr/eui/iab.idx
The index files only work if they match the IEEE data at the time the
`netaddr` package was built. If anything changes in the IEEE data, the
seek locations in the index will be thrown off, causing undefined
behavior.
However, the way `netaddr` is packaged doesn't guarantee that the
index will be kept in sync with the data files in the `ieee-data`
pacakge. In the `netaddr` packages, symbolic links are created to the
data files in the `ieee-data` package as follows:
$ dpkg -L ieee-data | grep usr.share.*.txt
/usr/share/ieee-data/iab.txt
/usr/share/ieee-data/oui.txt
$ ls -la /usr/lib/python2.7/dist-packages/netaddr/eui/*.txt
lrwxrwxrwx 1 root root 38 Oct 23 2015 /usr/lib/python2.7/dist-packages/netaddr/eui/iab.txt -> ../../../../../share/ieee-data/iab.txt
lrwxrwxrwx 1 root root 38 Oct 23 2015 /usr/lib/python2.7/dist-packages/netaddr/eui/oui.txt -> ../../../../../share/ieee-data/oui.txt
Upstream, `netaddr` ships with its own copy of these files. During the
build process, `netaddr` generates an index file for fast lookups into
the OUI and IAB text files.
However, there is a problem with this arrangement that only occurs in
the Debian package: if the `ieee-data` on a given system is out-of-
sync with the index in the `python-netaddr` or `python3-netaddr`, the
undefined behavior begins.
In MAAS, we make heavy use of netaddr, and the symptoms of the index
file being out of date have ranged from an IndexError being raised to
UnicodeDecodeError, since `netaddr` assumes that the index will always
match the data file, and caches the index for the life of the
process.[1]
Symptoms
========
This bug can cause `netaddr` to raise tracebacks during operation,
such as `IndexError`, and possibly others, as a result of the
incorrect indexes. For examples, see also:
Bug #1655049
Bug #1628761
Suggested ways to fix
=====================
(1) The `netaddr` package MUST always be in a state where the index
file is consistent with the IEEE data.
(1a) The `netaddr` package COULD ship with a copy of the IEEE data
files as-designed, so that there is never a mismatch regarding the on-
disk data. (This is the simplest fix, but is likely a Debian policy
violation due to the duplication of data.)
(1b) The `netaddr` package COULD make a copy of the current state of
the OUI and IAB indexes in `ieee-data` when the package is installed
or updated. (Perhaps hard links would work, so that `netaddr` can
continue working with the old data until the indexes are regenerated.
But it would need to fall back to a data copy in case of cross-device
links.)
(1c) If the `ieee-data` package changes, and the `netaddr` is using
the data from it, the `netaddr` package MUST correspondingly update
its data files and index.
(2) The `netaddr` upstream code MUST detect if the index file changes
and reload the index (to be usable in a long-running process backed by
a Debian package that could be updated at any time).
Short term, the most important thing needed is a fix for (1), so that
will be the focus for this bug.
Workaround
==========
Regenerate the indexes (for python 2.x and 3.x) as root by running:
sudo python -m netaddr.eui.ieee
sudo python3 -m netaddr.eui.ieee
Either or both commands may be needed, depending on which `netaddr`
packages are installed.
Then, restart any long-running processes (such as MAAS) which may rely
on `netaddr` for OUI lookups.
Note that even if this bug is fixed, the "long-running process" issue
still exists. To fix that, (2) above needs to be resolved.
---
[1]: That means there is a related issue: long-running processes will
be exposed to the same symptoms of this bug, if the `netaddr` package
is upgraded while the long-running process is continues to run.
Arguably, this is a bug that upstream should address by recalculating
the index if the data file changes, and/or forcing an index
recalculation if an integrity check fails, such as by storing a size
and hash of the file. I assume it would be counter-productive to do
too many integrity checks, though, because by the time you get done
with them, you may as well have recalculated the entire index. (And on
a slow embedded system, this might be unacceptable.)
To manage notifications about this bug go to:
https://bugs.launchpad.net/maas/+bug/1655447/+subscriptions
More information about the Ubuntu-openstack-bugs
mailing list