- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
看一下下面的代码。1.我正在创建一个到stardog的连接池
2. 从池中获取连接。3、使用完毕后将连接归还到池中。
我的问题是,如果我执行 aConn.close()
而不是返回到池中,会发生什么。
ConnectionConfiguration aConnConfig = ConnectionConfiguration
.to("testConnectionPool")
.credentials("admin", "admin");
ConnectionPoolConfig aConfig = ConnectionPoolConfig
.using(aConnConfig)
.minPool(10)
.maxPool(1000)
.expiration(1, TimeUnit.HOURS)
.blockAtCapacity(1, TimeUnit.MINUTES);
// now i can create my actual connection pool
ConnectionPool aPool = aConfig.create();
// if I want a connection object...
Connection aConn = aPool.obtain();
// now I can feel free to use the connection object as usual...
// and when I'm done with it, instead of closing the connection,
//I want to return it to the pool instead.
aPool.release(aConn);
// and when I'm done with the pool, shut it down!
aPool.shutdown();
如果我通过aConn.close();关闭连接会发生什么
每当我在任何类中使用连接时我询问的主要原因是我没有池对象来执行aPool.release(aConn);
是否建议这样做。它会破坏池化的使用吗?
最佳答案
如果你直接关闭连接,池仍然会有对连接的引用,因为它还没有被释放,所以当连接将关闭其资源时,池将保留引用,你可能会泄漏内存时间。
处理这个问题的建议方法是当您从池中获取连接时,使用 DelegatingConnection 包装它:
public final class PooledConnection extends DelegatingConnection {
private final ConnectionPool mPool;
public PooledConnection(final Connection theConnection, final ConnectionPool thePool) {
super(theConnection);
mPool = thePool;
}
@Override
public void close() {
super.close();
mPool.release(getConnection());
}
}
这样,您可以简单地在使用它的代码中关闭连接,它将正确地释放回池中,并且您不必担心传递对池的引用。
关于java - 如果我关闭 stardog 连接池中的连接会发生什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15922807/
我在问自己一个问题:我有一个 .ttl 文件存储在互联网上的某个地方(比如说 http://www.example/org/myFile ),我想查询它。 我可以用Stardog查询吗?类似于(在 n
我在 Stardog 中创建了一个自定义聚合函数来计算标准差。当您将 SPARQL 查询发布到端点或通过管理控制台中的查询面板时,这非常有用。 到目前为止,一切顺利,但我们面临一些问题。首先,当我们执
我正在使用 java 在 stardog 中创建一个新数据库。 当我创建数据库并在本地主机中导入 RDF 文件时,它的工作正常。 但是当我在远程服务器中创建数据库时,我收到同一 RDF 文件的文件未找
我可以使用以下 CLI 命令将自定义规则添加到 Stardog 中的命名图表: stardog data add db_name -g "http://graph_name"/path/to/rule
我正在使用 Stardog 来存储一堆来自不同来源的三元组。我使用 Jena 收集数据并将其合并到单个 Jena 图中。所有这些三元组都是 ABox 的一部分。 我不确定 Stardog 是否会要求
几周前它运行良好,但现在我在使用 stardog-admin.bat server start 启动服务器时遇到问题。当我这样做时,出现以下错误: WARNING: An illegal reflec
看一下下面的代码。1.我正在创建一个到stardog的连接池 2. 从池中获取连接。3、使用完毕后将连接归还到池中。 我的问题是,如果我执行 aConn.close() 而不是返回到池中,会发生什么。
所以我已经将这个.rdf加载到Stardog上然后我使用 Pubby跑过码头,浏览三重商店。 在我的 rdf 文件中,我有几个空白节点,stardog 为其赋予了空白节点标识符。这是 rdf 文件的一
我正在使用 RDFLib Python 库来操作 Stardog 数据库。如何添加空白节点?我正在尝试g.add((BNode(),FOAF.knows,Literal('amy'))) ,但我收到异
我正在尝试做一些非常简单的事情:连接到数据库,读取一些记录,并将它们显示在一个漂亮的界面中。 到目前为止,我所做的只是使用以下代码启动和停止服务器: Server aServer = Stardog
我正在尝试自定义 Stardog 规则。自定义规则基本上如下所示: @prefix rule: . [] a rule:SPARQLRule ; rule:content """ PREFIX
我有一个 SPARQL 查询,它在启用推理时在 Stardog 查询面板中返回结果,但在禁用时不返回结果。当我尝试使用 SPARQLwrapper 通过 python 进行查询时,我没有得到任何结果。
我是一个 Linux super 新手,所以让我们来分解一下。我正在关注these instructions但它似乎仍然不起作用。 我的 stardog.conf 文件如下所示: descriptio
我无法在 Sesame 2.8.1 存储库的帮助下将 Topbraid Composer 4.6.3 连接到 Stardog 3.0。这些是我正在执行的步骤: 创建新的 RDF/OWL Sesame2
我刚刚下载了 Stardog,并尝试在我的机器 (Mac OS X 10.14.2) 上运行它。 我使用 ZSH shell 并在我的 .zshrc 文件中添加了以下两行: export STARDO
我正在尝试使用 graphql 查询 stardog 服务器,下面是我的代码。 import { GraphQLSchema, GraphQLObjectType, GraphQLInt,
我正在尝试将我的应用程序与 stardog 集成。该应用程序已通过 sesame RemoteRepository 接口(interface)访问 Java 中的其他 RDF 存储库。 Stardog
尝试从 Node JS 应用程序查询本地运行的 Stardog 数据库。 查询在 Stardog 界面中运行时返回结果。 在 Node 中运行它时,返回 null 和错误的 promise 会搞砸。
正如标题所说,我正在尝试使用来自 visualstudio 的 SPARQL 查询来创建三元组。在 stardog studio 中使用相同的 SPARQL 查询是可行的,但是当我尝试使用 stard
我是一名优秀的程序员,十分优秀!