1

我为 TeamSpeak 服务器构建了一个应用程序(我通过专用框架编写的代码),该应用程序包含 3 个计时器和一些指令,可以从一秒到一秒地更新数据库中的记录。应用程序前几分钟运行正常,内存消耗从3.0%逐渐增加,但停止在29-30%,逐渐增加不减少!并且在运行大约 5-6 分钟后,应用程序开始消耗 100% 的处理器,并且其功能不再工作,或者工作繁重。

处理器100%后出现此错误:

Exception in thread "Timer-0" java.lang.OutOfMemoryError: Java heap space

SQL 文件连接器:

public class SQL {

    public static Connection con;

    String host;
    String name;
    String password;
    String database;

    public SQL(String host, String user, String pw, String db) {
        this.host = host;
        this.name = user;
        this.password = pw;
        this.database = db;
    }

    public void connect() {
        if(!isConnected()) {
            try {
                con = DriverManager.getConnection("jdbc:mysql://" + host + ":3306/" + database + "?autoReconnect=true&serverTimezone=UTC", name, password);
                System.out.println("[MySQL] Modulul MySQL a pornit cu succes!");

            } catch (SQLException e) {
                e.printStackTrace();
                System.out.println("[MySQL] Eroare modul SQL: §c" + e.getMessage());

            }

        }
    }

    public void close() {
        if(isConnected()) {
            try {
                con.close();
                System.out.println("[MySQL] Modulu SQL a fost inchis!");

                } catch (SQLException e) {
                e.printStackTrace();
                System.out.println("[MySQL] §4Eroare modul SQL: §c" + e.getMessage());

            }
        }
    }

    public boolean isConnected() {
        return con != null;

    }

    public void createTable(String name, String table) {
        try {
            con.createStatement().executeUpdate("CREATE TABLE IF NOT EXISTS " + name + "(" + table + ")");
        } catch (SQLException e) { 
            e.printStackTrace();
        }
    }

    public void update(String qry) {
        if(isConnected()) {
            try {
                con.createStatement().executeUpdate(qry);
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }

    public ResultSet getResult(String qry) {
        if(isConnected()) {
            try {
                return con.createStatement().executeQuery(qry);
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        return null;
    }

}

定时器构造函数:

            Timer timer = new Timer();
            TimerTask task1 = new TimerActivity();
            timer.scheduleAtFixedRate(task1, 1000, 1000);

定时器文件:

public class TimerActivity extends TimerTask {  

    @Override
    public void run() {
        for(Client c : Load.api.getClients()) {
            if(!(c.isOutputMuted()) && c.isRegularClient()) {
                if(FSQL.Client.ClientExist(c.getUniqueIdentifier())) {
                    try {
                    FSQL.Client.uptodate("users", "timeon = timeon + 1", "uniqid = '"+c.getUniqueIdentifier()+"'");
                    }catch (Exception e) {
                        e.printStackTrace();
                    }
                }
                else {
                    FSQL.Client.CreateClient(c.getUniqueIdentifier());
                }
            }
        }

    }

}

FSQL 类客户端:

public class Client extends Connection {

    public static Object get(String whereresult, String where, String select, String database) {

        ResultSet rs = mysql.getResult("SELECT " + select + " FROM " + database + " WHERE " + where + "='" + whereresult + "'");
        try {
            if(rs.next()) {
                Object v = rs.getObject(select);
                return v;
            }
        } catch (SQLException e) {
            return "ERROR";
        }

        return "ERROR";
    }

    public static int getint(String whereresult, String where, String select, String database) {

        ResultSet rs = mysql.getResult("SELECT " + select + " FROM " + database + " WHERE " + where + "='" + whereresult + "'");
        try {
            if(rs.next()) {
                int v = rs.getInt(select);
                return v;
            }
        } catch (SQLException e) {
            return 0;
        }

        return 0;
    }

    public static boolean exist(String tabela, String conditie, String cautat) {
        try {

            ResultSet rs = mysql.getResult("SELECT * FROM "+tabela+" WHERE "+ conditie + "'");
            if (rs.next()) {
                return rs.getString(cautat) != null;
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return false;
    }

    public static void uptodate(String tabela, String setul, String conditia) {
        mysql.update("UPDATE "+tabela+" SET "+setul+" WHERE "+conditia); 
    }

    public static boolean ClientExist(String id)
    {
        try {

                ResultSet rs = mysql.getResult("SELECT * FROM users WHERE uniqid= '" +id + "'");
            if(rs.next()) {
                return rs.getString("uniqid") !=null;
            }
        }catch (SQLException e) {
            e.printStackTrace();
        }
        return false;
    }

    public static void CreateClient(String id)
    {
        mysql.update("INSERT INTO users(UNIQID, LEVEL, COINS) VALUES ('"+id+"','0','0')");
        mysql.update("INSERT INTO function(UNIQID, LANG) VALUES ('"+id+"','0')");
    }

    public static void CreateChannel(String id, String data, int idcanal)
    {
        mysql.update("INSERT INTO channelsprivat(CLIENTID, DATE, CHID) VALUES ('"+id+"','"+data+"','"+idcanal+"')");
    }

    public static void CreateTag(int id)
    {
        mysql.update("INSERT INTO tags(IDCHANAL) VALUES ('"+id+"')");
    }

     public static Integer CheckMovePrivat(String id)

    {
        int i = 0;
        try {
        ResultSet rs = mysql.getResult("SELECT pmv FROM function WHERE uniqid= '" +id + "'");
        if(!rs.next() || (Integer.valueOf(rs.getInt("pmv")) == null));
            i = rs.getInt("pmv");
            return i;
        }catch (SQLException e) {
            e.printStackTrace();
            }
        return 0;
     }

     public static Integer IDChanal(String id)

        {
            int i = 0;
            try {
            ResultSet rs = mysql.getResult("SELECT chid FROM channelsprivat WHERE clientid= '" +id + "'");
            if(!rs.next() || (Integer.valueOf(rs.getInt("chid")) == null));
                i = rs.getInt("chid");
                return i;
            }catch (SQLException e) {
                e.printStackTrace();
                }
            return 0;
         }

     public static Integer TimeActiv(String id)

        {
            int i = 0;
            try {
            ResultSet rs = mysql.getResult("SELECT timeon FROM users WHERE uniqid= '" +id + "'");
            if(!rs.next() || (Integer.valueOf(rs.getInt("timeon")) == null));
                i = rs.getInt("timeon");
                return i;
            }catch (SQLException e) {
                e.printStackTrace();
                }
            return 0;
         }


}

在 FSQL 中是 conn 的类 Connection:

package FSQL;

import Main.SQL;

public class Connection {

    public static SQL mysql;

    public static void Myconnect() {

   mysql = new SQL("localhost", "root", "", "popicu");
        mysql.connect();
    }
}

加载.java

package Main;

import com.github.theholywaffle.teamspeak3.TS3Api;
import com.github.theholywaffle.teamspeak3.TS3Config;
import com.github.theholywaffle.teamspeak3.TS3Query;
import java.util.*;

import Exclusiv.TimerActivity;
import Exclusiv.TimerGroup;
import Exclusiv.TimerTopic;
import FSQL.Connection;

public class Load {

            // Initializare query
            public static final TS3Config config = new TS3Config();
            public static final TS3Query query = new TS3Query(config);
            public static final TS3Api api = query.getApi();

            public static void main(String[] args) {

            config.setHost("ipserver");
            query.connect();
            api.login("username", "password");  
            api.selectVirtualServerByPort(9987);    
            api.setNickname("[SRI] Nea-Popicu");
            System.out.println("Botul este conectat pe serverul dvs.");
            Events.LoadEvents();
            Connection.Myconnect();

            //Timere
            Timer timer = new Timer();
            TimerTask task1 = new TimerActivity(); 
            Timer timer2 = new Timer(); 
            TimerTask task2 = new TimerGroup(); 
            Timer timer3 = new Timer(); 
            TimerTask task3 = new TimerTopic(); 

            timer.scheduleAtFixedRate(task1, 1000, 1000);
            timer2.scheduleAtFixedRate(task2, 1000, 1000);
            timer3.scheduleAtFixedRate(task3, 1000*60, 1000*60);

            }
}

nohup 文件或屏幕上不会出现错误。

4

0 回答 0