[ 
https://issues.apache.org/jira/browse/KAFKA-6417?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=16415952#comment-16415952
 ] 

Chris Egerton commented on KAFKA-6417:
--------------------------------------

Just detecting a JAR file on a {{plugin.path}} directory isn't sufficient cause 
for alarm, since uber JARs are supported for plugins. An alternative could be 
to log a warning if a JAR file is detected in a {{plugin.path}} directory that 
doesn't contain any plugins. The warning could read something like "Archive 
file <archive file> in plugin path directory <plugin directory> does not 
contain any recognizable plugins and will not be used, even as a dependency for 
other plugins in the same directory."

Not completely in love with that wording/criteria; in the event that your 
{{plugin.path}} looks like {{/plugin/path,plugin/path/plugin1}}, non-plugin 
JARs found in the {{plugin/path/plugin1}} directory will then be incorrectly 
flagged even though they can be used as dependencies for {{plugin1}} since it 
is correctly formatted for use as a plugin in the {{/plugin/path}} directory.

[~cotedm], thoughts?

> plugin.path pointing at a plugin directory causes ClassNotFoundException
> ------------------------------------------------------------------------
>
>                 Key: KAFKA-6417
>                 URL: https://issues.apache.org/jira/browse/KAFKA-6417
>             Project: Kafka
>          Issue Type: Bug
>          Components: KafkaConnect
>    Affects Versions: 1.0.0
>            Reporter: Dustin Cote
>            Priority: Major
>
> When using the {{plugin.path}} configuration for the Connect workers, the 
> user is expected to specify a list containing the following per the docs:
> {quote}
> The list should consist of top level directories that include any combination 
> of: a) directories immediately containing jars with plugins and their 
> dependencies b) uber-jars with plugins and their dependencies c) directories 
> immediately containing the package directory structure of classes of plugins 
> and their dependencies 
> {quote}
> This means we would expect {{plugin.path=/usr/share/plugins}} for a structure 
> like {{/usr/share/plugins/myplugin1}},{{/usr/share/plugins/myplugin2}}, etc. 
> However if you specify {{plugin.path=/usr/share/plugins/myplugin1}} the 
> resulting behavior is that dependencies for {{myplugin1}} are not properly 
> loaded. This causes a {{ClassNotFoundException}} that is not intuitive to 
> debug. 



--
This message was sent by Atlassian JIRA
(v7.6.3#76005)

Reply via email to