diff --git a/src/main/java/lion/CustomUtil.java b/src/main/java/lion/CustomUtil.java index 79dddab..6621e72 100644 --- a/src/main/java/lion/CustomUtil.java +++ b/src/main/java/lion/CustomUtil.java @@ -3,8 +3,6 @@ package lion; import com.fasterxml.jackson.databind.ObjectMapper; import lombok.Data; -import java.io.IOException; -import java.net.ServerSocket; import java.util.concurrent.atomic.AtomicInteger; @@ -14,19 +12,4 @@ public class CustomUtil { public static AtomicInteger counter = new AtomicInteger(); public static ObjectMapper objectMapper = new ObjectMapper(); - - /** - * 寻找一定数量的可用端口 - * - * @return 可用端口的起始位置 -1为没有(几乎没有可能) - */ - public static short _findIdlePort(){ - for(int i=20000; i<65535; i++){ - try(ServerSocket ignored = new ServerSocket(i)){ - return (short) i; - }catch (IOException ignored) { - } - } - return -1; - } } diff --git a/src/main/java/lion/Domain/GalleryTask.java b/src/main/java/lion/Domain/GalleryTask.java index f57b90e..22aa4a8 100644 --- a/src/main/java/lion/Domain/GalleryTask.java +++ b/src/main/java/lion/Domain/GalleryTask.java @@ -6,17 +6,11 @@ import lombok.Data; @Data public class GalleryTask { - public static byte DOWNLOADING = 1; - public static byte DOWNLOAD_COMPLETE = 2; - - public static byte DOWNLOAD_QUEUED = 3; - + public static byte COMPRESSING = 3; public static byte COMPRESS_COMPLETE = 4; - public static byte COMPRESSING = 5; - @JsonInclude(JsonInclude.Include.NON_NULL) private String name; diff --git a/src/main/java/lion/ErrorCode/ErrorCode.java b/src/main/java/lion/ErrorCode/ErrorCode.java index 26f432c..f0063d7 100644 --- a/src/main/java/lion/ErrorCode/ErrorCode.java +++ b/src/main/java/lion/ErrorCode/ErrorCode.java @@ -3,7 +3,4 @@ package lion.ErrorCode; public class ErrorCode { public static final byte IO_ERROR = 1; public static final byte FILE_NOT_FOUND = 2; - - public static final byte COMPRESS_ERROR = 3; - } diff --git a/src/main/java/lion/MultiThreadedHTTPServer.java b/src/main/java/lion/MultiThreadedHTTPServer.java index 9c7d7d4..0c57fd5 100644 --- a/src/main/java/lion/MultiThreadedHTTPServer.java +++ b/src/main/java/lion/MultiThreadedHTTPServer.java @@ -106,7 +106,7 @@ public class MultiThreadedHTTPServer { // Get the range information for resuming download long startByte = 0; long endByte = fileLength - 1; - String rangeHeader = getRequestHeader(requestReader, "Range"); + String rangeHeader = getRequestHeader(requestReader); if (rangeHeader != null && rangeHeader.startsWith("bytes=")) { String[] rangeValues = rangeHeader.substring(6).split("-"); startByte = Long.parseLong(rangeValues[0]); @@ -158,15 +158,15 @@ public class MultiThreadedHTTPServer { } } - private static String getRequestHeader(BufferedReader requestReader, String headerName) throws IOException { + private static String getRequestHeader(BufferedReader requestReader) throws IOException { String line; while ((line = requestReader.readLine()) != null) { if (line.trim().isEmpty()) { break; } - if (line.startsWith(headerName + ":")) { - return line.substring(headerName.length() + 1).trim(); + if (line.startsWith("Range" + ":")) { + return line.substring("Range".length() + 1).trim(); } } return null; diff --git a/src/main/java/lion/Service/DownloadCheckService.java b/src/main/java/lion/Service/DownloadCheckService.java index d2d86c8..41c69d6 100644 --- a/src/main/java/lion/Service/DownloadCheckService.java +++ b/src/main/java/lion/Service/DownloadCheckService.java @@ -5,7 +5,6 @@ import io.netty.channel.DefaultEventLoop; import io.netty.channel.EventLoop; import io.netty.util.concurrent.Promise; import lion.Domain.GalleryTask; -import lion.ErrorCode.ErrorCode; import cn.hutool.core.io.FileUtil; import cn.hutool.core.util.ZipUtil; import lion.Message.AbstractMessage; @@ -30,7 +29,7 @@ public class DownloadCheckService { ScheduledThreadPoolExecutor convert_thread; - ArrayList convert_queue; + ArrayList compress_queue; Channel node; @@ -42,9 +41,9 @@ public class DownloadCheckService { this.queue = queue; this.promises = promises; eventLoop = new DefaultEventLoop(); - convert_queue = new ArrayList<>(0); + compress_queue = new ArrayList<>(0); convert_thread = new ScheduledThreadPoolExecutor(1); - convert_thread.scheduleAtFixedRate(this::convert, 0, 5, TimeUnit.SECONDS); + convert_thread.scheduleAtFixedRate(this::compress, 0, 5, TimeUnit.SECONDS); } public boolean downloadCheck(){ @@ -60,29 +59,35 @@ public class DownloadCheckService { ArrayList files = new ArrayList<>(Arrays.asList(fileArray)); + boolean result = false; //扫描进度 Iterator fileIterator = files.iterator(); for(GalleryTask galleryTask: queue){ //跳过已经下载完成或者压缩完成的任务 - if(galleryTask.is_download_complete() - || galleryTask.is_compress_complete() - || galleryTask.is_compressing()) + if(galleryTask.is_compress_complete() || galleryTask.is_compressing()) { + result = true; continue; + } while(fileIterator.hasNext()){ File file = fileIterator.next(); if(!file.getName().contains(String.valueOf(galleryTask.getGid()))) continue; + galleryTask.setStatus(GalleryTask.DOWNLOADING); fileIterator.remove(); - galleryTask.setName(file.getName()); + if(galleryTask.getName() == null || !galleryTask.getName().equals(file.getName())) + galleryTask.setName(file.getName()); File[] pages = file.listFiles((dir, name) -> !name.equals("galleryinfo.txt")); if (pages == null || pages.length == 0) continue; + if(galleryTask.getProceeding() != pages.length) + result = true; galleryTask.setProceeding(pages.length); if (new File(file.getPath(), "galleryinfo.txt").exists()) { + result = true; galleryTask.setStatus(GalleryTask.DOWNLOAD_COMPLETE); galleryTask.setPath(file.getPath()); } @@ -90,34 +95,28 @@ public class DownloadCheckService { fileIterator = files.iterator(); } - //转格式队列 + //压缩队列 for(GalleryTask galleryTask: queue) if (galleryTask.is_download_complete()) { galleryTask.setStatus(GalleryTask.COMPRESSING); - convert_queue.add(galleryTask); + compress_queue.add(galleryTask); } - return true; + return result; } /** - * 转换线程:将转换队列的任务复制一份,进行转换 + * 压缩线程:将压缩队列的任务复制一份,进行转换 */ - public void convert() { - if(convert_queue.isEmpty()) + public void compress() { + if(compress_queue.isEmpty()) return; ReentrantLock reentrantLock = new ReentrantLock(); reentrantLock.lock(); - ArrayList galleryTasks = new ArrayList<>(convert_queue); - convert_queue.clear(); + ArrayList galleryTasks = new ArrayList<>(compress_queue); + compress_queue.clear(); reentrantLock.unlock(); for (GalleryTask galleryTask : galleryTasks) { - File[] images = new File(galleryTask.getPath()).listFiles((dir, name) -> name.endsWith(".jpg") || name.endsWith(".png")); - if (images == null) { - galleryTask.setStatus(ErrorCode.COMPRESS_ERROR); - continue; - } - //创建文件夹 File file = new File(storagePath + galleryTask.getName()); if (file.isDirectory() || file.mkdirs()) { diff --git a/src/main/java/lion/storageNode.java b/src/main/java/lion/storageNode.java index 1aba734..0e2fc78 100644 --- a/src/main/java/lion/storageNode.java +++ b/src/main/java/lion/storageNode.java @@ -85,14 +85,24 @@ public class storageNode { tempQueue.clear(); } lock.unlock(); - //检查 - if (!downloadCheckService.downloadCheck() && queue.isEmpty()) { - counter++; - if(server != null && server.isActive() && counter > 10) { - server.writeAndFlush(new MaintainMessage()); - counter = 0; + //检查,当任务状态发生变化即方法返回true时,再更新,否则return + if (!downloadCheckService.downloadCheck()) { + boolean isSkip = true; + //返回false之后,还要额外检查是否有压缩完成的任务 + if(!queue.isEmpty()) + for (GalleryTask galleryTask : queue) + if (galleryTask.is_compress_complete()) { + isSkip = false; + break; + } + if(isSkip) { + counter++; + if (server != null && server.isActive() && counter > 10) { + server.writeAndFlush(new MaintainMessage()); + counter = 0; + } + return; } - return; } //发送 //上锁后再发送,避免出现发送完之后再下载完成