文件上传是 Web 开发中最常见的一个应用场景。一般在处理数据时,会有两种常见的方案:直接把文件流放在内存里,或者把文件流先缓冲到磁盘。
1、如果是高频且文件极小
使用纯内存模式,默认即可。如果高频小文件,是不适合用“临时文件模式”的,磁盘可能容易刷坏。只能多配些内存!
2、如果是服务器托管网低频或者文件很大
建议使用“临时文件模式”。即上传的数据流,先缓存为临时文件(落盘),再以本地文件流形式提供使用。这个非常省内存。比如,上传 1GB 的文件,服务内存几乎不会上升。
- 添加配置
使用临时文件需要服务器托管网通过配置开启
server.request.useTempfile: true #默认 false
- 用后主动删除(建议,不管有没有用“临时文件模式”都主动删除)
使用完后,注意要删掉
@Controller
public class DemoController{
@Post
@Mapping("/upload")
public void upload(UploadedFile file) {
try{
file.transferTo(new File("/demo/user/logo.jpg"));
} finally {
file.delete();
}
}
}
服务器托管,北京服务器托管,服务器租用 http://www.fwqtg.net
机房租用,北京机房租用,IDC机房托管, http://www.fwqtg.net
实际上,Hive 在较新的版本中已经支持毫秒级别的时间精度。你可以通过设置 hive.exec.default.serialization.format 和 mapred.output.value.format 属性为 1,启用 Hive 的时间精度为毫秒级。…