-
Notifications
You must be signed in to change notification settings - Fork 52
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
Graceful continuation on NOT_FOUND #170
Comments
@jimconner normally the as object as deserialized and then returned using the However, I think that you may optimise your call as
Did you try the following approach for org in cfClient.v3.organizations:
org_name = org['name']
try:
for space in cfClient.spaces.list(organization_guids=org['guid']):
space_name=space['name']
try:
for app in cfClient.v3.apps.list(space_guids=space['guid']):
app_name=app['name']
except InvalidStatusCode:
pass
except InvalidStatusCode:
pass |
Thanks for replying @antechrestos - I've been through a few different approaches for this so far. I started out by fetching all apps, spaces and orgs and used list comprehension to convert into in-memory objects, which was nice and fast, but gave me NOT_FOUND issues. I changed to the current app.space().organization() in an attempt to fetch things more dynamically (which mostly worked out OK). I'll try your suggested approach sometime soon, but I suspect the same issue will persist. We have some short-lived orgs/spaces/apps that are created and destroyed by pipelines. Looping through v3.organizations will likely give us the same result. We're hosting >5K apps on this particular CF foundation and there may be a few hundred apps within any given org. The script in question here is fetching the current droplet for each of the apps so that we can create SBOMs and run scanning tools across them. This is always going to be a slow process due to the size and number of blobs involved. The other place I need to work out some kind of graceful continuation is for when there are gitches on the network (or in one of the three different types of load balancer that sit in front of our estate) that cause a packet or two to vanish unexpectedly.
If you've got any ideas for how to make the client reconnect automatically then I'm all ears :-) Thanks again for replying @antechrestos - Please don't feel under any pressure. This is quite a low-priority problem for me. |
Hi - We are using cf-python-client as part of a task which downloads each app-blob in turn. As we have tens of thousands of containers, this job takes 8-10 hours to complete.
The job is theoretically quite straightforward...
More often than not, during the running of this task, we'll encounter an error along the lines of...
or
Given the number of orgs/spaces/apps we have in service, it is not too surprising that an app or space which was present at the start of the task is no longer around 6-8 hours later.
When we encounter an error like this we have no options but to restart the 8-10 hour task from the beginning again and hope that it manages to make it through without an error.
I was just wondering if there are any options to allow for more graceful continuation when objects are no longer found? This doesn't seem to be something that I can handle with a
try: except:
- Are there any options to make errors like this non-fatal?Cheers!!
The text was updated successfully, but these errors were encountered: