mirror of
https://github.com/netbox-community/netbox.git
synced 2026-01-11 21:10:29 +01:00
Non-unique interface-connection IDs from API #1990
Closed
opened 2025-12-29 17:21:14 +01:00 by adam
·
13 comments
No Branch/Tag Specified
main
update-changelog-comments-docs
feature-removal-issue-type
20911-dropdown
20239-plugin-menu-classes-mutable-state
21097-graphql-id-lookups
feature
fix_module_substitution
20923-dcim-templates
20044-elevation-stuck-lightmode
feature-ip-prefix-link
v4.5-beta1-release
20068-import-moduletype-attrs
20766-fix-german-translation-code-literals
20378-del-script
7604-filter-modifiers-v3
circuit-swap
12318-case-insensitive-uniqueness
20637-improve-device-q-filter
20660-script-load
19724-graphql
20614-update-ruff
14884-script
02496-max-page
19720-macaddress-interface-generic-relation
19408-circuit-terminations-export-templates
20203-openapi-check
fix-19669-api-image-download
7604-filter-modifiers
19275-fixes-interface-bulk-edit
fix-17794-get_field_value_return_list
11507-show-aggregate-and-rir-on-api
9583-add_column_specific_search_field_to_tables
v4.5.0
v4.4.10
v4.4.9
v4.5.0-beta1
v4.4.8
v4.4.7
v4.4.6
v4.4.5
v4.4.4
v4.4.3
v4.4.2
v4.4.1
v4.4.0
v4.3.7
v4.4.0-beta1
v4.3.6
v4.3.5
v4.3.4
v4.3.3
v4.3.2
v4.3.1
v4.3.0
v4.2.9
v4.3.0-beta2
v4.2.8
v4.3.0-beta1
v4.2.7
v4.2.6
v4.2.5
v4.2.4
v4.2.3
v4.2.2
v4.2.1
v4.2.0
v4.1.11
v4.1.10
v4.1.9
v4.1.8
v4.2-beta1
v4.1.7
v4.1.6
v4.1.5
v4.1.4
v4.1.3
v4.1.2
v4.1.1
v4.1.0
v4.0.11
v4.0.10
v4.0.9
v4.1-beta1
v4.0.8
v4.0.7
v4.0.6
v4.0.5
v4.0.3
v4.0.2
v4.0.1
v4.0.0
v3.7.8
v3.7.7
v4.0-beta2
v3.7.6
v3.7.5
v4.0-beta1
v3.7.4
v3.7.3
v3.7.2
v3.7.1
v3.7.0
v3.6.9
v3.6.8
v3.6.7
v3.7-beta1
v3.6.6
v3.6.5
v3.6.4
v3.6.3
v3.6.2
v3.6.1
v3.6.0
v3.5.9
v3.6-beta2
v3.5.8
v3.6-beta1
v3.5.7
v3.5.6
v3.5.5
v3.5.4
v3.5.3
v3.5.2
v3.5.1
v3.5.0
v3.4.10
v3.4.9
v3.5-beta2
v3.4.8
v3.5-beta1
v3.4.7
v3.4.6
v3.4.5
v3.4.4
v3.4.3
v3.4.2
v3.4.1
v3.4.0
v3.3.10
v3.3.9
v3.4-beta1
v3.3.8
v3.3.7
v3.3.6
v3.3.5
v3.3.4
v3.3.3
v3.3.2
v3.3.1
v3.3.0
v3.2.9
v3.2.8
v3.3-beta2
v3.2.7
v3.3-beta1
v3.2.6
v3.2.5
v3.2.4
v3.2.3
v3.2.2
v3.2.1
v3.2.0
v3.1.11
v3.1.10
v3.2-beta2
v3.1.9
v3.2-beta1
v3.1.8
v3.1.7
v3.1.6
v3.1.5
v3.1.4
v3.1.3
v3.1.2
v3.1.1
v3.1.0
v3.0.12
v3.0.11
v3.0.10
v3.1-beta1
v3.0.9
v3.0.8
v3.0.7
v3.0.6
v3.0.5
v3.0.4
v3.0.3
v3.0.2
v3.0.1
v3.0.0
v2.11.12
v3.0-beta2
v2.11.11
v2.11.10
v3.0-beta1
v2.11.9
v2.11.8
v2.11.7
v2.11.6
v2.11.5
v2.11.4
v2.11.3
v2.11.2
v2.11.1
v2.11.0
v2.10.10
v2.10.9
v2.11-beta1
v2.10.8
v2.10.7
v2.10.6
v2.10.5
v2.10.4
v2.10.3
v2.10.2
v2.10.1
v2.10.0
v2.9.11
v2.10-beta2
v2.9.10
v2.10-beta1
v2.9.9
v2.9.8
v2.9.7
v2.9.6
v2.9.5
v2.9.4
v2.9.3
v2.9.2
v2.9.1
v2.9.0
v2.9-beta2
v2.8.9
v2.9-beta1
v2.8.8
v2.8.7
v2.8.6
v2.8.5
v2.8.4
v2.8.3
v2.8.2
v2.8.1
v2.8.0
v2.7.12
v2.7.11
v2.7.10
v2.7.9
v2.7.8
v2.7.7
v2.7.6
v2.7.5
v2.7.4
v2.7.3
v2.7.2
v2.7.1
v2.7.0
v2.6.12
v2.6.11
v2.6.10
v2.6.9
v2.7-beta1
Solcon-2020-01-06
v2.6.8
v2.6.7
v2.6.6
v2.6.5
v2.6.4
v2.6.3
v2.6.2
v2.6.1
v2.6.0
v2.5.13
v2.5.12
v2.6-beta1
v2.5.11
v2.5.10
v2.5.9
v2.5.8
v2.5.7
v2.5.6
v2.5.5
v2.5.4
v2.5.3
v2.5.2
v2.5.1
v2.5.0
v2.4.9
v2.5-beta2
v2.4.8
v2.5-beta1
v2.4.7
v2.4.6
v2.4.5
v2.4.4
v2.4.3
v2.4.2
v2.4.1
v2.4.0
v2.3.7
v2.4-beta1
v2.3.6
v2.3.5
v2.3.4
v2.3.3
v2.3.2
v2.3.1
v2.3.0
v2.2.10
v2.3-beta2
v2.2.9
v2.3-beta1
v2.2.8
v2.2.7
v2.2.6
v2.2.5
v2.2.4
v2.2.3
v2.2.2
v2.2.1
v2.2.0
v2.1.6
v2.2-beta2
v2.1.5
v2.2-beta1
v2.1.4
v2.1.3
v2.1.2
v2.1.1
v2.1.0
v2.0.10
v2.1-beta1
v2.0.9
v2.0.8
v2.0.7
v2.0.6
v2.0.5
v2.0.4
v2.0.3
v2.0.2
v2.0.1
v2.0.0
v2.0-beta3
v1.9.6
v1.9.5
v2.0-beta2
v1.9.4-r1
v1.9.3
v2.0-beta1
v1.9.2
v1.9.1
v1.9.0-r1
v1.8.4
v1.8.3
v1.8.2
v1.8.1
v1.8.0
v1.7.3
v1.7.2-r1
v1.7.1
v1.7.0
v1.6.3
v1.6.2-r1
v1.6.1-r1
1.6.1
v1.6.0
v1.5.2
v1.5.1
v1.5.0
v1.4.2
v1.4.1
v1.4.0
v1.3.2
v1.3.1
v1.3.0
v1.2.2
v1.2.1
v1.2.0
v1.1.0
v1.0.7-r1
v1.0.7
v1.0.6
v1.0.5
v1.0.4
v1.0.3-r1
v1.0.3
1.0.0
Labels
Clear labels
beta
breaking change
complexity: high
complexity: low
complexity: medium
needs milestone
netbox
pending closure
plugin candidate
pull-request
severity: high
severity: low
severity: medium
status: accepted
status: backlog
status: blocked
status: duplicate
status: needs owner
status: needs triage
status: revisions needed
status: under review
topic: GraphQL
topic: Internationalization
topic: OpenAPI
topic: UI/UX
topic: cabling
topic: event rules
topic: htmx navigation
topic: industrialization
topic: migrations
topic: plugins
topic: scripts
topic: templating
topic: testing
type: bug
type: deprecation
type: documentation
type: feature
type: housekeeping
type: translation
Mirrored from GitHub Pull Request
No Label
Milestone
No items
No Milestone
Projects
Clear projects
No project
Notifications
Due Date
No due date set.
Dependencies
No dependencies set.
Reference: starred/netbox#1990
Reference in New Issue
Block a user
Blocking a user prevents them from interacting with repositories, such as opening or commenting on pull requests or issues. Learn more about blocking a user.
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
Originally created by @pm17788 on GitHub (Sep 7, 2018).
Environment
Steps to Reproduce
Gather all the interface connections into a set of files:
Iterate through the JSON outputs from above, and isolate just the
idfield from within each of theinterface-connectionarray member within theresultsarray:Expected Behavior
Expected that the raw gathered count and the
sort -uoutput be the same.Observed Behavior
Apparently duplicated interface IDs? Not quite sure.
Duplicated IDs aren't the only thing which seems odd. If we trust that 9827 is the accurate count of overall interface connections in my instance, the bulk API-based get seems to be missing data for ~1500 interface connections.
(Edit): Formatting, clarity
@pm17788 commented on GitHub (Sep 7, 2018):
This a re-work of #2391 using just the API and
jq/sortrather than a custom script. As @jeremystretch pointed out, there was a decent possibility I cocked something up in my script. I really hoped (still am) that this is some sort of a brain-fart on my side.@pm17788 commented on GitHub (Sep 7, 2018):
Vexingly, I am unable to replicate this behaviour using
nbshell:@pm17788 commented on GitHub (Sep 10, 2018):
D'Oh. Wrong button. Sorry about that.
@jeremystretch commented on GitHub (Sep 13, 2018):
I'm not able to replicate this behavior. Note that InterfaceConnection IDs are enforced as primary keys at the database level, so it should not be possible to have duplicates.
What does the API return for the total object
countat the/api/dcim/interface-connections/endpoint? And what doesInterfaceConnection.objects.count()return innbshell?@pm17788 commented on GitHub (Sep 13, 2018):
Both
nbshelland the API'scountvariable return, right now, "9863"I, too, am confused by the fact that my API calls seem to return duplicates, since, as you point out, the InterfaceConnection ID is a PK.
If it wasn't for Occam's razor looking menacingly at me from a corner of my desk, I'd start to suspect DB corruption.
I even wrote a quick thing in nbshell which wrote out each connection's
.idand.to_csv()to a file, and looked at what was showing up as "duplicate" to see if there was, perhaps, a pattern to what is shown as "dupes". Nope. All sorts of things seem to be mix-n-matched - things like my Core <=> AggSwitch connections or TOR <=> ServerNIC connections. Nothing jumped out, sadly.I've just re-ran the test on my test instance which is based on a
pg_dump-based restore, and I am able to replicate the disparity, which means I have an instance where I can turn the debugging to 11 or thereabout to see what's going on. Which knobs can I tweak to make it tell us useful things?@pm17788 commented on GitHub (Oct 1, 2018):
@jeremystretch: Is there anything else I can do to help with this?
@LBegnaud commented on GitHub (Oct 1, 2018):
should be relatively easy to find the actual dupes, no? Admittedly i haven't spent too much time thinking about it, but wouldn't you be duplicating things by your collection of items? getting the first thousand items, then doing an offset of a thousand?
@DanSheps commented on GitHub (Oct 2, 2018):
This is a bit hacky, but have you thought of dumping all rows to a CSV (maintaining all data) then looking at the rows and highlighting duplicates to see if you actually have duplicates?
@pm17788 commented on GitHub (Oct 2, 2018):
@DanSheps: Sorry, not sure I fully understand what you're suggesting. Using
nbshellto make queries, there were no duplicates at all. The duplicates only showed up using the API to enumerate all connections.@LBegnaud: You have a good point, and if I had 10 dupes, it'd make sense (because in my example, I made 10 "paged" calls). But since I saw ~1500 duplicates, I do not believe that the offset/pagination overlap account for the dupes.
@DanSheps commented on GitHub (Oct 2, 2018):
What about doing what I suggested with the API then?
@pm17788 commented on GitHub (Oct 3, 2018):
@DanSheps: Something roughly like this:
nbshellUsing
nbshell-generated "master" to cross-check what I got out of the API:Sample output:
@pm17788 commented on GitHub (Oct 3, 2018):
@DanSheps: Re-read your question with more attention (am on-call this week, so a bit hectic). I misread it initially. The dupes from the API side of things are not just in connection IDs, but in the actual data, too.
@jeremystretch commented on GitHub (Nov 6, 2018):
Not sure what else there is we can do with this. No one else has been able to replicate the reported issue. I'm going to close this out, but please feel free to continue the discussion on the mailing list if you're still trying to track this down. If we can achieve reproduction I'm happy to re-open this as a bug.