【问题标题】:Sonar throws in headless environment on a MacSonar 在 Mac 上投入无头环境
【发布时间】:2013-07-30 20:25:05
【问题描述】:

我们正在尝试通过我们在 Mac OS X Mountain Lion 系统上构建的常规 ant 驱动的 Jenkins 运行声纳,但失败并出现以下异常:

.../main/custom_rules.xml:149:java.lang.InternalError:无法连接到窗口服务器 - 权限不足。 在 java.lang.ClassLoader$NativeLibrary.load(Native Method) 在 java.lang.ClassLoader.loadLibrary0(ClassLoader.java:1827) 在 java.lang.ClassLoader.loadLibrary(ClassLoader.java:1724) 在 java.lang.Runtime.loadLibrary0(Runtime.java:823) 在 java.lang.System.loadLibrary(System.java:1045) 在 sun.security.action.LoadLibraryAction.run(LoadLibraryAction.java:50) 在 java.security.AccessController.doPrivileged(本机方法) 在 java.awt.Toolkit.loadLibraries(Toolkit.java:1605) 在 java.awt.Toolkit.(Toolkit.java:1627) 在 sun.awt.AppContext$2.run(AppContext.java:240) 在 sun.awt.AppContext$2.run(AppContext.java:226) 在 java.security.AccessController.doPrivileged(本机方法) 在 sun.awt.AppContext.initMainAppContext(AppContext.java:226) 在 sun.awt.AppContext.access$200(AppContext.java:112) 在 sun.awt.AppContext$3.run(AppContext.java:306) 在 java.security.AccessController.doPrivileged(本机方法) 在 sun.awt.AppContext.getAppContext(AppContext.java:287) 在 com.sun.jmx.trace.Trace.out(Trace.java:180) 在 com.sun.jmx.trace.Trace.isSelected(Trace.java:88) 在 com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.isTraceOn(DefaultMBeanServerInterceptor.java:1830) 在 com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerDynamicMBean(DefaultMBeanServerInterceptor.java:929) 在 com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerObject(DefaultMBeanServerInterceptor.java:916) 在 com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerMBean(DefaultMBeanServerInterceptor.java:312) 在 com.sun.jmx.mbeanserver.JmxMBeanServer$2.run(JmxMBeanServer.java:1195) 在 java.security.AccessController.doPrivileged(本机方法) 在 com.sun.jmx.mbeanserver.JmxMBeanServer.initialize(JmxMBeanServer.java:1193) 在 com.sun.jmx.mbeanserver.JmxMBeanServer.(JmxMBeanServer.java:225) 在 com.sun.jmx.mbeanserver.JmxMBeanServer.(JmxMBeanServer.java:170) 在 com.sun.jmx.mbeanserver.JmxMBeanServer.newMBeanServer(JmxMBeanServer.java:1401) 在 javax.management.MBeanServerBuilder.newMBeanServer(MBeanServerBuilder.java:93) 在 javax.management.MBeanServerFactory.newMBeanServer(MBeanServerFactory.java:311) 在 javax.management.MBeanServerFactory.createMBeanServer(MBeanServerFactory.java:214) 在 javax.management.MBeanServerFactory.createMBeanServer(MBeanServerFactory.java:175) 在 sun.management.ManagementFactory.createPlatformMBeanServer(ManagementFactory.java:302) 在 java.lang.management.ManagementFactory.getPlatformMBeanServer(ManagementFactory.java:504) 在 com.persistit.Persistit.registerMBean(Persistit.java:758) 在 com.persistit.Persistit.registerMXBeans(Persistit.java:735) 在 com.persistit.Persistit.initializeManagement(Persistit.java:654) 在 com.persistit.Persistit.initialize(Persistit.java:434) 在 org.sonar.batch.index.Caches.initPersistit(Caches.java:70) 在 org.sonar.batch.index.Caches.(Caches.java:53) 在 sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 在 sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39) 在 sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27) 在 java.lang.reflect.Constructor.newInstance(Constructor.java:513) 在 org.picocontainer.injectors.AbstractInjector.newInstance(AbstractInjector.java:145) 在 org.picocontainer.injectors.ConstructorInjector$1.run(ConstructorInjector.java:342) 在 org.picocontainer.injectors.AbstractInjector$ThreadLocalCyclicDependencyGuard.observe(AbstractInjector.java:270) 在 org.picocontainer.injectors.ConstructorInjector.getComponentInstance(ConstructorInjector.java:364) 在 org.picocontainer.injectors.AbstractInjectionFactory$LifecycleAdapter.getComponentInstance(AbstractInjectionFactory.java:56) 在 org.picocontainer.behaviors.AbstractBehavior.getComponentInstance(AbstractBehavior.java:64) 在 org.picocontainer.behaviors.Stored.getComponentInstance(Stored.java:91) 在 org.picocontainer.DefaultPicoContainer.getInstance(DefaultPicoContainer.java:698) 在 org.picocontainer.DefaultPicoContainer.getComponent(DefaultPicoContainer.java:646) 在 org.picocontainer.DefaultPicoContainer.getComponent(DefaultPicoContainer.java:631) 在 org.picocontainer.parameters.BasicComponentParameter$1.resolveInstance(BasicComponentParameter.java:118) 在 org.picocontainer.parameters.ComponentParameter$1.resolveInstance(ComponentParameter.java:136) 在 org.picocontainer.injectors.SingleMemberInjector.getParameter(SingleMemberInjector.java:78) 在 org.picocontainer.injectors.ConstructorInjector$CtorAndAdapters.getParameterArguments(ConstructorInjector.java:309) 在 org.picocontainer.injectors.ConstructorInjector$1.run(ConstructorInjector.java:335) 在 org.picocontainer.injectors.AbstractInjector$ThreadLocalCyclicDependencyGuard.observe(AbstractInjector.java:270) 在 org.picocontainer.injectors.ConstructorInjector.getComponentInstance(ConstructorInjector.java:364) 在 org.picocontainer.injectors.AbstractInjectionFactory$LifecycleAdapter.getComponentInstance(AbstractInjectionFactory.java:56) 在 org.picocontainer.behaviors.AbstractBehavior.getComponentInstance(AbstractBehavior.java:64) 在 org.picocontainer.behaviors.Stored.getComponentInstance(Stored.java:91) 在 org.picocontainer.DefaultPicoContainer.getInstance(DefaultPicoContainer.java:698) 在 org.picocontainer.DefaultPicoContainer.getComponent(DefaultPicoContainer.java:646) 在 org.picocontainer.DefaultPicoContainer.getComponent(DefaultPicoContainer.java:631) 在 org.picocontainer.parameters.BasicComponentParameter$1.resolveInstance(BasicComponentParameter.java:118) 在 org.picocontainer.parameters.ComponentParameter$1.resolveInstance(ComponentParameter.java:136) 在 org.picocontainer.injectors.SingleMemberInjector.getParameter(SingleMemberInjector.java:78) 在 org.picocontainer.injectors.ConstructorInjector$CtorAndAdapters.getParameterArguments(ConstructorInjector.java:309) 在 org.picocontainer.injectors.ConstructorInjector$1.run(ConstructorInjector.java:335) 在 org.picocontainer.injectors.AbstractInjector$ThreadLocalCyclicDependencyGuard.observe(AbstractInjector.java:270) 在 org.picocontainer.injectors.ConstructorInjector.getComponentInstance(ConstructorInjector.java:364) 在 org.picocontainer.injectors.AbstractInjectionFactory$LifecycleAdapter.getComponentInstance(AbstractInjectionFactory.java:56) 在 org.picocontainer.behaviors.AbstractBehavior.getComponentInstance(AbstractBehavior.java:64) 在 org.picocontainer.behaviors.Stored.getComponentInstance(Stored.java:91) 在 org.picocontainer.DefaultPicoContainer.getInstance(DefaultPicoContainer.java:698) 在 org.picocontainer.DefaultPicoContainer.getComponent(DefaultPicoContainer.java:646) 在 org.picocontainer.DefaultPicoContainer.getComponent(DefaultPicoContainer.java:631) 在 org.picocontainer.parameters.BasicComponentParameter$1.resolveInstance(BasicComponentParameter.java:118) 在 org.picocontainer.parameters.ComponentParameter$1.resolveInstance(ComponentParameter.java:136) 在 org.picocontainer.injectors.SingleMemberInjector.getParameter(SingleMemberInjector.java:78) 在 org.picocontainer.injectors.ConstructorInjector$CtorAndAdapters.getParameterArguments(ConstructorInjector.java:309) 在 org.picocontainer.injectors.ConstructorInjector$1.run(ConstructorInjector.java:335) 在 org.picocontainer.injectors.AbstractInjector$ThreadLocalCyclicDependencyGuard.observe(AbstractInjector.java:270) 在 org.picocontainer.injectors.ConstructorInjector.getComponentInstance(ConstructorInjector.java:364) 在 org.picocontainer.injectors.AbstractInjectionFactory$LifecycleAdapter.getComponentInstance(AbstractInjectionFactory.java:56) 在 org.picocontainer.behaviors.AbstractBehavior.getComponentInstance(AbstractBehavior.java:64) 在 org.picocontainer.behaviors.Stored.getComponentInstance(Stored.java:91) 在 org.picocontainer.DefaultPicoContainer.instantiateComponentAsIsStartable(DefaultPicoContainer.java:1033) 在 org.picocontainer.DefaultPicoContainer.addAdapterIfStartable(DefaultPicoContainer.java:1025) 在 org.picocontainer.DefaultPicoContainer.startAdapters(DefaultPicoContainer.java:1002) 在 org.picocontainer.DefaultPicoContainer.start(DefaultPicoContainer.java:766) 在 org.sonar.api.platform.ComponentContainer.startComponents(ComponentContainer.java:87) 在 org.sonar.api.platform.ComponentContainer.execute(ComponentContainer.java:73) 在 org.sonar.batch.scan.ScanTask.scan(ScanTask.java:57) 在 org.sonar.batch.scan.ScanTask.execute(ScanTask.java:45) 在 org.sonar.batch.bootstrap.TaskContainer.doAfterStart(TaskContainer.java:80) 在 org.sonar.api.platform.ComponentContainer.startComponents(ComponentContainer.java:88) 在 org.sonar.api.platform.ComponentContainer.execute(ComponentContainer.java:73) 在 org.sonar.batch.bootstrap.BootstrapContainer.executeTask(BootstrapContainer.java:156) 在 org.sonar.batch.bootstrap.BootstrapContainer.doAfterStart(BootstrapContainer.java:144) 在 org.sonar.api.platform.ComponentContainer.startComponents(ComponentContainer.java:88) 在 org.sonar.api.platform.ComponentContainer.execute(ComponentContainer.java:73) 在 org.sonar.batch.bootstrapper.Batch.startBatch(Batch.java:86) 在 org.sonar.batch.bootstrapper.Batch.execute(Batch.java:68) 在 org.sonar.batch.Batch.execute(Batch.java:103) 在 org.sonar.ant.Launcher.execute(Launcher.java:78) 在 sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 在 sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 在 sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 在 java.lang.reflect.Method.invoke(Method.java:597) 在 org.sonar.ant.SonarTask.delegateExecution(SonarTask.java:244) 在 org.sonar.ant.SonarTask.execute(SonarTask.java:193) 在 org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291) 在 sun.reflect.GeneratedMethodAccessor4.invoke(未知来源) 在 sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 在 java.lang.reflect.Method.invoke(Method.java:597) 在 org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106) 在 org.apache.tools.ant.Task.perform(Task.java:348) 在 org.apache.tools.ant.Target.execute(Target.java:392) 在 org.apache.tools.ant.Target.performTasks(Target.java:413) 在 org.apache.tools.ant.Project.executeSortedTargets(Project.java:1399) 在 org.apache.tools.ant.Project.executeTarget(Project.java:1368) 在 org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41) 在 org.apache.tools.ant.Project.executeTargets(Project.java:1251) 在 org.apache.tools.ant.Main.runBuild(Main.java:811) 在 org.apache.tools.ant.Main.startAnt(Main.java:217) 在 org.apache.tools.ant.launch.Launcher.run(Launcher.java:280) 在 org.apache.tools.ant.launch.Launcher.main(Launcher.java:109)

显然我们希望无头运行 Jenkins 实例,因此设置了-Djava.awt.headless=true,这也反映在 Jenkins 显示给我们的系统信息中。尽管如此,它仍然无法正常工作,并且该异常相当不明确。

还有其他人偶然发现这个问题吗?

提前致谢, 托马斯。

【问题讨论】:

    标签: macos jenkins osx-mountain-lion sonarqube


    【解决方案1】:

    这是 Mac 上某些 Java 6 版本的错误(显然是 1.6.0_51)。这里有更多细节:

    解决方法是升级到 Java 7。

    问候

    【讨论】:

      【解决方案2】:

      我最近遇到了这个问题,偶然发现了这个问题。我想也许我会详细说明以防其他人遇到这个问题。我使用的解决方案是应用 Java 7。说“升级”有点含糊。您想要做的是向 Jenkins 添加 7。按照这些步骤,我能够成功构建我的项目:

      1. 转到 Oracle Java 页面并下载适用于 Mac 的 1.7_51 jdk
      2. 打开 dmg 并运行可执行文件。
      3. 在 Mac 上,这会将 JDK 安装到 /Library/Java/JavaVirtualMachines/jdk1.7.0_51.jdk/
      4. 在 Jenkins 中,转到“管理 Jenkins”>“配置系统”
      5. 在 JDK 标题下,单击 JDK Installations 按钮
      6. 在名称类型“JDK 1.7.0_51”下
      7. 对于 JAVA_HOME,键入“/Library/Java/JavaVirtualMachines/jdk1.7.0_51.jdk/Contents/Home/”
      8. 选择保存
      9. 转到您的项目并选择配置
      10. 您现在应该在页面顶部附近有一个 JDK 下拉菜单。
      11. 选择刚刚在“管理 Jenkins”下配置的 JDK
      12. 运行构建

      执行此操作后,我的构建成功运行,没有“无法连接到窗口服务器 - 权限不足错误”。

      【讨论】:

        【解决方案3】:

        使用 JDK 6 时的一种解决方法(当升级到 JDK 7 不是一个选项时)是在执行 sonar-runner 时添加 JVM 选项 -Djava.awt.headless=true

        我成功地使用了这个解决方法,例如具有 sonar-runner 构建步骤的 Jenkins 构建服务器。

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 2016-07-07
          • 2015-10-08
          • 2011-05-19
          • 1970-01-01
          • 1970-01-01
          • 2012-11-09
          • 1970-01-01
          相关资源
          最近更新 更多