@@ -89,6 +89,7 @@ class DatabaseWrapper(BaseDatabaseWrapper):
89
89
"endswith" : "LIKE '%%' || {}" ,
90
90
"iendswith" : "LIKE '%%' || UPPER({})" ,
91
91
}
92
+ _connection_pools = {}
92
93
93
94
def _isnull_operator (a , b ):
94
95
is_null = {
@@ -176,7 +177,12 @@ def get_connection_params(self):
176
177
177
178
@async_unsafe
178
179
def get_new_connection (self , conn_params ):
179
- return MongoClient (** conn_params , driver = self ._driver_info ())
180
+ if self .alias not in self ._connection_pools :
181
+ conn = MongoClient (** conn_params , driver = self ._driver_info ())
182
+ # setdefault() ensures that multiple threads don't set this in
183
+ # parallel.
184
+ self ._connection_pools .setdefault (self .alias , conn )
185
+ return self ._connection_pools [self .alias ]
180
186
181
187
def _driver_info (self ):
182
188
if not os .environ .get ("RUNNING_DJANGOS_TEST_SUITE" ):
@@ -192,11 +198,27 @@ def _rollback(self):
192
198
def set_autocommit (self , autocommit , force_begin_transaction_with_broken_autocommit = False ):
193
199
self .autocommit = autocommit
194
200
201
+ def _close (self ):
202
+ pass
203
+
195
204
@async_unsafe
196
205
def close (self ):
197
- super ().close ()
206
+ self .validate_thread_sharing ()
207
+ # MongoClient is a connection pool and, unlike database drivers that
208
+ # implement PEP 249, shouldn't be closed by connection.close().
209
+
210
+ def close_pool (self ):
211
+ """Close the MongoClient."""
212
+ connection = self .connection
213
+ if connection is None :
214
+ return
215
+ # Remove all references to the connection.
216
+ self .connection = None
198
217
with contextlib .suppress (AttributeError ):
199
218
del self .database
219
+ del self ._connection_pools [self .alias ]
220
+ # Then close it.
221
+ connection .close ()
200
222
201
223
@async_unsafe
202
224
def cursor (self ):
0 commit comments