-
Notifications
You must be signed in to change notification settings - Fork 24
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
Refactor network interfaces and protocols inventory tables #284
Labels
level/subtask
Subtask issue
module/inventory
Inventory module
mvp
Minimum Viable Product refinement
type/enhancement
Enhancement issue
Comments
vikman90
added
level/task
Task issue
module/inventory
Inventory module
mvp
Minimum Viable Product refinement
type/enhancement
Enhancement issue
labels
Nov 8, 2024
Unification proposal:From the three different tables the idea is to merge them into a single one using the iface name as the join column:
Details
e.g:
Details
e.g:
Details
e.g:
Result of unifying the 3 cases
Details
e.g:
|
Update 22/11
From this case: {
"iface": [
{
"IPv4": [
{
"address": "172.17.0.1",
"broadcast": "172.17.255.255",
"dhcp": "unknown",
"metric": "0",
"netmask": "255.255.0.0"
}
],
"adapter": "",
"gateway": " ",
"mac": "02:42:1c:26:13:65",
"mtu": 1500,
"name": "docker0",
"rx_bytes": 0,
"rx_dropped": 0,
"rx_errors": 0,
"rx_packets": 0,
"state": "down",
"tx_bytes": 0,
"tx_dropped": 0,
"tx_errors": 0,
"tx_packets": 0,
"type": "ethernet"
},
{
"IPv4": [
{
"address": "192.168.0.141",
"broadcast": "192.168.0.255",
"dhcp": "unknown",
"metric": "0",
"netmask": "255.255.255.0"
}
],
"IPv6": [
{
"address": "fe80::be24:11ff:fe54:83fb",
"broadcast": "",
"dhcp": "unknown",
"metric": "",
"netmask": "ffff:ffff:ffff:ffff::"
}
],
"adapter": "",
"gateway": "192.168.0.1",
"mac": "bc:24:11:54:83:fb",
"mtu": 1500,
"name": "ens18",
"rx_bytes": 653336088,
"rx_dropped": 154,
"rx_errors": 0,
"rx_packets": 731620,
"state": "up",
"tx_bytes": 303676094,
"tx_dropped": 0,
"tx_errors": 0,
"tx_packets": 638612,
"type": "ethernet"
}
]
}
We get this json: {
"networks": [
{
"adapter": "",
"address": "172.17.0.1",
"broadcast": "172.17.255.255",
"dhcp": "unknown",
"gateway": " ",
"iface": "docker0",
"iface_type": "ethernet",
"mac": "02:42:1c:26:13:65",
"metric": "0",
"mtu": 1500,
"netmask": "255.255.0.0",
"network_checksum": "cc10013383f0c7e9dbe8adc809edd8562854ca76",
"network_item_id": "fae3b9f3354ce8946db29fbf6c1811172ec77ea9",
"proto_type": "ipv4",
"rx_bytes": 0,
"rx_dropped": 0,
"rx_errors": 0,
"rx_packets": 0,
"state": "down",
"tx_bytes": 0,
"tx_dropped": 0,
"tx_errors": 0,
"tx_packets": 0
},
{
"adapter": "",
"address": "192.168.0.141",
"broadcast": "192.168.0.255",
"dhcp": "unknown",
"gateway": "192.168.0.1",
"iface": "ens18",
"iface_type": "ethernet",
"mac": "bc:24:11:54:83:fb",
"metric": "0",
"mtu": 1500,
"netmask": "255.255.255.0",
"network_checksum": "42953299ec1227367718861a7fe65d4a750c1a32",
"network_item_id": "4a99254163997c30e63092675ee715c332a58b7e",
"proto_type": "ipv4",
"rx_bytes": 664044729,
"rx_dropped": 154,
"rx_errors": 0,
"rx_packets": 785555,
"state": "up",
"tx_bytes": 321044806,
"tx_dropped": 0,
"tx_errors": 0,
"tx_packets": 689763
},
{
"adapter": "",
"address": "fe80::be24:11ff:fe54:83fb",
"broadcast": "",
"dhcp": "unknown",
"gateway": "192.168.0.1",
"iface": "ens18",
"iface_type": "ethernet",
"mac": "bc:24:11:54:83:fb",
"metric": "",
"mtu": 1500,
"netmask": "ffff:ffff:ffff:ffff::",
"network_checksum": "872208a226d963159fe2b312f49b54683552c5b0",
"network_item_id": "e86c97ff99df2ceb70f6cff90668a6552d2eb8f7",
"proto_type": "ipv6",
"rx_bytes": 664044729,
"rx_dropped": 154,
"rx_errors": 0,
"rx_packets": 785555,
"state": "up",
"tx_bytes": 321044806,
"tx_dropped": 0,
"tx_errors": 0,
"tx_packets": 689763
}
]
}
|
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Labels
level/subtask
Subtask issue
module/inventory
Inventory module
mvp
Minimum Viable Product refinement
type/enhancement
Enhancement issue
Parent Issue: #292
The current network inventory separates interfaces and protocols, since each network interface may have zero or many IP addresses.
Now, since we're synchronizing this data with Indexer (which is not an SQL database), we need to merge both tables into one, repeating the data originally stored in the interfaces table.
Take into account that, since the relationship is zero-or-many to one, we must ensure that there is at less one entry for each network interface, even if it has no IP addresses.
Depends on
The text was updated successfully, but these errors were encountered: