Bug #30694
closedRedhat repos are no longer listed completely
Description
On foreman 1.24.3 it works as usual.
But if I load the same manifest on a foreman 2.1 I only get to see a few versions of repos, sometimes only some versions are missing, sometimes every version.
I also noticed that the time until the results appear is much longer. Before it was 5 seconds now it is 60 seconds until the contents are displayed.
No log information found.
One Pic is from Foreman 1.24 the other with less versions is from Foreman 2.1
Files
Updated by Tomer Brisker over 4 years ago
- Project changed from Foreman to Katello
Updated by Bernhard Suttner over 4 years ago
- Found in Releases Katello 3.16.0 added
- Found in Releases deleted (
2.1.1)
Updated by Bernhard Suttner over 4 years ago
- Priority changed from Normal to High
Updated by Jonathon Turel over 4 years ago
Can you try refreshing your subscription manifest and see if that has any effect on the results in the list? Thanks for the report!
Updated by Jonathon Turel over 4 years ago
- Status changed from New to Need more information
Updated by Brad Glascock over 4 years ago
I have the same issue and have refreshed the manifest a couple times. Tried both with simple content access enabled and without.
Updated by Richard Stempfl over 4 years ago
refresh of the manifest unfortunately brings no improvement. From time to time other release versions are shown but never completely
Updated by Chris Roberts over 4 years ago
- Category set to Repositories
- Status changed from Need more information to New
- Target version set to Katello 3.17.0
- Triaged changed from No to Yes
Updated by Bernhard Suttner over 4 years ago
This is broken for the Katello 3.16.0. I think it should be at least cherry-picked back to 3.16 as its a very important issue.
Updated by Richard Stempfl over 4 years ago
In the meantime I have noticed that only redhat7 repositories are affected. redhat8 works.
Updated by Justin Sherrill over 4 years ago
- Status changed from New to Rejected
- Target version changed from Katello 3.17.0 to Katello Recycle Bin
This is caused by an issue in dynflow, and fixed here: https://github.com/Dynflow/dynflow/pull/362
the fix isn't released yet though. You can try to apply the patch locally and restart all services, or enable the repo using hammer cli.
Updated by Marcel Kühlhorn over 4 years ago
Justin Sherrill wrote:
This is caused by an issue in dynflow, and fixed here: https://github.com/Dynflow/dynflow/pull/362
the fix isn't released yet though. You can try to apply the patch locally and restart all services, or enable the repo using hammer cli.
Applying the patch slightly improved things:
Now, on a foreman server that accesses the Internet through an HTTP proxy, for the first product selected all versions are shown, but trying to list versions for another product after enabling one of them leads to "No repositories available"
After reloading the page the versions for that product can be listed completely, so you now have to reload the page every time you extended a products version list and want to list another
Updated by Tomer Brisker over 4 years ago
- Status changed from Rejected to New
- Target version deleted (
Katello Recycle Bin) - Triaged changed from Yes to No
reopening per comment #12
Updated by Justin Sherrill over 4 years ago
- Status changed from New to Need more information
I've never seen this new behavior you describe. A few questions:
1) do you have to 'enable' a repo and then expand a new repo set to see it come up empty? or does just expanding two repos sets in a row also reproduce the behavior?
2) does it happen every time?
3) is it possible to try without an http proxy? (not that i know why that make any difference assuming there is not any sort of connection limit)
Updated by Justin Sherrill over 4 years ago
Also, after reproducing the issue, can you go to Monitor > tasks and look for the most recent 'scan CDN' task. Are there any errors in it?
Updated by Marcel Kühlhorn over 4 years ago
1) Enabling a repository seems to increase the frequency at which it happens, but after expanding multiple repos it eventually happens without too
2) When I wrote the first comment it happened every time, now its more sporadic
3) I'll have to try that still
4) the scan CDN tasks do not show any error
As Richard noted further up, this seems to only affect RHEL 7 repositories
Updated by Marcel Kühlhorn over 4 years ago
I can now say it only happens with HTTP Proxy.
For completeness sake I also tried disabling Auth in squid, with the same result:
after a random number of expanded repos I get No repositories available.
The squid access log shows no connection errors either.
My reproducer is simply putting "rhel-7" in the search box and then expand a number of repos until the failure to load more occurs
Updated by Justin Sherrill over 4 years ago
- Category deleted (
Repositories)
Thanks Marcel!!!
Does the version you are using have this change: https://github.com/Katello/katello/pull/8728/files
(I don't think it does, as that issue is marked for katello 3.17). Would you be able to apply that patch, restart services (including dynflow*) and re-test. Then look in the logs for 'Failed at scanning for repository'
Updated by Justin Sherrill over 4 years ago
Specifically /var/log/foreman/production.log
Updated by Marcel Kühlhorn over 4 years ago
With the patch I get this in production.log:
2020-09-17T15:48:49 [I|app|] Completed 500 Internal Server Error in 7526ms (Views: 0.6ms | ActiveRecord: 15.5ms | Allocations: 41764) 2020-09-17T15:48:49 [E|app|] Failed at scanning for repository: could not obtain a connection from the pool within 5.000 seconds (waited 5.000 seconds); all pooled connections were in use
I also now see the scan CDN tasks ending up in warning state with
Exception: ActiveRecord::ConnectionTimeoutError: could not obtain a connection from the pool within 5.000 seconds (waited 5.000 seconds); all pooled connections were in use
Updated by The Foreman Bot over 4 years ago
- Status changed from Need more information to Ready For Testing
- Assignee set to Justin Sherrill
- Pull request https://github.com/Katello/katello/pull/8963 added
Updated by Justin Sherrill over 4 years ago
Would you be able to try this patch? https://github.com/Katello/katello/pull/8963
this limits the number of concurrent fetches to 5. If you still hit the issue, you may want to try lowering it. Putting it at 1 would basically make it sequential.
You'll need to restart the dynflow workers between each try.
Updated by Marcel Kühlhorn over 4 years ago
After some testing I found that to reliably not run into the error even when extending multiple repos at the same time I had to decrease the group size down to 2.
Updated by Ian Ballou over 4 years ago
- Category set to Repositories
- Target version set to Katello 3.17.0
- Triaged changed from No to Yes
Updated by Justin Sherrill over 4 years ago
Hello!, I updated the pr with another change. This change should cause the http proxy information being loaded prior to spawning threads. This should reduce the amount of db access that is needed within the threads. I also bumped up the thread count to 8 by default, but i'm curious again with this change what seems to work for you.
Updated by Marcel Kühlhorn over 4 years ago
Thank you Justin, with the latest version of the patch it works reliable with your set group size
Updated by Justin Sherrill over 4 years ago
Awesome to hear! Thank you for the testing!
Updated by Justin Sherrill over 4 years ago
- Target version changed from Katello 3.17.0 to Katello 3.16.1
Updated by The Foreman Bot over 4 years ago
- Fixed in Releases Katello 4.0.0 added
Updated by Justin Sherrill over 4 years ago
- Status changed from Ready For Testing to Closed
Applied in changeset katello|e433f4a4dca2ee7168002d7e76cbc10a0b0054b5.
Updated by Marcel Kühlhorn over 4 years ago
- Found in Releases Katello 3.16.1.2 added
Updated by Marcel Kühlhorn about 4 years ago
- Found in Releases deleted (
Katello 3.16.1.2)