Невозможно создать fat jar с зависимостями с помощью maven и bitbucket

#maven #neo4j #bitbucket #bitbucket-pipelines

#maven #neo4j #bitbucket #bitbucket-конвейеры

Вопрос:

Что мы пытаемся сделать, мы пытаемся создать и развернуть файл fat jar (т. Е. Со всеми зависимостями), используя maven и scp, все через конвейер bitbucket, но мы получаем java.lang.Ошибка NoClassDefFoundError: okhttp3 / OkHttpClient.

Что должен делать базовый java-плагин Файл jar — это плагин для neo4j, который запускается при внесении изменений в базу данных. Плагин создает json с различными свойствами базы данных, подготавливает их в формате json и отправляет их в другую службу на том же сервере, используя OkHttpClient .

Это не проблема с разрешениями, мы запускаем скрипт в конвейере bitbucket, чтобы убедиться, что разрешения для файла jar верны.

Это не проблема с конечной точкой, мы успешно протестировали конечную точку, на которую ссылается OkHttpClient с помощью postman. Обе службы работают в одной и той же докер-сети, поэтому проблем с портом или HTTP-доступом быть не должно.

Вывод в журналах neo4j Мы перезапускаем neo4j после успешного развертывания и видим, что плагин был успешно зарегистрирован. Мы видим, что json подготовлен правильно, однако плагин завершается ошибкой со следующей ошибкой:

 2020-12-05 16:43:30.121 0000 INFO  [o.n.s.AbstractNeoWebServer$ServerComponentsLifecycleAdapter] Web server started.
2020-12-05 16:43:37.318 0000 INFO  [c.n.k.i.p.PageCacheWarmer] [london/a225b7b2] Page cache warmup completed. 104622 pages loaded. Duration: 10s 389ms. 10.07 pages/ms
2020-12-05 16:44:10.434 0000 INFO  [c.i.n.t.MyTransactionEventListener] [london/a225b7b2] createJsonBody: json: [{"id":15591428}]
2020-12-05 16:44:10.435 0000 INFO  [c.i.n.t.MyTransactionEventListener] [london/a225b7b2] createJsonBody: json: [{"id":15591428}]
2020-12-05 16:44:10.507 0000 INFO  [c.i.n.t.MyTransactionEventListener] [london/a225b7b2] sendJsonToApi: json: [{"id":15591428}]
2020-12-05 16:44:10.514 0000 ERROR [o.n.b.r.s.i.ErrorReporter] Client triggered an unexpected error [Neo.DatabaseError.General.UnknownError]: okhttp3/OkHttpClient, reference 9a0e0b9c-43ae-4ef5-8fe8-b2bdebba1fd6.
2020-12-05 16:44:10.514 0000 ERROR [o.n.b.r.s.i.ErrorReporter] Client triggered an unexpected error [Neo.DatabaseError.General.UnknownError]: okhttp3/OkHttpClient, reference 9a0e0b9c-43ae-4ef5-8fe8-b2bdebba1fd6.
**java.lang.NoClassDefFoundError: okhttp3/OkHttpClient**
    at com.ikwattro.neo4j.tx.MyTransactionEventListener.sendJsonToApi(MyTransactionEventListener.java:77) ~[neo4j-tx-listener-1.0-SNAPSHOT.jar:?]
    at com.ikwattro.neo4j.tx.MyTransactionEventListener.afterCommit(MyTransactionEventListener.java:40) ~[neo4j-tx-listener-1.0-SNAPSHOT.jar:?]
    at com.ikwattro.neo4j.tx.MyTransactionEventListener.afterCommit(MyTransactionEventListener.java:22) ~[neo4j-tx-listener-1.0-SNAPSHOT.jar:?]
    at org.neo4j.kernel.internal.event.DatabaseTransactionEventListeners.afterCommit(DatabaseTransactionEventListeners.java:99) ~[neo4j-kernel-4.2.0.jar:4.2.0]
    at org.neo4j.kernel.impl.api.KernelTransactionImplementation.afterCommit(KernelTransactionImplementation.java:978) ~[neo4j-kernel-4.2.0.jar:4.2.0]
 

Мы думаем, что проблема в том, что это, по-видимому, наводит нас на мысль, что jar не создан maven с зависимостями.

Мы не уверены в том, как решить проблему.

Дополнительная информация.

Обработчик файлов / транзакций Java выглядит следующим образом:

 public class MyTransactionEventListener extends TransactionEventListenerAdapter<Void> {

    private JSONArray json;
    private final LogService logsvc;

    public MyTransactionEventListener(GraphDatabaseService graphDatabaseService, LogService logsvc) {
        this.logsvc = logsvc;
    }

    @Override
    public Void beforeCommit(TransactionData data, Transaction transaction, GraphDatabaseService databaseService)
            throws Exception {
        createJsonBody(data);
        return null;
    }

    @Override
    public void afterCommit(TransactionData td, Void state, GraphDatabaseService db) {
        sendJsonToApi();
        resetJson();
    }

    @Override
    public void afterRollback(TransactionData data, Void state, GraphDatabaseService databaseService) {
        resetJson();
    }

    void resetJson() {
        this.json = null;
    }

    void createJsonBody(TransactionData td) {
        JSONArray json = new JSONArray();
        Iterable<Node> nodes = td.createdNodes();
        for (Node node : nodes) {
            JSONObject nodeJson = new JSONObject();
            long id = node.getId();
            try {
                nodeJson.put("id", id);
            } catch (JSONException e) {
                e.printStackTrace();
            }
            json.put(nodeJson);
        }

        logsvc.getUserLog(MyTransactionEventListener.class).info("createJsonBody: json: "   json.toString());
        this.json = json;
    }

    void sendJsonToApi() {
        logsvc.getUserLog(MyTransactionEventListener.class).info("sendJsonToApi: json: "   json.toString());
        if (this.json == null)
            return;

        try {
            OkHttpClient client = new OkHttpClient().newBuilder().build();
            RequestBody body = RequestBody.create(json.toString().getBytes("utf-8"));
            Request request = new Request.Builder().url(ENDPOINT).method("POST", body)
                    .addHeader("Content-Type", "application/json").build();

            Response response = client.newCall(request).execute();
            
            logsvc.getUserLog(MyTransactionEventListener.class).info("sendJsonToApi: data should be sent");
            logsvc.getUserLog(MyTransactionEventListener.class).info("sendJsonToApi: response: "   response.toString());
        } catch (Exception e) {
            logsvc.getUserLog(MyTransactionEventListener.class).error("sendJsonToApi: Exception: "   e.toString());
        }
    }
}
 

Конвейер выглядит следующим образом:

 image: maven:3.6.3

pipelines:
  default:
    - step:
        name: Build
        caches:
          - maven
        script: 
          - mvn clean compile assembly:single
          - mvn -B install
        artifacts:
          - 'target/neo4j-tx-listener-1.0-SNAPSHOT.jar'
  
    - step:
        name: Deploy-File
        deployment: production
        script:        
          - pipe: atlassian/scp-deploy:0.3.3
            variables:
              USER: $USER
              SERVER: $SERVER
              REMOTE_PATH: '/mnt/volume_lon1_01/neo4j/plugins'
              LOCAL_PATH: '${BITBUCKET_CLONE_DIR}/target/*'
          - pipe: atlassian/ssh-run:0.1.3
            variables:
              SSH_USER: $USER
              SERVER: $SERVER
              COMMAND: 'chmod 744 /mnt/volume_lon1_01/neo4j/plugins/neo4j-tx-listener-1.0-SNAPSHOT.jar'
 

Файл POM выглядит следующим образом:

 <?xml version="1.0" encoding="UTF-8"?>
<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/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.ikwattro</groupId>
    <artifactId>neo4j-tx-listener</artifactId>
    <version>1.0-SNAPSHOT</version>

    <properties>
        <neo4j.version>4.2.1</neo4j.version>
        <maven.compiler.source>11</maven.compiler.source>
        <maven.compiler.target>11</maven.compiler.target>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.neo4j</groupId>
            <artifactId>neo4j</artifactId>
            <version>${neo4j.version}</version>
        </dependency>
        <dependency>
            <groupId>org.neo4j</groupId>
            <artifactId>neo4j-kernel</artifactId>
            <version>${neo4j.version}</version>
        </dependency>
        <dependency>
            <groupId>org.neo4j</groupId>
            <artifactId>neo4j-logging</artifactId>
            <version>${neo4j.version}</version>
        </dependency>
        <dependency>
            <groupId>org.neo4j</groupId>
            <artifactId>neo4j-kernel</artifactId>
            <type>test-jar</type>
            <version>${neo4j.version}</version>
        </dependency>
        <dependency>
            <groupId>org.codehaus.jettison</groupId>
            <artifactId>jettison</artifactId>
            <version>1.4.1</version>
        </dependency>
        <dependency>
            <groupId>org.apache.httpcomponents</groupId>
            <artifactId>httpclient</artifactId>
            <version>4.5.13</version>
        </dependency>
        <dependency>
            <groupId>org.apache.httpcomponents</groupId>
            <artifactId>httpasyncclient</artifactId>
            <version>4.1.4</version>
        </dependency>
        <dependency>
            <groupId>org.apache.httpcomponents</groupId>
            <artifactId>httpmime</artifactId>
            <version>4.5.13</version>
        </dependency>
        <dependency>
            <groupId>com.squareup.okhttp3</groupId>
            <artifactId>okhttp</artifactId>
            <version>4.10.0-RC1</version>
        </dependency>
    </dependencies>

    <build>

        <plugins>
            <plugin>
                <artifactId>maven-compiler-plugin</artifactId>
                <configuration>
                    <source>11</source>
                    <target>11</target>
                </configuration>
            </plugin>

            <plugin>
                <artifactId>maven-assembly-plugin</artifactId>
                <version>3.3.0</version>
                <configuration>
                    <descriptorRefs>
                        <descriptorRef>jar-with-dependencies</descriptorRef>
                    </descriptorRefs>
                </configuration>
                <executions>
                    <execution>
                        <id>make-assembly</id>                        <!-- this is used for inheritance merges -->
                        <phase>package</phase>                        <!-- bind to the packaging phase -->
                        <goals>
                            <goal>single</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>



        </plugins>
    </build>


</project>
 

Любая помощь будет очень признательна.

Ответ №1:

Проблема решена.

Нам нужно было

  1. Скопируйте файл -jar-with-dependencies с шага сборки maven. Мы копировали тонкую банку.
  2. Измените файл POM следующим образом в соответствии с инструкциями neo4j для пользовательских плагинов с для зависимостей, уже предоставленных neo4j.