JAVA Specifying port with InetAddress

17,381

As I already mentioned in the comments, according to the Javadoc isReachable isn't implemented in a way that would allow you to control the selected port. Actually, if it is allowed to do so by system privileges it will just ping the machine (ICMP request).

Doing it manually (ie, using a socket) will certainly work and isn't really more complicated and/or longer:

SocketAddress sockaddr = new InetSocketAddress("cloudnine1999.no-ip.org", 43594);
// Create your socket
Socket socket = new Socket();
boolean online = true;
// Connect with 10 s timeout
try {
    socket.connect(sockaddr, 10000);
} catch (SocketTimeoutException stex) {
    // treating timeout errors separately from other io exceptions
    // may make sense
    online=false;
} catch (IOException iOException) {
    online = false;    
} finally {
    // As the close() operation can also throw an IOException
    // it must caught here
    try {
        socket.close();
    } catch (IOException ex) {
        // feel free to do something moderately useful here, eg log the event
    }

}
// Now, in your initial version all kinds of exceptions were swallowed by
// that "catch (Exception e)".  You also need to handle the IOException
// exec() could throw:
if(!online){
    System.out.println("OFFLINE: Restarting Server..");
    try {
        Runtime.getRuntime().exec("cmd /c start start.bat");
    } catch (IOException ex) {
         System.out.println("Restarting Server FAILED due to an exception " + ex.getMessage());
    }
}        

EDIT: forgot to handle IOException which also means the server isn't functioning, added

EDIT2: added the handling of the IOException that close() can throw

EDIT3: and exception handling for exec()

Share:
17,381
Admin
Author by

Admin

Updated on June 06, 2022

Comments

  • Admin
    Admin about 2 years

    I am using InetAddress to determine if my server is online.

    If the server is offline it will restart the server.

    This process loops every 5 minutes to check once again if the server is online.

    It works fine but now I need to figure out how to specify that I want to use port 43594 when checking the server status instead of the default port 80.

    Thanks! Here's my code:

    import java.net.InetAddress;
    public class Test extends Thread {
        public static void main(String args[]) {
            try {
                while (true) {
                    try
                    {
                        InetAddress address = InetAddress.getByName("cloudnine1999.no-ip.org");
                        boolean reachable = address.isReachable(10000);
                        if(reachable){
                            System.out.println("Online");
                        }
                        else{
                            System.out.println("Offline: Restarting Server...");
                            Runtime.getRuntime().exec("cmd /c start start.bat");
                        }
                    }
                    catch (Exception e)
                    {
                        e.printStackTrace();
                    }
                    Thread.sleep(5 * 60 * 1000);
                }
            }
            catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
    

    EDIT:

    Okay so I took someones advice and I made it into this. But now when I uncomment this line.. Runtime.getRuntime().exec("cmd /c start start.bat");

    I get this error..

    error: unreported exception IOException; must be caught or declared to be thrown

    This is my current code:

    import java.net.*;
    import java.io.*;
    public class Test extends Thread {
        public static void main(String args[]) {
            try {
                while (true) {
                    SocketAddress sockaddr = new InetSocketAddress("cloudnine1999.no-ip.org", 43594);
                    Socket socket = new Socket();
                    boolean online = true;
                    try {
                        socket.connect(sockaddr, 10000);
                    }
                    catch (IOException IOException) {
                        online = false;
            }
                    if(!online){
                System.out.println("OFFLINE: Restarting Server..");
                //Runtime.getRuntime().exec("cmd /c start start.bat");
            }
                    if(online){
                        System.out.println("ONLINE");
                    }
                    Thread.sleep(1 * 10000);
                }
            }
            catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
    
  • Admin
    Admin over 11 years
    Oh also the socket.close() had to be be removed it also gave me errors.
  • fvu
    fvu over 11 years
    No you should not remove it, I modified my code to show how to catch it locally. IMO throwing exceptions on close() operations is not the most useful feature in Java, but that's the way it is. Sorry for the confusion, the small testprogram I use to test such snippets already had a throws IOException which causedme to miss this issue.
  • fvu
    fvu over 11 years
    And an example of how to catch and handle the exception thrown by exec added - I think the program is almost complete now, don't you think? :-)
  • harschware
    harschware over 9 years
    almost... Unreachable catch block for SocketTimeoutException. It is already handled by the catch block for IOException :-)
  • fvu
    fvu over 9 years
    @harschware indeed, nice catch - code has been corrected.