Застрял нить в сервере - PullRequest
0 голосов
/ 12 октября 2019

Мой класс java такой:

package com.indiabulls.portfoliotracker.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

import com.indiabulls.trade.dbConnection.JDBCConnection;


public class AppKeyValidationDao {
private static  JDBCConnection instance;
private static  Connection con;
private static  PreparedStatement pstmntAppKeyValidate = null;
private static long lastAccess;
private static Statement stmt = null;

private static String strappKeyValidate = "select count(1) from tablename";

static {
    try {
        instance = new JDBCConnection();
        con = instance.getConnection();
        pstmntAppKeyValidate = con.prepareStatement(strappKeyValidate);
        lastAccess = System.currentTimeMillis();
    } catch (SQLException e) {
    }
}

/**
 * 
 * @param userId
 * @param AppKey
 * @return this method will used for validate app Key from the database
 * @throws SQLException
 */
public static  String validateAppKey(String userId, String AppKey) throws SQLException {
    String status = "false";
    int count = 0;
    ResultSet rs = null;

    try {
        checkConnection();
        pstmntAppKeyValidate.setString(1, userId.trim());
        pstmntAppKeyValidate.setString(2, AppKey.trim());
        rs = pstmntAppKeyValidate.executeQuery();
        if (rs != null) {
            while (rs.next()) {
                count = rs.getInt(1);
            }
        }
        if (count > 0) {
            status = "true";
        }

    } catch (Exception e) {
        status = "ERROR";
        System.out.println("***********************Exception is*******" + e.getMessage());
        e.printStackTrace();
    } finally {
        try {
            if (rs != null) {
                rs.close();
                rs = null;
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
    return status;

}

/*public static String validateAppKey(String userId, String AppKey) {
    String status = "false";
    int count = 0;
    ResultSet rs = null;
    JDBCConnection instance = null;
    PreparedStatement pstmntAppKeyValidate = null;
    try {
        instance = new JDBCConnection();
    } catch (SQLException e1) {
        // TODO Auto-generated catch block
        e1.printStackTrace();
    }
     Connection con = instance.getConnection();

    String query = "select count(1) from users_login_details where uld_entity_id = ? and uld_app_key = ? and trunc(uld_current_login_time) >= trunc(sysdate) and uld_invalid_login_flag in ('Y', 'C')";
    try {
         pstmntAppKeyValidate = con.prepareStatement(query);

        pstmntAppKeyValidate.setString(1, userId.trim());
        pstmntAppKeyValidate.setString(2, AppKey.trim());
        rs = pstmntAppKeyValidate.executeQuery();
        if (rs != null) {
            while (rs.next()) {
                count = rs.getInt(1);
            }
        }
        if (count > 0) {
            status = "true";
        }
    } catch (SQLException e) {
        status = "ERROR";
        System.out.println("***********************Exception is*******" + e.getMessage());
        e.printStackTrace();
    } finally {
        try {
            if(rs != null) {
                rs.close();
            }
            if(pstmntAppKeyValidate != null) {
                pstmntAppKeyValidate.close();
            }
            if(con != null) {
                con.close();
            }   
        }catch(Exception e) {
            e.printStackTrace();
        }

    }

    return status;
}*/

private static synchronized void checkConnection() {
    try {
        if ((System.currentTimeMillis() - lastAccess) >= 120000) {
            stmt = con.createStatement();
        }
    } catch (Exception g) {
        try {
            // instance = new JDBCConnection();
            con = instance.getConnection();
            pstmntAppKeyValidate = con.prepareStatement(strappKeyValidate);
            // lastAccess = System.currentTimeMillis();
        } catch (Exception m) {
        }
    }
    lastAccess = System.currentTimeMillis();
}


 }

Я получаю сообщение о зависании темы на производстве, когда было несколько пользователей. хорошо ли сделать синхронизированный метод validateAppKey вместо метода экземпляра?

Ответы [ 2 ]

1 голос
/ 12 октября 2019

Удалите статический метод validateAppKey, поскольку он вызывает блокировку на уровне класса.

0 голосов
/ 14 октября 2019

Эту проблему можно решить с помощью безопасности потока (т. Е. Синхронизированного метода)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...