Commit 884d60d
committed
Fix potential goroutine leak.
Race conditions in cleanup goroutines could cause them to fail. As they
are created every time a queue becomes non-empty, a single queue being
worked can cause multiple goroutines to spawn for cleanup, and they
could all get quite unlucky and never be able to perform their cleanup
(particularly if a task gets left in that queue for a while after
triggering multiple cleanup routines).
Taken across a large number of queues, this can be an issue and leak
memory unnecessarily. The implementation now recognizes that the
presence of the "dependents" semaphore makes synchronous cleanup a safe
procedure, simplifying logic and interactions between goroutines.1 parent 0f27f5b commit 884d60d
3 files changed
Lines changed: 47 additions & 47 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
830 | 830 | | |
831 | 831 | | |
832 | 832 | | |
833 | | - | |
834 | | - | |
835 | | - | |
836 | | - | |
837 | | - | |
838 | | - | |
839 | | - | |
840 | | - | |
| 833 | + | |
| 834 | + | |
| 835 | + | |
| 836 | + | |
| 837 | + | |
| 838 | + | |
| 839 | + | |
| 840 | + | |
| 841 | + | |
| 842 | + | |
| 843 | + | |
| 844 | + | |
841 | 845 | | |
842 | 846 | | |
843 | 847 | | |
844 | 848 | | |
845 | | - | |
846 | 849 | | |
847 | 850 | | |
848 | 851 | | |
849 | | - | |
850 | | - | |
851 | | - | |
852 | | - | |
853 | | - | |
854 | | - | |
855 | | - | |
856 | | - | |
857 | | - | |
858 | | - | |
859 | | - | |
860 | | - | |
861 | | - | |
862 | | - | |
863 | | - | |
864 | | - | |
865 | | - | |
866 | | - | |
867 | | - | |
868 | | - | |
869 | | - | |
870 | | - | |
871 | | - | |
872 | | - | |
873 | | - | |
874 | | - | |
875 | | - | |
876 | | - | |
877 | | - | |
878 | | - | |
879 | | - | |
880 | | - | |
881 | | - | |
882 | | - | |
883 | | - | |
884 | | - | |
| 852 | + | |
| 853 | + | |
| 854 | + | |
| 855 | + | |
| 856 | + | |
| 857 | + | |
| 858 | + | |
885 | 859 | | |
| 860 | + | |
886 | 861 | | |
887 | 862 | | |
888 | 863 | | |
| |||
908 | 883 | | |
909 | 884 | | |
910 | 885 | | |
911 | | - | |
| 886 | + | |
| 887 | + | |
| 888 | + | |
| 889 | + | |
912 | 890 | | |
913 | 891 | | |
914 | | - | |
| 892 | + | |
| 893 | + | |
| 894 | + | |
| 895 | + | |
| 896 | + | |
| 897 | + | |
| 898 | + | |
915 | 899 | | |
916 | 900 | | |
917 | 901 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
67 | 67 | | |
68 | 68 | | |
69 | 69 | | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
70 | 73 | | |
71 | 74 | | |
72 | 75 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
109 | 109 | | |
110 | 110 | | |
111 | 111 | | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
112 | 125 | | |
113 | 126 | | |
114 | 127 | | |
| |||
0 commit comments