Cloudera CDH/CDP 및 Hadoop EcoSystem, Semantic IoT등의 개발/운영 기술을 정리합니다. gooper@gooper.com로 문의 주세요.
build.sbt파일에 아래의 구문을 넣는다(sbt-assembly를 사용하는 경우만 가능함)
assemblyExcludedJars in assembly := { val cp = (fullClasspath in assembly).value cp filter {_.data.getName == "slf4j-api-1.7.20.jar"} }
*참고 : https://github.com/sbt/sbt-assembly#merge-strategy
-------------------------오류내용 -------------------------
C:devworkspacesda-commonbuildlibssda-common-2.0.0-SNAPSHOT.jar:org/slf4j/helpers/SubstituteLoggerFactory.class
C:Usersgooper.ivy2cacheorg.slf4jslf4j-apijarsslf4j-api-1.7.20.jar:org/slf4j/helpers/SubstituteLoggerFactory.class
at sbtassembly.Assembly$.applyStrategies(Assembly.scala:140)
at sbtassembly.Assembly$.x$1$lzycompute$1(Assembly.scala:25)
at sbtassembly.Assembly$.x$1$1(Assembly.scala:23)
at sbtassembly.Assembly$.stratMapping$lzycompute$1(Assembly.scala:23)
at sbtassembly.Assembly$.stratMapping$1(Assembly.scala:23)
at sbtassembly.Assembly$.inputs$lzycompute$1(Assembly.scala:67)
at sbtassembly.Assembly$.inputs$1(Assembly.scala:57)
at sbtassembly.Assembly$.apply(Assembly.scala:83)
at sbtassembly.Assembly$$anonfun$assemblyTask$1.apply(Assembly.scala:240)
at sbtassembly.Assembly$$anonfun$assemblyTask$1.apply(Assembly.scala:237)
at scala.Function1$$anonfun$compose$1.apply(Function1.scala:47)
at sbt.$tilde$greater$$anonfun$$u2219$1.apply(TypeFunctions.scala:40)
at sbt.std.Transform$$anon$4.work(System.scala:63)
at sbt.Execute$$anonfun$submit$1$$anonfun$apply$1.apply(Execute.scala:228)
at sbt.Execute$$anonfun$submit$1$$anonfun$apply$1.apply(Execute.scala:228)
at sbt.ErrorHandling$.wideConvert(ErrorHandling.scala:17)
at sbt.Execute.work(Execute.scala:237)
at sbt.Execute$$anonfun$submit$1.apply(Execute.scala:228)
at sbt.Execute$$anonfun$submit$1.apply(Execute.scala:228)
at sbt.ConcurrentRestrictions$$anon$4$$anonfun$1.apply(ConcurrentRestrictions.scala:159)
at sbt.CompletionService$$anon$2.call(CompletionService.scala:28)
at java.util.concurrent.FutureTask.run(FutureTask.java:266)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
at java.util.concurrent.FutureTask.run(FutureTask.java:266)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at java.lang.Thread.run(Thread.java:745)
[error] (*:assembly) deduplicate: different file contents found in the following:
[error] C:devworkspacesda-commonbuildlibssda-common-2.0.0-SNAPSHOT.jar:org/slf4j/LoggerFactory.class
[error] C:Usersgooper.ivy2cacheorg.slf4jslf4j-apijarsslf4j-api-1.7.20.jar:org/slf4j/LoggerFactory.class
[error] deduplicate: different file contents found in the following:
[error] C:devworkspacesda-commonbuildlibssda-common-2.0.0-SNAPSHOT.jar:org/slf4j/helpers/BasicMDCAdapter.class
[error] C:Usersgooper.ivy2cacheorg.slf4jslf4j-apijarsslf4j-api-1.7.20.jar:org/slf4j/helpers/BasicMDCAdapter.class
[error] deduplicate: different file contents found in the following:
[error] C:devworkspacesda-commonbuildlibssda-common-2.0.0-SNAPSHOT.jar:org/slf4j/helpers/BasicMarker.class
[error] C:Usersgooper.ivy2cacheorg.slf4jslf4j-apijarsslf4j-api-1.7.20.jar:org/slf4j/helpers/BasicMarker.class
[error] deduplicate: different file contents found in the following:
[error] C:devworkspacesda-commonbuildlibssda-common-2.0.0-SNAPSHOT.jar:org/slf4j/helpers/SubstituteLogger.class
[error] C:Usersgooper.ivy2cacheorg.slf4jslf4j-apijarsslf4j-api-1.7.20.jar:org/slf4j/helpers/SubstituteLogger.class
[error] deduplicate: different file contents found in the following:
[error] C:devworkspacesda-commonbuildlibssda-common-2.0.0-SNAPSHOT.jar:org/slf4j/helpers/SubstituteLoggerFactory.class
[error] C:Usersgooper.ivy2cacheorg.slf4jslf4j-apijarsslf4j-api-1.7.20.jar:org/slf4j/helpers/SubstituteLoggerFactory.class
[error] Total time: 34 s, completed 2016. 8. 11 오후 1:51:31
댓글 0
번호 | 제목 | 날짜 | 조회 수 |
---|---|---|---|
» | 여러가지 방법으로 특정 jar파일을 exclude하지 못하는 경우 해당 jar파일을 제외시키는 방법 | 2016.08.11 | 300 |
14 | jar파일의 dependency찾는 프로그램 | 2016.08.11 | 402 |
13 | compile할때와 exclude할때 대상을 표현하는 명칭이 다르므로 주의할것 | 2016.08.10 | 1049 |
12 | 외부 jar파일을 만들려고하는jar파일의 package로 포함하는 방법 | 2016.08.10 | 176 |
11 | 로컬의 라이브러리파일들을 dependency에 포함시키는 방법 | 2016.08.09 | 646 |
10 | gradle을 이용하여 jar파일 생성시 provided속성을 지정할 수 있게 설정하는 방법 | 2016.08.09 | 648 |
9 | [SBT] assembly시 "[error] deduplicate: different file contents found in the following:"오류 발생시 조치사항 | 2016.08.04 | 1154 |
8 | [SBT] SBT 사용법 정리(링크) | 2016.08.04 | 1072 |
7 | [SBT] project.sbt에 libraryDependencies에 필요한 jar를 지정했으나 sbt compile할때 클래스를 못찾는 오류가 발생했을때 조치사항 | 2016.08.03 | 1263 |
6 | build할때 unmappable character for encoding MS949 에러 발생시 조치사항 | 2016.08.03 | 933 |
5 | [sbt] sbt-assembly를 이용하여 실행에 필요한 모든 j라이브러리를 포함한 fat jar파일 만들기 | 2016.07.11 | 2214 |
4 | [sbt] sbt 0.13.11 를 windows에 설치하고 scala프로그램을 compile해서 jar파일 만들기 | 2016.07.11 | 725 |
3 | centos에 sbt 0.13.5 설치 | 2016.05.30 | 817 |
2 | git설명 한글판 | 2015.12.09 | 533 |
1 | pom.xml에서 build.gradle로 변환 | 2015.09.14 | 697 |