碰到诡异问题,求助大能解答,关于表单提交大文件无限数据提交问题

服务器环境
php环境

出现情况:上传30M文件的时候 本地数据一直在提交,观察服务器io 也一直有下载流量。但是就没有个结束,php输出 $_FILES,也不会执行到这行代码,比如我提交30M文件表单提交,但是流量估计超过好几百M也不会停止,反正不人为停止脚步,就是不断在数据交互。请问有大哥碰到这情况吗?是否哪些php配置没配置对




大文件上传问题已解决 以我测试上传32M文件大小为例

php 运行方式 FPM-FCGI

php.ini 

upload_max_filesize = 64M//上传文件最大限制

post_max_size = 100M //POST方法提交最大限制 最好大于上面

max_execution_time = 300//脚本超时时间
max_input_time = 300
memory_limit = 200M //如果不够大。会导致内存溢出500错误

nginx.conf

client_max_body_size 100m; //根据文件大小自己调整提交空间


以上解决方案。自己查百度摸索出来分享下,有哪位大能能对大文件上传有比较系统的配置优化方案希望能指点一二,谢谢!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是Java多线程千万级数据导出的示例代码: ```java import java.io.File; import java.util.ArrayList; import java.util.List; import java.util.concurrent.CountDownLatch; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import com.alibaba.excel.ExcelWriter; import com.alibaba.excel.metadata.Sheet; import com.alibaba.excel.support.ExcelTypeEnum; public class ExcelExportUtil { /** * 导出Excel * * @param dataList 数据列表 * @param sheetName sheet名称 * @param filePath 文件路径 * @param fileName 文件名 * @param sheetSize 每个sheet中数据的行数 */ public static void exportExcel(List<List<Object>> dataList, String sheetName, String filePath, String fileName, int sheetSize) { // 创建线程池 ExecutorService executorService = Executors.newFixedThreadPool(10); // 创建ExcelWriter ExcelWriter excelWriter = new ExcelWriter(new File(filePath + fileName), ExcelTypeEnum.XLSX); // 计算需要创建的sheet数量 int sheetCount = dataList.size() % sheetSize == 0 ? dataList.size() / sheetSize : dataList.size() / sheetSize + 1; // 创建计数器 CountDownLatch countDownLatch = new CountDownLatch(sheetCount); // 创建sheet for (int i = 0; i < sheetCount; i++) { // 计算每个sheet中数据的起始位置和结束位置 int startIndex = i * sheetSize; int endIndex = Math.min(startIndex + sheetSize, dataList.size()); // 创建sheet Sheet sheet = new Sheet(i + 1, 0); sheet.setSheetName(sheetName + (i + 1)); // 创建数据列表 List<List<Object>> sheetDataList = new ArrayList<>(); for (int j = startIndex; j < endIndex; j++) { sheetDataList.add(dataList.get(j)); } // 将sheet数据提交到线程池中进行处理 executorService.submit(new ExcelExportTask(excelWriter, sheet, sheetDataList, countDownLatch)); } try { // 等待所有线程处理完成 countDownLatch.await(); } catch (InterruptedException e) { e.printStackTrace(); } finally { // 关闭ExcelWriter和线程池 excelWriter.finish(); executorService.shutdown(); } } } ``` 其中,ExcelExportTask是一个实现了Runnable接口的任务类,用于将数据写入Excel中。具体代码如下: ```java import java.util.List; import java.util.concurrent.CountDownLatch; import com.alibaba.excel.ExcelWriter; import com.alibaba.excel.metadata.Sheet; public class ExcelExportTask implements Runnable { private ExcelWriter excelWriter; private Sheet sheet; private List<List<Object>> dataList; private CountDownLatch countDownLatch; public ExcelExportTask(ExcelWriter excelWriter, Sheet sheet, List<List<Object>> dataList, CountDownLatch countDownLatch) { this.excelWriter = excelWriter; this.sheet = sheet; this.dataList = dataList; this.countDownLatch = countDownLatch; } @Override public void run() { try { // 写入数据 excelWriter.write0(dataList, sheet); } finally { // 计数器减1 countDownLatch.countDown(); } } } ``` 使用示例: ```java import java.util.ArrayList; import java.util.List; public class ExcelExportTest { public static void main(String[] args) { // 模拟数据 List<List<Object>> dataList = new ArrayList<>(); for (int i = 0; i < 10000000; i++) { List<Object> row = new ArrayList<>(); row.add("数据" + i); dataList.add(row); } // 导出Excel ExcelExportUtil.exportExcel(dataList, "Sheet1", "D:/", "data.xlsx", 1000000); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值