RFR 9: 8087286 Need a way to handle control-C and possibly some other signals

Roger Riggs Roger.Riggs at Oracle.com
Tue Feb 2 23:04:22 UTC 2016


Hi Stuart,


 From your later email; all threads to invoke signal handlers are 
non-daemon threads
and are expected to return from the handler and terminate.  Yes, worth a 
spec.


On 2/2/2016 5:08 PM, Stuart Marks wrote:
> Hi Roger,
>
> It will be good to get this into the JDK. Lots of people have been 
> asking for this.
>
> I have a few comments on the API.
>
> 1) Is there a way to query the set of signals supported? This might be 
> a Set<String> returned by a static method, for example. I agree that 
> signal strings outside this set shouldn't be supported.
Remember;  "as simple and small as possible"...

If you want to use a signal try it; if it throws an exception; then its 
not available.
>
> 2) The Signal class spec mentions SIGINT, SIGHUP, and SIGTERM 
> explicitly. Are these required to be implemented on all platforms, or 
> just on "unix-like" platforms, are they just examples? What signals 
> are available on Windows?
It also says, everything is OS and implementation dependent.  So no not 
required;  SIGHUP is not supported on windows.
>
> 3) raise() is spec'd to throw an exception if there's no handler 
> registered. But wouldn't it make sense to allow it if the default 
> handler is registered?
The default handlers are all known to shutdown;  if you want to exit the 
Java runtime, call exit() or shutdown.
The requirement to have a registered handler is a bit of caution to keep 
the behavior more stable.
>
> 4) In an earlier message you said that the Signal object is a 
> capability, so the security check is on getting a reference. It seems 
> to me that setting a handler is in a different category from raising a 
> signal; this suggests to me that using the same object as a capability 
> for both should be rethought.
That suggests there should be two permissions and there is a different 
security context expected for handlers that throwers.
I think that makes it more complicated than necessary.  In most OS, 
there is no difference in the protections for throwing and catching 
exceptions.
>
> 5) I don't understand the asymmetry between register() and 
> unregister(). Your earlier exchanges with Chris and with Gerard 
> touched on this, specifically, the requirement that the caller pass 
> unregister() a reference to the old handler in order for 
> unregistration to work. You had said this was safer, if there are 
> uncoordinated pieces of code attempting to set/unset signal handlers.
>
> It looks to me like this API is really about maintaining process 
> global state consisting of a single handler -- user-specified or 
> default -- for each supported signal. (I agree that it shouldn't try 
> to have a stack or a chain of handlers.) There are a few other things 
> that are global like this, such as the security manager and policy, 
> System.setIn/Out/Err, and so forth. As such, uncoordinated access to 
> the signal API is pretty much broken no matter what. Thus I don't 
> think it makes sense to have a CAS-like protocol for unregistering a 
> handler, to protect against the case where "somebody else" might have 
> registered a handler different from yours.
>
> Something like this might make sense:
>
>     void register(Consumer<Signal> handler);
>     void unregister();
yes, that would be simpler;  if there is more than one Signal handler in 
the process; its pretty close to undefined
about the interactions.
>
> The register() call would be pretty much as currently specified; the 
> unregister() call would restore the default handler. Alternatively, 
> register(null) could be used instead of unregister(), but this is 
> quite minor.
Great, we're down to:  of(), register(h), unregister(), name(), 
number(), equals(), hashcode(), toString().

I'll take another pass at tomorrow.


Thanks, Roger

>
> Thanks,
>
> s'marks
>
>
>
>
>
> On 2/1/16 8:02 AM, Roger Riggs wrote:
>> Please review an API addition to handle signals such as SIGINT, 
>> SIGHUP, and
>> SIGTERM.
>> This JEP 260 motivated alternative to sun.misc.Signal supports the 
>> use case for
>> interactive applications that need to handle Control-C and other 
>> signals.
>>
>> The new java.util.Signal class provides a settable primary signal 
>> handler and a
>> default
>> signal handler.  The primary signal handler can be unregistered and 
>> handling is
>> restored
>> to the default signal handler.  System initialization registers 
>> default signal
>> handlers
>> to terminate on SIGINT, SIGHUP, and SIGTERM.  Use of the Signal API 
>> requires
>> a permission if a SecurityManager is set.
>>
>> The sun.misc.Signal implementation is modified to be layered on a common
>> thread and dispatch mechanism. The VM handling of native signals is 
>> not affected.
>> The command option to reduce signal use by the runtime with -Xrs is 
>> unmodified.
>>
>> The changes to hotspot are minimal to rename the hardcoded callback 
>> to the Java
>> Signal dispatcher.
>>
>> Please review and comment on the API and implementation.
>>
>> javadoc:
>>    http://cr.openjdk.java.net/~rriggs/signal-doc/
>>
>> Webrev:
>> jdk:  http://cr.openjdk.java.net/~rriggs/webrev-signal-8087286/
>> hotspot: http://cr.openjdk.java.net/~rriggs/webrev-hs-signal-8087286/
>>
>> Issue:
>>     https://bugs.openjdk.java.net/browse/JDK-8087286
>>
>> JEP 260:
>>    https://bugs.openjdk.java.net/browse/JDK-8132928
>>
>> Thanks, Roger
>>
>>




More information about the core-libs-dev mailing list