Докер — проблема с java netty_tcnative

Я пытаюсь докеризовать 4 службы, и у меня возникла проблема с одной из служб. В частности, эта служба реализована как служба весенней загрузки и использует API видения Google. При создании изображений и запуске контейнеров все работает нормально, пока не дойдет до той части, где используется код API видения Google. Затем у меня возникают следующие ошибки времени выполнения при запуске контейнеров:

netty-tcnative unavailable (this may be normal)
java.lang.IllegalArgumentException: Failed to load any of the given libraries: [netty_tcnative_linux_x86_64, netty_tcnative_linux_x86_64_fedora, netty_tcnative_x86_64, netty_tcnative]
at io.grpc.netty.shaded.io.netty.util.internal.NativeLibraryLoader.loadFirstAvailable(NativeLibraryLoader.java:104) ~[grpc-netty-shaded-1.18.0.jar!/:1.18.0]
at io.grpc.netty.shaded.io.netty.handler.ssl.OpenSsl.loadTcNative(OpenSsl.java:526) ~[grpc-netty-shaded-1.18.0.jar!/:1.18.0]
at io.grpc.netty.shaded.io.netty.handler.ssl.OpenSsl.<clinit>(OpenSsl.java:93) ~[grpc-netty-shaded-1.18.0.jar!/:1.18.0]
at io.grpc.netty.shaded.io.grpc.netty.GrpcSslContexts.defaultSslProvider(GrpcSslContexts.java:244) [grpc-netty-shaded-1.18.0.jar!/:1.18.0]
at io.grpc.netty.shaded.io.grpc.netty.GrpcSslContexts.configure(GrpcSslContexts.java:171) [grpc-netty-shaded-1.18.0.jar!/:1.18.0]
at io.grpc.netty.shaded.io.grpc.netty.GrpcSslContexts.forClient(GrpcSslContexts.java:120) [grpc-netty-shaded-1.18.0.jar!/:1.18.0]
at io.grpc.netty.shaded.io.grpc.netty.NettyChannelBuilder.buildTransportFactory(NettyChannelBuilder.java:385) [grpc-netty-shaded-1.18.0.jar!/:1.18.0]
at io.grpc.internal.AbstractManagedChannelImplBuilder.build(AbstractManagedChannelImplBuilder.java:435) [grpc-core-1.18.0.jar!/:1.18.0]
at com.google.api.gax.grpc.InstantiatingGrpcChannelProvider.createSingleChannel(InstantiatingGrpcChannelProvider.java:223) [gax-grpc-1.42.0.jar!/:1.42.0]
at com.google.api.gax.grpc.InstantiatingGrpcChannelProvider.createChannel(InstantiatingGrpcChannelProvider.java:164) [gax-grpc-1.42.0.jar!/:1.42.0]
at com.google.api.gax.grpc.InstantiatingGrpcChannelProvider.getTransportChannel(InstantiatingGrpcChannelProvider.java:156) [gax-grpc-1.42.0.jar!/:1.42.0]
at com.google.api.gax.rpc.ClientContext.create(ClientContext.java:157) [gax-1.42.0.jar!/:1.42.0]
at com.google.cloud.vision.v1.stub.GrpcImageAnnotatorStub.create(GrpcImageAnnotatorStub.java:84) [google-cloud-vision-1.66.0.jar!/:1.66.0]
at com.google.cloud.vision.v1.stub.ImageAnnotatorStubSettings.createStub(ImageAnnotatorStubSettings.java:120) [google-cloud-vision-1.66.0.jar!/:1.66.0]
at com.google.cloud.vision.v1.ImageAnnotatorClient.<init>(ImageAnnotatorClient.java:136) [google-cloud-vision-1.66.0.jar!/:na]
at com.google.cloud.vision.v1.ImageAnnotatorClient.create(ImageAnnotatorClient.java:117) [google-cloud-vision-1.66.0.jar!/:na]
at com.google.cloud.vision.v1.ImageAnnotatorClient.create(ImageAnnotatorClient.java:108) [google-cloud-vision-1.66.0.jar!/:na]

Полный файл журнала ошибки можно найти по этой ссылке: Полный файл журнала .

Вот мой файл docker-compose.yml и Dockerfile службы, вызывающей проблему:

Файл Docker

FROM maven:3.6.0-jdk-8-alpine
WORKDIR /app/back
COPY src src
COPY pom.xml .
RUN mvn clean package

FROM openjdk:8-jdk-alpine
RUN apk add --no-cache curl
WORKDIR /app/back

COPY --from=0 /app/back/target/imagescanner*.jar ./imagescanner.jar
COPY --from=0 /app/back/target/classes/API-Key.json .
ENV GOOGLE_APPLICATION_CREDENTIALS ./API-Key.json
EXPOSE 8088

ENTRYPOINT ["java", "-jar", "./imagescanner.jar"]

docker-compose.yml

version: '3'

services:
   front:
     container_name: demoLab_front
     build: ./front
     image: demolab/front:latest
     expose:
       - "3000"
     ports:
       - "8087:3000"
     restart: always
   back:
     container_name: demoLab_backGCV
     build: ./backGCV
     image: demolab/backgcv:latest
     depends_on:
       - lab
     ports:
       - "8088:8088"
     restart: always
   lab:
     container_name: demoLab_labGCV
     build: ./lab
     image: demolab/labgcv:latest
     expose:
       - "8089"
     ports:
       - "8089:8089"
     restart: always
   sift:
     container_name: demoLab_labSIFT
     build: ./detect-label-service
     image: demolab/labsift:latest
     expose:
       - "5000"
     ports:
       - "5000:5000"
     restart: always

ИЗМЕНИТЬ

После некоторого поиска в Google я обнаружил, что: примеры GRPC Java не работают в Alpine Linux, поскольку требуемый libnetty-tcnative-boringssl-static зависит от glibc. Alpine использует musl libc, и запуск приложения завершится ошибкой с сообщением, подобным моему. Я нашел этот проект, который пытается создать правильные изображения, но он кажется сломанным для много людей (сборка не подошла для моего случая)


person Mr. D    schedule 16.04.2019    source источник
comment
Я вижу в журналах, что отсутствует файл зависимостей libcrypt.so.1. Suppressed: java.lang.UnsatisfiedLinkError: /tmp/libio_grpc_netty_shaded_netty_tcnative_linux_x86_641095585491871975468.so: Error loading shared library libcrypt.so.1: No such file or directory (needed by /tmp/libio_grpc_netty_shaded_netty_tcnative_linux_x86_641095585491871975468.so)   -  person Rohit Jindal    schedule 16.04.2019
comment
Вы правы, я просто редактирую вопрос, который отвечает, почему он отсутствует.   -  person Mr. D    schedule 16.04.2019


Ответы (1)


Проблема решена заменой этой строки Dockerfile:

FROM openjdk:8-jdk-alpine

с этой строкой:

FROM koosiedemoer/netty-tcnative-alpine
person Mr. D    schedule 16.04.2019