Скорее всего где-то присваивается значение переменной модуля. Ты думаешь, что это происходит при каждом запросе, но это происходит всего 1 раз.
например, если этот код
alexlpопределен на уровне модуля, то проблема очевидна.
session = Session.query(User).get('request.GET')
session.save()
Приведу пример:
надо написать простую обертку вокруг коннекта к Sqlite, чтобы в контроллере, мидлварях или моделях не плодить новые подключения, а использовать уже открытые:
пишем модуль db:
import sqlite3
_coonnections = {}
def connection(database):
try:
return _connections[database]
except KeyError:
cn = sqlite3.connect(database)
_connections[database] = cn
return cn
from db import connection
cn = connection('test.db')
Но как только появятся другие потоки - программа начнет вылетать с ошибкой
ProgrammingError: SQLite objects created in a thread can only be used in that same thread.The object was created in thread id 2244 and this is thread id 2236
Думаю твои сессии путаются из-за переменных инициализируемых на уровне модуля.