패턴 "com.sun.jersey"를 shadedPattern "route66.com.sun.jersey"로 변경 중입니다. Maven 음영 플러그인 사용.Maven 음영이있는 저지 문제 : 음영 패턴 com.sun.jersey가 런타임 오류 "MultiPartReaderClientSide를 인스턴스화 할 수 없습니다."
내 코드에서 com.sun.jersey : jersey-client : 1.19.3을 사용하고 있고 hadoop에서 실행 중입니다. 그러나 hadoop 시스템의 lib jar에는 이전 버전의 jersey-client가 있습니다. 그래서 클래스 "com.sun.jersey"를 shadedPattern "route66.com.sun.jersey"로 변경하여 클래스가 예외를 찾지 못하도록해야했습니다. 심지어 적절히 변경 META_INF/서비스에서 확인 된 모든 클래스 이름이 존재하게 ServicesResourceTransformer을 사용하고
<execution>
<phase>package</phase>
<goals>
<goal>shade</goal>
</goals>
<configuration>
<shadedClassifierName>jar-with-dependencies</shadedClassifierName>
<minimizeJar>false</minimizeJar>
<keepDependenciesWithProvidedScope>false</keepDependenciesWithProvidedScope>
<shadedArtifactAttached>true</shadedArtifactAttached>
<relocations>
<relocation>
<pattern>com.sun.jersey</pattern>
<shadedPattern>route66.com.sun.jersey</shadedPattern>
</relocation>
</relocations>
<transformers>
<transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
<mainClass>com.yahoo.infox.route66.udf.ContentExtractorUdf</mainClass>
</transformer>
<transformer implementation="org.apache.maven.plugins.shade.resource.ServicesResourceTransformer"/>
</transformers>
<filters>
<filter>
<artifact>*:*</artifact>
<excludes>
<exclude>META-INF/*.SF</exclude>
<exclude>META-INF/*.DSA</exclude>
<exclude>META-INF/*.RSA</exclude>
</excludes>
</filter>
</filters>
</configuration>
</execution>
내 pom.xml 파일에 음영 코드는 다음과 같습니다.
에도이 후 나는 오류
SEVERE: The provider class, class route66.com.sun.jersey.multipart.impl.MultiPartReaderClientSide, could not be instantiated. Processing will continue but the class will not be utilized
java.lang.IllegalArgumentException: The MultiPartConfig instance we expected is not present. Have you registered the MultiPartConfigProvider class?
at route66.com.sun.jersey.multipart.impl.MultiPartReaderClientSide.<init>(MultiPartReaderClientSide.java:107)
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
at java.lang.reflect.Constructor.newInstance(Constructor.java:422)
at route66.com.sun.jersey.core.spi.component.ComponentConstructor._getInstance(ComponentConstructor.java:210)
at route66.com.sun.jersey.core.spi.component.ComponentConstructor.getInstance(ComponentConstructor.java:180)
at route66.com.sun.jersey.core.spi.component.ProviderFactory.__getComponentProvider(ProviderFactory.java:166)
at route66.com.sun.jersey.core.spi.component.ProviderFactory.getComponentProvider(ProviderFactory.java:137)
at route66.com.sun.jersey.core.spi.component.ProviderServices.getComponent(ProviderServices.java:283)
at route66.com.sun.jersey.core.spi.component.ProviderServices.getServices(ProviderServices.java:163)
at route66.com.sun.jersey.core.spi.factory.MessageBodyFactory.initReaders(MessageBodyFactory.java:176)
at route66.com.sun.jersey.core.spi.factory.MessageBodyFactory.init(MessageBodyFactory.java:162)
at route66.com.sun.jersey.api.client.Client.init(Client.java:343)
at route66.com.sun.jersey.api.client.Client.access$000(Client.java:119)
at route66.com.sun.jersey.api.client.Client$1.f(Client.java:192)
at route66.com.sun.jersey.api.client.Client$1.f(Client.java:188)
at route66.com.sun.jersey.spi.inject.Errors.processWithErrors(Errors.java:193)
at route66.com.sun.jersey.api.client.Client.<init>(Client.java:188)
at route66.com.sun.jersey.client.apache4.ApacheHttpClient4.<init>(ApacheHttpClient4.java:151)
at route66.com.sun.jersey.client.apache4.ApacheHttpClient4.<init>(ApacheHttpClient4.java:137)
at route66.com.sun.jersey.client.apache4.ApacheHttpClient4.create(ApacheHttpClient4.java:181)
여기에 잘못 어떤 생각을 무엇입니까?