2017-01-03 11:46
@sdfsf 以下这几个链接中有上千个相关项目,供参考:
http://git.oschina.net/search?search=jfinal&type=project&condition=updated_at
https://www.oschina.net/search?q=jfinal&scope=project&tag1=0&tag2=0&lang=0&os=0
https://github.com/search?o=desc&q=jfinal&s=stars&type=Repositories&utf8=%E2%9C%93
2017-01-02 21:52
@localhost8080 根据日志提示信息,可以猜测一下,可能是连接池在多线程下并发分配资源时造成了死锁,但死锁存在并不一定就是不正常的,检测出死锁,将死锁去除也是一种处理方式。
据日志信息来说这类死锁可能是正常现象,否则就直接报ERROR,而不是WARN
2017-01-01 17:57
@xzquan 返回true 对于 start() 来说是告诉 jfinal 插件启动正常,返回 false则 jfinal 会报出异常,终止项目的启动,这种机制是让插件可以告知 jfinal 是否要终止项目的启动
如果某个插件是一个关键性插件,启动不正常就会影响关键业务,这时让项目无法启动是必要的
类似的 stop 是告知 jfinal 插件停止失败,jfinal 会对此写日志,可通过查看日志知道插件为什么没有停止成功,进而去修正程序
2017-01-01 15:07
start() 与 stop() 方法会别会在 jfinal 启动与停止时被回调,开发插件,只需要实现 IPlugin 接口,在 start() 里面放入希望项目启动时的操作,在 stop() 中放入希望项目停止时的操作即可
除了 Plugin 以外,jfinal 的主要扩展方式有:Controller、Model、Interceptor、Render、Handler,这五个扩展方式相对比较具体,针对于特定需求去扩展,而 IPlugin 就担当起了不确定需求与方向的扩展,因为 jfinal 无法穷尽所有用户需求和场景,而 Plugin 是一个更加抽象化,没有指明具体方向的扩展