JFinal Weixin 已经设置了RedisPlugin,获取值时提示Could not get a resource from the pool

发布于 2021-11-30 10:30:50 字数 2022 浏览 984 评论 1



@JFinal 你好,
我在使用JFinal Weixin时,已经在代码中声明RedisPlugin,如下
public void configPlugin(Plugins me) {
// 配置C3p0数据库连接池插件
C3p0Plugin c3p0Plugin = new C3p0Plugin(PropKit.get("jdbcUrl"),
PropKit.get("user"), PropKit.get("password").trim());
me.add(c3p0Plugin);


//设置Redis缓存
RedisPlugin redis = new RedisPlugin("weixin", "localhost");
redis.start();
//me.add(redis);//添加该语句,会使cache对象为空
ApiConfigKit.setAccessTokenCache(new RedisAccessTokenCache());
}




实际使用中,在获取ACCESS_TOKEN时
public static AccessToken getAccessToken() {
String appId = ApiConfigKit.getApiConfig().getAppId();
AccessToken result = null;
try {
result = accessTokenCache.get(appId);
} finally {
if (result != null && result.isAvailable())
return result;

refreshAccessToken();
return accessTokenCache.get(appId);
}
}

accessTokenCache不为空,如图

但获取不到值,在refreshAccessToken方法中也写不了值,直接报错,提示“Could not get a resource from the pool?”?

redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource from the pool
at redis.clients.util.Pool.getResource(Pool.java:50)
at redis.clients.jedis.JedisPool.getResource(JedisPool.java:86)
at com.jfinal.plugin.redis.Cache.getJedis(Cache.java:1202)
at com.jfinal.plugin.redis.Cache.setex(Cache.java:72)
at com.jfinal.weixin.sdk.cache.RedisAccessTokenCache.set(RedisAccessTokenCache.java:19)
at com.jfinal.weixin.sdk.api.AccessTokenApi.refreshAccessToken(AccessTokenApi.java:73)
at com.jfinal.weixin.sdk.api.AccessTokenApi.getAccessToken(AccessTokenApi.java:49)
at com.jfinal.weixin.sdk.api.JsTicketApi.getTicket(JsTicketApi.java:47)
请问是什么原因造成的,如何解决?谢谢。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

岁月打碎记忆 2021-12-01 12:19:42

刚看到,这种异常多半是连接redis没有成功,或者是你本地的redis压根就没启动起来!

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文