damccorm opened a new issue, #19751:
URL: https://github.com/apache/beam/issues/19751

   It seems that Apache Beam's Pipeline instances are not garbage collected, 
even if the pipelines are finished or cancelled and there are no references to 
those pipelines in the Python interpreter.
   
   For pipelines executed in a script, this is not a problem. However, for 
interactive pipelines executed inside a Jupyter notebook, this limits how well 
we can track and remove the dependencies of those pipelines. For example, if a 
pipeline reads from some cache, it would be nice to be able to delete that 
cache once there are no references to it from pipelines or the global namespace.
   
   The issue can be reproduced using the following script: 
[https://gist.github.com/ostrokach/a16556dc77c96b87fe23c2fbd8fb6346](https://gist.github.com/ostrokach/a16556dc77c96b87fe23c2fbd8fb6346).
   
   \--\---
   
   On further examination, turns out that this is due to the 
[`_PubSubReadEvaluator._subscription_cache`|https://github.com/apache/beam/blob/27bb5bc7b244809e7f6022adb2730d10204ce4d3/sdks/python/apache_beam/runners/direct/transform_evaluator.py#L418]
 class attribute keeping references to all `ReadFromPubSub` transforms.
   
   Imported from Jira 
[BEAM-7750](https://issues.apache.org/jira/browse/BEAM-7750). Original Jira may 
contain additional context.
   Reported by: ostrokach.


-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: [email protected]

For queries about this service, please contact Infrastructure at:
[email protected]

Reply via email to