- 
        1. Re: Transparent deployment for Cluster and Standalone modesclemens_august Dec 1, 2016 3:48 PM (in response to clemens_august)I have found a viable solution: pack a minimal EAR with 1 session bean, which contains the injection as mentioned above: @Resource(lookup = "java:jboss/clustering/group/default") private Group group; This EAR is deployed only in a cluster installation. In all other places, the Group now can be fetched by a JNDI lookup. In a standalone installation the lookup will fail, and null can be returned. 
- 
        2. Re: Transparent deployment for Cluster and Standalone modespferraro Dec 1, 2016 10:58 PM (in response to clemens_august)clemens_august This works transparently in WF 10.1. 
- 
        3. Re: Transparent deployment for Cluster and Standalone modesclemens_august Dec 2, 2016 2:12 AM (in response to pferraro)Hello Paul Thank you very much for your answer. I would just like to make clear, what it is related to, because there was a reply by me already. So please allow me to follow up with 2 questions. - Do you mean, that as of WF10.1, I can inject an org.wildfly.clustering.group.Group as a @Resource into a session bean, and it will work in standalone as well, giving a null value for the Group?
- Further on, can you confirm, that in WF9.0.2 this behaves differently, i.e., deployment of such a bean will fail in standalone mode?
 I am asking, because for the time being we have to stay with WF9.0.2, and I would like to understand, whether I missed something by introducing the workaround described in my own reply. Best regards Clemens 
- 
        4. Re: Transparent deployment for Cluster and Standalone modespferraro Dec 2, 2016 7:50 AM (in response to clemens_august)clemens_august In WF10, all "default" clustering abstractions (including Group) will resolve to a local implementation when using a non-clustered server configuration. The local implementation of Group only has a membership of itself, and can never receive membership change events. I think this is more graceful than resolving to null. These local implementations existed in WF9, but they used a separate JNDI name, e.g. java:jboss/clustering/group/local So, the only way to make this transparent to your application was to externalize the absolute JNDI names to a deployment descriptor, and reference the clustering resources via their resource-ref names. 
- 
        5. Re: Transparent deployment for Cluster and Standalone modesgbrown1 Jun 18, 2019 3:22 PM (in response to pferraro)I realize this is an old question, but I'm still seeing something similar in Wildfly 17. I'm trying to inject a CommandDispatcherFactory as follows (based on the documentation in the High Availability Guide): @Resource(lookup = "java:jboss/clustering/dispatcher/default") private CommandDispatcherFactory factory; This works fine when running in a cluster, but generates the following exception when running standalone: Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException: No bean named 'java:jboss/clustering/dispatcher/default' available: not found in JNDI environment at org.springframework.jndi.support.SimpleJndiBeanFactory.getBean(SimpleJndiBeanFactory.java:122) at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.getResource(CommonAnnotationBeanPostProcessor.java:487) at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor$ResourceElement.getResourceToInject(CommonAnnotationBeanPostProcessor.java:636) at org.springframework.beans.factory.annotation.InjectionMetadata$InjectedElement.inject(InjectionMetadata.java:180) at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:90) at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.postProcessProperties(CommonAnnotationBeanPostProcessor.java:321) ... 175 more Injecting the default group works correctly in both configurations: @Resource(lookup = "java:jboss/clustering/group/default") private Group group; Any suggestions would be very much appreciated. Thanks, Greg Brown [edit] For what it's worth, looking up the local command dispatcher factory (java:jboss/clustering/dispatcher/local) throws a NamingException in standalone mode. 
- 
        6. Re: Transparent deployment for Cluster and Standalone modespferraro Jun 19, 2019 1:12 PM (in response to gbrown1)That's strange. We have an integration test that validate this exact scenario: wildfly/CommandDispatcherTestCase.java at master · wildfly/wildfly · GitHub Have you made any changes to the default standalone.xml? 
- 
        7. Re: Transparent deployment for Cluster and Standalone modespferraro Jun 19, 2019 1:21 PM (in response to gbrown1)It's also unclear to my why spring is resolving the @Resource annotation. This is the responsibility of the container (i.e. ee subsystem of WildFly). 
- 
        8. Re: Transparent deployment for Cluster and Standalone modesgbrown1 Jun 20, 2019 8:22 AM (in response to pferraro)Thanks for the response. We have modified standalone.xml as well as standalone-ha.xml. I looked at the diff for both but didn't see anything obvious. Is there something in particular I should be looking for? 
- 
        9. Re: Transparent deployment for Cluster and Standalone modesgbrown1 Jun 24, 2019 12:50 PM (in response to pferraro)Hi Paul, I just installed a fresh download of Wildfly 17 (no changes to the default config), and the "java:jboss/clustering/group/default" name doesn't appear to be registered in the JNDI tree. There's actually no entry for "clustering" at all. Greg 
- 
        10. Re: Transparent deployment for Cluster and Standalone modespferraro Jun 24, 2019 5:00 PM (in response to gbrown1)These are not static jndi bindings. The bindings are only resolvable if the deployment references them. Normally, a @Resource annotation is sufficient to establish a dependency on the given clustering service to the deployment. Can you paste the class that contains the @Resource annotation? 
- 
        11. Re: Transparent deployment for Cluster and Standalone modesgbrown1 Jun 25, 2019 8:47 AM (in response to pferraro)Hi Paul, I believe this is the relevant source code: @Service public class ClusterCallService { @Resource(lookup = "java:jboss/clustering/dispatcher/default") private CommandDispatcherFactory dispatcherFactory; private ClusterMembershipService clusterMembershipService = null; private CommandDispatcher<ClusterCallService> dispatcher = null; private Map<String, Object> handlers = new HashMap<>(); private static final Logger log = Logger.getLogger(ClusterCallService.class); @Autowired public void setClusterMembershipService(ClusterMembershipService clusterMembershipService) { this.clusterMembershipService = clusterMembershipService; } @PostConstruct protected void init() { log.info("Initializing cluster call service for " + clusterMembershipService.getNodeName()); dispatcher = dispatcherFactory.createCommandDispatcher(getClass().getName(), this); } @PreDestroy protected void dispose() { dispatcher.close(); } ... } Thanks! Greg 
- 
        12. Re: Transparent deployment for Cluster and Standalone modespferraro Jun 25, 2019 9:10 AM (in response to gbrown1)OK - I'm not sure how, but it looks to me like Spring is getting first crack at wiring you bean, which would explain the failure to resolve the jndi name (as well as the stacktrace). Try moving your CommandDispatcherFactory jndi binding to your deployment descriptor and reference it by name. e.g. <resource-ref> <res-ref-name>clustering/dispatcher</res-ref-name> <lookup-name>java:jboss/clustering/dispatcher/default</lookup-name> </resource-ref> This has the effect of both establishing the dependency on the CommandDispatcherFactory to your deployment, as well as create a static JNDI binding to your application's local namespace (i.e. java:comp/env/clustering/dispatcher) Then inject the CommandDispatcherFactory into your ClusterCallService bean via: @Resource(name = "clustering/dispatcher") private CommandDispatcherFactory dispatcherFactory; That should do the trick. 
- 
        13. Re: Transparent deployment for Cluster and Standalone modesjaikiran Jun 26, 2019 12:51 AM (in response to pferraro)pferraro wrote: OK - I'm not sure how, but it looks to me like Spring is getting first crack at wiring you bean, which would explain the failure to resolve the jndi name (as well as the stacktrace). Hi Paul, it looks like Greg is trying to inject this resource into a non-Java EE component: @Service public class ClusterCallService { @Resource(lookup = "java:jboss/clustering/dispatcher/default") private CommandDispatcherFactory dispatcherFactory; The @Service isn't a Java EE annotation. We (JBoss AS) used to support a @org.jboss.ejb3.annotation.Service during AS 5.x days but that support was removed starting AS7. So I don't think, it any of our Java EE or WildFly specific annotations. Greg, can you post the fully qualified name of this annotation that you are importing? I'm guessing it's some kind of a Spring annotation which marks this as a Spring bean, which then explains why Spring takes control over this injection and fails. 
- 
        14. Re: Transparent deployment for Cluster and Standalone modesgbrown1 Jun 26, 2019 7:59 AM (in response to jaikiran)It is a Spring annotation (org.springframework.stereotype.Service). However, I'm not sure that's the source of the problem. For example, this code works fine: @Service public class ClusterMembershipService { @Resource(lookup = "java:jboss/clustering/group/default") private Group group = null; ... } Greg 
 
     
     
    