Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to prevent static methods being accessed by multiple Servlet Threads at once

here is the code I used for
deleting and renaming lots of file inside a directory.

protected void doPost(HttpServletRequest request, HttpServletResponse response)
  throws ServletException, IOException {
    response.setContentType("text/html; charset=UTF-8");
    response.setCharacterEncoding("UTF-8");
    RootSipResourceApp.updateRootFile(strDirectorypath, strappID, appNames);
    RequestDispatcher dispatcher = getServletContext().getRequestDispatcher("/index.jsp");
    dispatcher.forward(request, response);
}

public static void updateRootFile(String directorypath, String appID, String[] appName) 
  throws IOException {
    try {
        FileInputStream fin = null;
        File[] listOfFiles=fileLists(directorypath);
        for (int i = 0; i < listOfFiles.length; i++) {
            if (listOfFiles[i].isFile()) {
                rootFiles = listOfFiles[i].getName();
                if (rootFiles.endsWith(".properties") || rootFiles.endsWith(".PROPERTIES")) {
                    fin = new FileInputStream(directorypath + rootFiles);
                    properties.load(new InputStreamReader(fin, Charset.forName("UTF-8")));
                    String getAppName = properties.getProperty("root.label." + appID);
                    String propertyStr = "root.label." + appID;
                    saveFile(fin, getAppName, directorypath + rootFiles, propertyStr, appName[i]);
                }
            }
        }
    } catch (Exception e) {
        System.out.println("expn-" + e);
    }
}

public static void saveFile(FileInputStream fins, String oldAppName, String filePath, String propertyStr, String appName)
  throws IOException {
    String oldChar = propertyStr + "=" + oldAppName;
    String newChar = propertyStr + "=" + appName;
    String strLine;
    File f1 = new File(filePath);
    File f2 = new File("C:\\Equinox\\RootSipResource\\root\\root_created.properties");
    BufferedReader br = new BufferedReader(new InputStreamReader( new FileInputStream(f1), "UTF-8"));
    OutputStreamWriter out = new OutputStreamWriter(new FileOutputStream(f2), "UTF-8");
    while ((strLine = br.readLine()) != null) {
        strLine = strLine.replace(oldChar, newChar);
        out.write(strLine);
        out.write("\r\n");
    }
    out.flush();
    out.close();
    br.close();
    fins.close();
}
like image 640
divz Avatar asked Dec 27 '22 08:12

divz


2 Answers

Option 1:

change public static void updateRootFile to public static synchronized void updateRootFile

Option 2:

Add member to servlet class

private final static Object lock = new Object();

then wrap code inside updateRootFile method into

synchronized(lock) {
   ....
}

The difference is that Option 1 locks whole servlet class (all its synchronized methods) while Option 2 allow calling other servlet's methods from other threads except updateRootFile()

I believe one of the most definitive guides is here. Chapters 07 - 11 related to multithreaded code.

like image 196
andrey Avatar answered Jan 13 '23 15:01

andrey


you can use synchronized method for this. you can read about it here

public synchronized static void updateRootFile
like image 42
dku.rajkumar Avatar answered Jan 13 '23 13:01

dku.rajkumar