nutz,今晚来一发(2): 文件上传时得到路径怎么全是00/00/00/00,能不能改

代码如下:

    @AdaptBy(type=UploadAdaptor.class,args={"~/tmp"})
    @At("/upload/*")
    public String test_upload(String type, @Param("file")TempFile file){
        System.out.println(file.getFile().getAbsolutePath());
        return type + "&" + file.getFile();
    }

会输出这样的log

C:\Users\Administrator\tmp\00\00\00\00\00\00\00\48

为什么呢? 

答案一如既往在下期提问中给出...

--------------------------------------------------华丽的分割线-------------------------------

上期的答案,供参考:

注意, java.sql.DataSource只是个接口.但下面讨论的DataSource均指代数据库连接池实现. 

根本原因在于: Nutz的Ioc容器不是全局的,一旦没有被引用,就随时被GC.

  1. 题目中的NutIoc实例,在方法返回之后,处于无引用的状态, 即满足了GC的条件,随时会被GC.

  2. 题目中默认为2个基本ioc对象, DataSource和Dao, 其中Dao默认指代NutDao

  3. NutIoc被gc时,会触发depose事件, 从而调用各ioc对象的depose/close方法

  4. 一般来说DataSource都会配置成depose事件触发close方法,即关闭连接池. 这样就导致DataSource对象处于关闭状态, 而NutDao的数据库连接均由DataSource提供, 直接导致NutDao实例在操作任意数据库方法时报错.

  5. 注意, GC的时机是几乎不可控,不可预测的, 这就意味着上述的ioc容器被gc, depose方法被调用,DataSource被关闭的时机也是不可控及不可预测的. 这会导致程序有时候是好的(GC在Dao方法执行完成之后),有时候会挂的(GC在Dao执行完成之前)

错误的解决思路:

1. 去掉depose事件. 首先是连接池都有初始大小和最小活跃数,这意味着DataSource被gc前总持有那么几个数据库连接. 并发上去了,gc来不及, 很快就数据库连接耗尽.

2. 那,去掉depose事件,连接池初始化大小和最小活跃数都设置为0呢. 初始化大小为0, 但你总会使用一次NutDao的方法吧, 那么就建立了一个连接, 然后最小活跃数是0, 将连接数从1降为0那么, 总有那么一个时间差,然后, 呵呵, 一个坑就摆在那了, 哪天碰巧没能快速关闭,也没被gc, 爆数据库连接数

3. 好吧,那我不用连接池,可以了吧? 可以,性能掉渣

解决方法:

  1. 在Mvc中, 你几乎100%会用到@IocBy, 也就是NutMvc来持有ioc, 那么你就不别自行new NutIoc了. 在Setup接口中,你可以通过config.getIoc()来获取Ioc容器(常见于启动时的初始化,加载全局变量,计划任务什么的), 在任何不可能直接得到Ioc容器的地方, 通过 Mvcs.ctx().getDefaultIoc() 获取 .注意, Mvcs.ctx()总是非常规方法.

  2. 非Mvc环境, 应使用一个工具类管理, 而且必须持有Ioc容器


  3. public class DaoZ { // 供参考
        private static Ioc ioc; // 静态属性,确保了Ioc容器不会被gc
        
        public static synchronized Ioc ioc() { // 同步,用你喜欢的方法就好啦
            if (ioc == null) {
                try {
                    ioc = new NutIoc(new ComboIocLoader("*js","ioc/", "*annotation", "net.wendal.iot"));
                }
                catch (ClassNotFoundException e) {
                    throw Lang.warp(e);
                }
            }
            return ioc;
        }
        
        public static Dao dao() {
            return ioc.get(Dao.class);
        }
    }


转载于:https://my.oschina.net/wendal/blog/357542

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值