0

我试图从“REALTIME事件处理HIFOOP,NIFI,KAFKA和风暴”构建“流模拟器”Hortonworks教程特别是从它的“实验室0:使用APACHE NIFI的入住,路线和土地实时活动“。Hortonworks教程生成失败,sun.security.provider.certpath.SunCertPathBuilderException

http://hortonworks.com/hadoop-tutorial/realtime-event-processing-nifi-kafka-storm/#stream-simulator-lab0

为了给你粗略的概念,这是什么,这里从Hortoworks页面描述:“流模拟器是一个轻量级的框架,其产生的卡车事件数据模拟器使用纽约市的卡车路线(KML ),其中定义了具有经度和纬度信息的驾驶员道路路径 模拟器使用Akka来简化并发性,消息传递和继承,它具有两个普通旧Java对象(PO​​JOS),一个用于卡车,另一个用于生成事件的驱动程序。

当我尝试建立模拟器直接从最新的Hortonworks沙盒(HDP 2.4)通过构建Maven的报告结束这个错误:

[ERROR] Failed to execute goal on project storm-kafka-0.8-plus: 
Could not resolve dependencies for project net.wurstmeister.storm: 
storm-kafka-0.8-plus:jar:0.4: Failed to collect dependencies at org.apache.storm:storm-core:jar: 
0.9.1-incubating -> clj-time:clj-time:jar:0.4.1: 
Failed to read artifact descriptor for clj-time:clj-time:jar:0.4.1: 
Could not transfer artifact clj-time:clj-time:pom:0.4.1 from/to clojars (https://clojars.org/repo/): 
sun.security.validator.ValidatorException: PKIX path building failed:  
sun.security.provider.certpath.SunCertPathBuilderException: 
unable to find valid certification path to requested target 

更详细的(Maven的-e)揭示了这些错误的详细信息:

... 
Caused by: sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target 
    at sun.security.validator.PKIXValidator.doBuild(PKIXValidator.java:385) 
    at sun.security.validator.PKIXValidator.engineValidate(PKIXValidator.java:292) 
    at sun.security.validator.Validator.validate(Validator.java:260) 
    at sun.security.ssl.X509TrustManagerImpl.validate(X509TrustManagerImpl.java:326) 
    at sun.security.ssl.X509TrustManagerImpl.checkTrusted(X509TrustManagerImpl.java:231) 
    at sun.security.ssl.X509TrustManagerImpl.checkServerTrusted(X509TrustManagerImpl.java:126) 
    at sun.security.ssl.ClientHandshaker.serverCertificate(ClientHandshaker.java:1454) 
    ... 74 more 
Caused by: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target 
    at sun.security.provider.certpath.SunCertPathBuilder.engineBuild(SunCertPathBuilder.java:196) 
    at java.security.cert.CertPathBuilder.build(CertPathBuilder.java:268) 
    at sun.security.validator.PKIXValidator.doBuild(PKIXValidator.java:380) 
    ... 80 more 

,这里是pom.xml中导致生成错误:

<project xmlns="http://maven.apache.org/POM/4.0.0" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 
         http://maven.apache.org/maven-v4_0_0.xsd"> 
<modelVersion>4.0.0</modelVersion> 

<groupId>com.hortonworks</groupId> 
<artifactId>storm-demo</artifactId> 
<packaging>pom</packaging> 
<version>1.0</version> 
<name>Storm Demo Parent Project</name> 

<modules> 
    <module>transport-domain</module> 
    <module>stream-simulator</module> 
    <module>storm-streaming</module> 
    <module>storm-demo-webapp</module> 
    <module>storm-kafkaplus</module> 
    <!-- <module>iot-integration-tester</module> --> 
</modules> 

<build> 
    <pluginManagement> 
     <plugins> 
      <plugin> 
       <groupId>org.apache.maven.plugins</groupId> 
       <artifactId>maven-compiler-plugin</artifactId> 
       <configuration> 
        <source>1.7</source> 
        <target>1.7</target> 
       </configuration> 
      </plugin> 
     </plugins> 
    </pluginManagement> 
</build> 

<dependencies> 
    <dependency> 
     <groupId>junit</groupId> 
     <artifactId>junit</artifactId> 
     <version>3.8.1</version> 
     <scope>test</scope> 
    </dependency> 
</dependencies> 

任何想法如何解决这个问题?请帮忙!

更新:接下来生成错误

固定证书有问题之后,我现在有一个错误:

[INFO] ------------------------------------------------------------------------ 
[INFO] Building Storm Demo Parent Project 1.0 
[INFO] ------------------------------------------------------------------------ 
Downloading: https://repo.maven.apache.org/maven2/org/apache/maven/plugins/maven-compiler-plugin/maven-metadata.xml 
[WARNING] Could not transfer metadata org.apache.maven.plugins:maven-compiler-plugin/maven-metadata.xml from/to central (https://repo.maven.apache.org/maven2): sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target 
[INFO] ------------------------------------------------------------------------ 
[INFO] Reactor Summary: 
[INFO] 
[INFO] transport-domain ................................... SUCCESS [ 2.233 s] 
[INFO] stream-simulator ................................... SUCCESS [ 3.694 s] 
[INFO] storm-streaming .................................... SUCCESS [01:13 min] 
[INFO] storm-demo-webapp .................................. SUCCESS [ 8.642 s] 
[INFO] storm-kafka-0.8-plus ............................... SUCCESS [ 17.440 s] 
[INFO] Storm Demo Parent Project .......................... FAILURE [ 0.171 s] 
[INFO] ------------------------------------------------------------------------ 
[INFO] BUILD FAILURE 
[INFO] ------------------------------------------------------------------------ 
[INFO] Total time: 01:45 min 
[INFO] Finished at: 2016-07-26T14:15:46+00:00 
[INFO] Final Memory: 119M/826M 
[INFO] ------------------------------------------------------------------------ 
[ERROR] Error resolving version for plugin 'org.apache.maven.plugins:maven-compiler-plugin' from the repositories [local (/root/.m2/repository), central (https://repo.maven.apache.org/maven2)]: Plugin not found in any plugin repository 

回答

0

你的Maven插件尝试连接到HTTPS远程仓库,即https://clojars.org/repo/

您可以使用此帖子的解决方案之一:

Problems using Maven and SSL behind proxy

我推荐的解决方案是:

(步骤可以浏览器之间会发生变化)

  • 使用浏览器(使用Chrome)去https://clojars.org/repo/
  • 点击锁图标,然后选择“详细信息“并单击”查看证书“
  • 转到”详细信息“选项卡并选择”复制到文件“
  • 选择类型“Base 64 X.509(。CER)”,并保存到某个地方
  • 现在打开一个命令提示符,然后键入(使用自己的路径):

    keytool -import -file C:\temp\mavenCert.cer -keystore C:\temp\mavenKeystore

  • 现在,您可以用参数

    -Djavax.net.ssl.trustStore=C:\temp\mavenKeystore再次运行该命令

  • linux下使用绝对路径

    现在

可以运行Maven作为构建:

/root/maven/bin/mvn clean package -Djavax.net.ssl.trustStore=C:\temp\mavenKeystore

+0

所做的一切都是按照你的建议,还是同样的错误。在linux上,当创建密钥库时,keytool让你为这个新的密钥库设置密码。可能这个密码是maven的问题吗? – dokondr

+1

如果您为keysotre创建了密码,那么比传递'mvn'命令多一个参数:'javax.net.ssl.keyStorePassword = yourpwd' -useful link:http://maven.apache.org/guides/mini/guide- repository-ssl.html - 并非所有属性都必须根据您的精确设置进行设置:商店类型可能保留为默认值,密码可能为空。 –

+0

密钥库密码不是问题。生成失败,因为我使用https://clojars.org/repo/的证书而不是https://clojars.org/repo/clj-time/。现在我有另一个maven错误:[错误]错误解决版本插件'org.apache.maven.plugins:maven-compiler-plugin'从存储库[本地(/root/.m2/repository),中央(https:/ /repo.maven.apache.org/maven2)]:在任何插件库中找不到插件。请在我更新的帖子中查看详情。 – dokondr