Uploaded image for project: 'JDK'
  1. JDK
  2. JDK-8305763

Parsing a URI with an underscore goes through a silent exception, negatively impacting performance

    XMLWordPrintable

Details

    • b26
    • Verified

    Backports

      Description

        Using underscores in the name for a URI triggers a silent exception in the java standard library, which consumes 5% of the CPU.

        Exception:
        java.net.URISyntaxException: Illegal character in hostname at index N: xyz1_abcd.com
            at java.base/java.net.URI$Parser.fail(URI.java:2943)
            at java.base/java.net.URI$Parser.parseHostname(URI.java:3487)
            at java.base/java.net.URI$Parser.parseServer(URI.java:3329)

        This exception is silent and does not produce any messages, except for ODP profiler, there is no other evidence that it’s happening (the stack trace above was printed after changes to Java library). The reason for this is because of how the URI creation is implemented in the java.net.URI class (link here: https://github.com/openjdk/jdk/blob/master/src/java.base/share/classes/java/net/URI.java#L3527). There are two paths for creating a valid URI, and one of them goes through an exception.

        We can see that if parseServer fails, there is still a way the authority gets assigned and we don’t throw an exception from the method. This means, not being able to parse the server is ok and the exception is silenced. In our case, the server parsing fails because we find an illegal character, as only alphanumeric and dash characters are allowed.

        Created on behalf of Dhamoder Nalla @ Microsoft.

        Attachments

          Issue Links

            Activity

              People

                dhanalla Dhamoder Nalla
                cslucas Cesar Soares
                Votes:
                0 Vote for this issue
                Watchers:
                6 Start watching this issue

                Dates

                  Created:
                  Updated:
                  Resolved: