Caused by: javax.security.auth.login.LoginException: unable to find LoginModule class: com.ibm.secur

本文介绍了解决Hadoop在使用IBM专有JDK时出现的LoginModule兼容性问题的方法。通过替换特定类文件并修改配置,使得Hadoop能够正常运行。

首先说下出现这个错误的环境配置吧:aix小型机安装tomcat,(配有ibm专有的jdk,1.6),hadoop(1.0.4)集群,linux:redhat,jdk是oracle的1.6。出现上面的错误信息;上网查了下,发现也有相同的错误出现:http://mail-archives.apache.org/mod_mbox/hadoop-user/201208.mbox/%3COF2E935E40.56BFE6E6-ON85257A64.004BB391-85257A64.004BF20E@us.ibm.com%3E,上面说是大概意思是IBM的jdk有特殊的LoginModules,可能和hadoop的不匹配,可以看到下面的

UserGroupInformation.java中的源代码:

 private static String getOSLoginModuleName() {
  262     if (System.getProperty("java.vendor").contains("IBM")) {
  263       return windows ? "com.ibm.security.auth.module.NTLoginModule"
  264        : "com.ibm.security.auth.module.LinuxLoginModule";    
  265     } else {
  266       return windows ? "com.sun.security.auth.module.NTLoginModule"
  267         : "com.sun.security.auth.module.UnixLoginModule";
  268     }
  269   }
  270 
private static Class<? extends Principal> getOsPrincipalClass() {
  274     ClassLoader cl = ClassLoader.getSystemClassLoader();
  275     try {
  276       if (System.getProperty("java.vendor").contains("IBM")) {
  277         if (windows) {
  278           return (Class<? extends Principal>)
  279             cl.loadClass("com.ibm.security.auth.UsernamePrincipal");
  280         } else {
  281           return (Class<? extends Principal>)
  282             (System.getProperty("os.arch").contains("64")
  283              ? cl.loadClass("com.ibm.security.auth.UsernamePrincipal")
  284              : cl.loadClass("com.ibm.security.auth.LinuxPrincipal"));
  285         }
  286       } else {
  287         return (Class<? extends Principal>) (windows
  288            ? cl.loadClass("com.sun.security.auth.NTUserPrincipal")
  289            : cl.loadClass("com.sun.security.auth.UnixPrincipal"));
  290       }
  291     } catch (ClassNotFoundException e) {
  292       LOG.error("Unable to find JAAS classes:" + e.getMessage());
  293     }
  294     return null;
  295   }


上面红色字体的部分在ibm的jdk里面并没有发现,所以直接报错说那个LinuxLoginModule找不到,那么怎么办呢?可以考虑下把这两个类替换掉:
在ibm jdk的api中:

可以看到这两个类:


直接用上面的两个类去替换前面红色部分的类就可以了。


替换完成之后要怎么做呢?

1.使用linux系统,在eclipse的java工程中导入hadoop的所有包,并把上面的文件放入src下面,直接保存;

2. 打开bin下面的文件,查找到 UserLoginInformation开头的类,使用linux系统的工具把hadoop-core-1.0.4.jar里面相应的类替换掉;

3. 把hadoop集群所有的hadoop-core-1.0.4.jar用上面得到的替换掉;

做完上面的,基本应该就ok了,这样再测试一下,看是否ok。

最后,声明一下,这个还没有经过博主测试,只是一个想法。



分享,快乐,成长


转载请注明出处:http://blog.youkuaiyun.com/fansy1990


<think>好的,我现在要解决用户的问题:Java中出现java.lang.ClassNotFoundException: javax.annotation.security.DeclareRoles的异常。首先,我需要理解这个问题的原因,然后找到合适的解决方案。 首先,用户提到的异常是找不到,这说明在运行时,JVM无法加载指定的名是javax.annotation.security.DeclareRoles,这属于Java的注解相关。根据以往的知识,这问题通常是因为缺少相关的依赖库,或者模块路径配置不正确,尤其是在使用Java 9及以上版本时,模块系统(JPMS)可能导致某些原本在早期版本中默认包含的被移除或需要显式引入。 接下来,我需要回忆相关的解决方案。例如,之前处理过似的ClassNotFoundException,比如javax.xml.bind相关的缺失,解决方法通常是添加JAXB API的依赖,因为从Java 9开始,这些被移出了Java SE的标准库,需要手动引入。似地,javax.annotation包中的可能也被移到了其他模块或需要额外依赖。 查阅用户提供的引用内容,特别是引用[3]和引用[4],都是关于处理JAXB相关找不到的问题,解决方法是添加jaxb-api等依赖。虽然问题不同,但思路相似,即添加缺失的依赖库。 接下来,我需要确认javax.annotation.security.DeclareRoles属于哪个库。根据Java EE的历史,这些注解通常包含在Java EE的API库中,如javax.annotation-api。在Java EE转向Jakarta EE之后,部分包名发生了变化,但用户的问题中的仍然属于javax.annotation包,因此可能需要添加旧的javax.annotation-api依赖。 检查Maven仓库,可以找到javax.annotation的依赖项,例如: ```xml <dependency> <groupId>javax.annotation</groupId> <artifactId>javax.annotation-api</artifactId> <version>1.3.2</version> </dependency> ``` 添加这个依赖应该能解决找不到的问题。此外,如果用户使用的是Java 9+,并且项目使用模块化系统(module-info.java),需要确认模块是否打开了必要的导出,或者是否添加了requires javax.annotation.api。 另外,可能的其他情况包括依赖冲突或版本不兼容,但根据常见的解决方式,首先应该尝试添加显式依赖。 总结解决方案的步骤应该是: 1. 添加javax.annotation-api依赖。 2. 确保构建工具正确引入依赖。 3. 检查模块配置(如果使用模块化系统)。 4. 清理并重新构建项目。 最后,生成相关问题,比如其他注解缺失的问题,或者模块化配置的问题,以便用户进一步了解可能遇到的似情况。</think>### 解决方案 出现`java.lang.ClassNotFoundException: javax.annotation.security.DeclareRoles`的原因是Java项目缺少包含该的依赖库。`DeclareRoles`属于Java EE安全注解的一部分,在Java 9及以上版本中,部分Java EE模块被移除,需手动添加依赖。 #### 具体步骤: 1. **添加依赖** 在Maven项目中,添加`javax.annotation-api`依赖(包含`javax.annotation.security`包): ```xml <dependency> <groupId>javax.annotation</groupId> <artifactId>javax.annotation-api</artifactId> <version>1.3.2</version> </dependency> ``` Gradle项目则添加: ```groovy implementation 'javax.annotation:javax.annotation-api:1.3.2' ``` 2. **模块化项目检查**(Java 9+) 若项目使用`module-info.java`,需添加模块声明: ```java requires java.annotation; ``` 3. **清理并重新构建** 执行`mvn clean install`或Gradle的`clean build`,确保依赖生效。 #### 补充说明 - 该通常用于声明EJB或Web应用的角色权限注解(如`@DeclareRoles`),常见于Java EE/Jakarta EE项目[^1][^3]。 - 若使用Spring Boot,需排除冲突依赖或调整版本兼容性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值