-
Notifications
You must be signed in to change notification settings - Fork 39
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Lock Annotation #135
Comments
Should an XML equivalent also be defined? Or would that be left to the discretion of the specifications that choose to support it? For example, the EJB specification supports the following XML equivalent of the annotation in ejb-jar.xml:
Other specification that might want to use this annotation, and also have XML (like web.xml) may also desire to have an XML equivalent. If the annotation were the same as EJB, except with a different package... i.e. so only supporting 2 options:
With a default of WRITE, then perhaps the EJB spec could just allow applications to use the EJB version and new concurrency version interchangeably, then the above specific EJB XML could be left alone; no need to support two different ways in XML. I assume the EJB specification would be allowed to consume the new annotation and :
|
I haven't thought too much on how other specs consume the api. As a first instance I think it would be good for it to behave similar to the EJB annotations so that they can be used interchangeably with the advantage that it brings the equivalent EJB functionality to CDI beans. |
|
Let's not do that.
I don't think we should update EJB anymore, and just leave it be. At most we can define a kind of subset of EJB lite that consists of a set of annotations and extensions that lets EJB be implemented via CDI. This new annotation would then automatically apply to these 'EJB' beans (which are actually CDI beans then). See https://github.com/OmniFish-EE/omni-beans for a prototype of that idea. |
While omni-beans is an interesting exercise to demonstrate how closely CDI has come to replicating EJB functionality, any product that ships the EJB API classes would be required to pass the EJB TCK, and would therefore be an EJB implementation (even if that is backed by a CDI implementation under the covers). While we could update the EJB specification to define a new EJB Extra Lite, I think that would generally result in confusion with people wondering why they would want to use the new EJB Extra Lite vs just CDI. Or, are there still some remaining EJB exclusive capabilities that CDI really doesn't want? The purpose of my prior comment was to:
|
XML is really not needed. We should try not to bother with EJB/managed beans any more and just stick to CDI as much as possible. |
Managed beans has been removed from the platform, and CDI no longer depends on it. Still, there's a slew of remaining usage or references to this managed beans spec. For instance, Servlets are still managed beans, and REST still mentions managed beans in its spec document as well. |
I would like to propose still adding the Lock annotation for the 3.1 release. Don't go overboard yet with new features, but standardise what we done and understood through the years: |
Compatibility with existing code mostly. We're (seemingly?) not yet ready to drop EJB completely from the profiles, probably because of the large body of existing code.
Most things in EJB Lite could be done by features in other specs, though most would land in Concurrency I think, and a few in Security. Transactions has already absorbed the EJB features, and Interceptors have already been split out. I don't think CDI itself (CDI core) wants any of those higher level features. EJB Ultra / Extra Lite being based on CDI by spec definition, and not just as an implementation detail, might make a lot of things a lot easier and consistent in the platform, and make a level of legacy EJB support trivial to add to other platform such as Tomcat and Quarkus. |
My vote is that we are too late in the Jakarta EE 11 release cycle for it to be a good idea to add more features. I would recommend that we look into adding it early on in 3.2. The focus for 3.1 should be on getting an RC1 built and ensure we have at least one compatible implementation passing the TCK by the approaching deadline for component specification release review. It should be noted that if Open Liberty is needed to be the compatible implementation, our schedules are such that the RC1 will be needed by March 20 (around 1 week from now), in order to have a publicly available downloadable beta that can be used to pass the TCK by the component specification deadline. If Glassfish can be used instead, maybe their schedules will allow some additional weeks of time, but it seems to me like we are inviting unnecessary risk if we choose to add anything new at this point in the schedule. |
I was indeed thinking about whether it would be too late or not. Concurrency is a bit later in the release waves, so theoretically there is some time, but let's look at it for 3.2 then. |
Some additional background: |
The Quarkus design looks just about right, including basing it on |
@m-reza-rahman Instead of the simple timeout and throwing exceptions, I would like a configurable waiting mechanism and put the waiting instances into a queue or something. |
If we allow configuring a timeout, it would be optional to configure and would otherwise not time out. If we are basing this on ReadWriteLock and its provided implementation, ReentrantReadWriteLock, then the options for waiting mechanism are the Fair mode or Non-fair mode described in https://docs.oracle.com/en/java/javase/21/docs/api/java.base/java/util/concurrent/locks/ReentrantReadWriteLock.html . Is that what you had in mind when you say waiting mechanism? Or something different? |
I think this is more than fine. After all, the EJB locking functionality is pretty minimal. The Quarkus design also appears pretty simple. |
@njr-11 It looks good. I also hope there is a configurable |
Before we can even get to the topic of the possibility of applying a Lock across multiple servers like that, I would like to first figure out what the scope of a Lock is within a single server. The CDI beans with methods to which Lock is applied will themselves have a scope, such as |
The primary intended use was indeed just application scoped beans and singletons, essentially at the instance level. However, it would be good to keep it as broadly applicable as possible. I would suggest looking at what OmniServices and Quarkus is doing already (I think both just leave it open to users where they can apply @lock but provide some sort of guidance). Java/Jakarta EE typically has left cluster-level concerns to vendors. I would just stick to standardizing single server behavior. |
Thanks - that's good. It eliminates the ambiguity which would be the source of user errors related to scope if we limit to ApplicationScoped and Singleton, so I would definitely favor that. I would say wait until someone presents a good use case why they need Lock at another scope before opening it up further. |
That's fine. I would leave the possibility open for the future. There may be use cases I have not yet encountered. |
Create a Lock annotation that is functionally equivalent to the EJB Lock annotation but is more general in scope and therefore can be used more generally across the platform.
see https://docs.google.com/document/d/1uZFBoIujXCc-gQhCzh_ZdlKEsrsV0yVVIHzBTI3usF8/edit#heading=h.90fmh0qb8iq4 and https://jakarta.ee/specifications/platform/9/apidocs/jakarta/ejb/lock
The text was updated successfully, but these errors were encountered: