Итак, я использую ExecutorService для многопоточности, и поскольку задачи в основном являются проверкой прокси, номера потоков велики (около 1000 потоков). Что ж, когда потоки не добавляются, но их медленно убивают, приложение начинает замедляться, а потоки убиваются все медленнее, пока оно просто не останавливается и не зависает при малых числах (например, 25 потоков).
Как это можно решить без фактического насильственного уничтожения этих потоков и выполнения работы?
РЕДАКТИРОВАТЬ: Доброе утро, я записал мою проблему, чтобы мы могли ее понять, даже по моей неверной интерпретации. https://streamable.com/cgoa6
А вот код этой программы:
Основной класс:
package me.inao.proxycheck;
import me.inao.proxycheck.menu.Selection;
import java.io.BufferedReader;
import java.io.FileReader;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class Main {
public static void main(String[] args){
byte mode = new Selection().getNumSelect(new String[]{"Proxy check", "Test2", "Test3"});
byte proxyType = 0;
BufferedReader reader = null;
int threads = 1000;
ExecutorService pool = Executors.newFixedThreadPool(threads);
if(mode == 1){
proxyType = new Selection().getNumSelect(new String[]{"HTTP(s)", "SOCKS"});
try{
reader = new BufferedReader(new FileReader("./proxies.txt"));
String line;
boolean breakx = false;
while(true){
for(int i = 0; i < (threads+1); i++){
line = reader.readLine();
byte finalProxyType = proxyType;
String finalLine = line;
if(finalLine != null){
pool.execute(() -> {
new Thread().checkProxy(finalLine, finalProxyType);
});
}else{
breakx = true;
break;
}
}
if(breakx){
break;
}
}
}catch (Exception e){
System.out.println("File 'proxies.txt.txt' not found..");
}
}
pool.shutdown();
}
}
Класс me.inao.proxycheck.Thread:
package me.inao.proxycheck;
import me.inao.proxycheck.proxy.ProxyCheck;
import java.io.File;
import java.io.FileWriter;
import java.net.Proxy;
public class Thread extends java.lang.Thread {
public void checkProxy(String line, byte type){
Proxy proxy = new ProxyCheck().createProxy(line.split(":")[0], line.split(":")[1], type);
if(new ProxyCheck().isValid(proxy)){
System.out.println("Found valid: " + proxy.type() + " | " + proxy.address().toString());
if(!(new File("./proxies/").exists())){
new File("./proxies").mkdir();
}
File f;
if(type == 1) f = new File("./proxies/workingHTTP.txt");
else if(type == 2) f = new File("./proxies/workingSOCKS.txt");
else f = new File("./proxies/workingOTHERS.txt");
if(f.exists()){
try{
FileWriter wr = new FileWriter(f, true);
wr.write(line + "\n");
wr.flush();
wr.close();
}catch (Exception e){
e.printStackTrace();
}
}else{
try{
FileWriter wr = new FileWriter(f);
wr.write(line + "\n");
wr.flush();
wr.close();
}catch (Exception e){
e.printStackTrace();
}
}
}
}
}
Класс me.inao.proxycheck.proxy.ProxyCheck
package me.inao.proxycheck.proxy;
import java.net.*;
public class ProxyCheck {
public Proxy createProxy(String addr, String port, byte type){
if(addr == null || port == null){
System.out.println("Provided invalid proxy (null)");
return null;
}
SocketAddress address = new InetSocketAddress(addr, Integer.parseInt(port));
if(type == 1){
return new Proxy(Proxy.Type.HTTP, address);
}
else if(type == 2){
return new Proxy(Proxy.Type.SOCKS, address);
}
else return null;
}
public boolean isValid(Proxy proxy){
try{
if(proxy != null){
URL url = new URL("http://azenv.net/");
HttpURLConnection conn = (HttpURLConnection)url.openConnection(proxy);
conn.setRequestMethod("GET");
conn.setConnectTimeout(5000);
conn.connect();
if(conn.getResponseCode() == 200){
return true;
}else{
return false;
}
}
}catch (Exception e){
return false;
}
return false;
}
}