1

我有一个执行以下操作的控制器操作:

  1. 从数据库中获取域对象

  2. 使用该对象的信息来查找数据文件(在磁盘上)并将该文件的内容写入响应输出流。

我的问题是数据库连接是在操作期间保留的,包括流式传输数据所需的(长时间)时间。当有多个用户同时流式传输数据时,这会导致大量不必要的数据库连接。

def stream() {
  StreamDetails sd = StreamDetails.get(params.id)

  // Extract info needed to read the stream
  String filename = sd.filename

  // The database connection is no longer needed, how to properly release it?

  // Start writing the data stream to response output
  // This may take a long time and does not use a db connection
  streamService.writeToOutput(filename,response.getOutputStream())
}

我试过了:

  1. sessionFactory将bean注入控制器并sessionFactory.currentSession.close()在调用服务之前调用。但是,这会导致SessionException在线调用服务,即。在输入writeToOutput()方法之前(并且该方法中的任何内容都不需要数据库连接)。而且我认为会话不应该真正关闭,只是释放到池中。

  2. 将代码复制粘贴streamService.writeToOutput(...)到控制器以避免服务调用。在这种情况下,所有代码都会被执行,但SessionException在操作完成后仍然会抛出 a 。

如何正确提前释放连接?

4

1 回答 1

-1

您是否尝试过注入数据源?您可以使用 DataSourceUtils 创建一个新连接,然后您可以使用它来获取文件名。然后您可以手动关闭()此连接。

我不知道您是否可以将此连接与 gorm 结合使用,因此您可能还必须创建自定义 sql 查询。

于 2012-10-19T12:27:11.447 回答