From 6a35bfcfefda94898256405300ac9d3af82be810 Mon Sep 17 00:00:00 2001 From: Ryan Murray Date: Thu, 11 Jun 2020 11:19:01 +0200 Subject: [PATCH] Enable Dremio for 4.2 (#14) * upgrade version * Update flight to work on 4.2 * parallel is still not usable * removed shaded jar as no longer required * match libraries/versions to dremio 4.2.2 --- Dockerfile | 4 +- pom.xml | 194 +++++++++--------- .../java/com/dremio/flight/AuthValidator.java | 7 +- src/main/java/com/dremio/flight/Producer.java | 7 +- .../flight/formation/DatasetBuilder.java | 3 +- .../flight/formation/FormationConfig.java | 1 + .../flight/formation/FormationPlugin.java | 31 ++- .../flight/formation/FormationWriter.java | 1 + .../com/dremio/flight/TestFlightEndpoint.java | 2 + .../dremio/flight/TestSslFlightEndpoint.java | 2 - 10 files changed, 137 insertions(+), 115 deletions(-) diff --git a/Dockerfile b/Dockerfile index 35d824d..bb82663 100644 --- a/Dockerfile +++ b/Dockerfile @@ -14,8 +14,8 @@ # limitations under the License. # -FROM dremio/dremio-oss:latest +FROM dremio/dremio-oss:4.2.2 -COPY target/dremio-flight-connector-0.11.0-SNAPSHOT-shaded.jar /opt/dremio/jars/ +COPY target/dremio-flight-connector-0.20.0-SNAPSHOT.jar /opt/dremio/jars/ ENTRYPOINT ["bin/dremio", "start-fg"] diff --git a/pom.xml b/pom.xml index 0433430..5bbdb93 100755 --- a/pom.xml +++ b/pom.xml @@ -22,7 +22,7 @@ com.dremio.flight dremio-flight-connector - 0.11.0-SNAPSHOT + 0.20.0-SNAPSHOT jar - 0.15.1 - 4.1.4-202001240912140359-a90eb503 + 1.0.0-20200327115344-e8784bde9c-dremio + 4.2.2-202004211133290458-b550b6fa 4.12 - 0.9.44 - 1.7.10 - 1.1.3 - 2.10.2 + 8.2.0 + 1.7.28 + 1.2.3 3.9.1 - 20.0 - 4.1.38.Final - 2.0.25.Final - -Ddremio.flight.ssl=true -Ddremio.flight.enabled=true -Ddremio.flight.parallel.enabled=true + 28.1-jre + 4.1.45.Final + 2.0.28.Final + -Ddremio.flight.ssl=true ${project.basedir}/target/generated-sources @@ -151,12 +150,12 @@ org.mortbay.jetty:servlet-api-2.5 org.apache.logging.log4j:log4j-slf4j-impl log4j:* - - + io.netty:*:4.0 + - - - + + io.netty:*:${netty.version} + @@ -398,57 +397,6 @@ limitations under the License. - - org.apache.maven.plugins - maven-shade-plugin - 3.1.0 - - - package - - shade - - - - - org.apache.arrow:arrow-flight:shaded - com.google.flatbuffers:flatbuffers-java - - - io.opencensus:* - com.google.code.gson:gson - com.google.code.findbugs:jsr305 - com.google.code.errorprone:error_prone_annotations - com.google.api.grpc:proto-google-common-protos - com.google.protobuf:protobuf-java - - - io.netty:netty-transport-native-unix-common - io.netty:netty-transport-native-epoll - - - - - com.google.protobuf - cdap.com.google.protobuf - - - - META-INF.native.libnetty_ - META-INF.native.libcdap_netty_ - - - META-INF.native.netty_ - META-INF.native.cdap_netty_ - - - - true - shaded - - - - @@ -456,52 +404,96 @@ limitations under the License. org.apache.arrow - - arrow-flight + flight-grpc ${arrow.flight.version} - shaded - - org.apache.arrow - arrow-format - - - org.apache.arrow - arrow-memory - - - org.apache.arrow - arrow-vector - + + com.fasterxml.jackson.core + jackson-core + + + com.fasterxml.jackson.core + jackson-annotations + + + com.fasterxml.jackson.core + jackson-databind + + + io.grpc + grpc-netty + + + io.netty + netty-handler + + + io.netty + netty-transport + + + io.netty + netty-tcnative-boringssl-static + + + + + + io.grpc + grpc-netty + 1.23.0 + + + io.netty + netty-codec-http2 + + + io.netty + netty-handler-proxy + - com.fasterxml.jackson.core - jackson-core - ${jackson.version} + io.netty + netty-codec-http2 + ${netty.version} - com.fasterxml.jackson.core - jackson-annotations - ${jackson.version} + io.netty + netty-tcnative-boringssl-static + ${netty.boringssl.version} - com.fasterxml.jackson.core - jackson-databind - ${jackson.version} + io.netty + netty-transport + ${netty.version} + + + io.netty + netty-handler + ${netty.version} + + + com.google.guava + guava + ${guava.version} + + + com.google.protobuf + protobuf-java + ${protobuf.version} + + + com.google.protobuf + protobuf-java-util + ${protobuf.version} - - - - - - com.dremio.sabot dremio-sabot-kernel ${version.dremio} - provided + org.slf4j @@ -530,7 +522,7 @@ limitations under the License. com.dremio dremio-dac-backend ${version.dremio} - provided + diff --git a/src/main/java/com/dremio/flight/AuthValidator.java b/src/main/java/com/dremio/flight/AuthValidator.java index 0f67bb7..cfc704a 100644 --- a/src/main/java/com/dremio/flight/AuthValidator.java +++ b/src/main/java/com/dremio/flight/AuthValidator.java @@ -13,6 +13,7 @@ * See the License for the specific language governing permissions and * limitations under the License. */ + package com.dremio.flight; import java.util.Arrays; @@ -30,6 +31,8 @@ import com.dremio.exec.proto.UserBitShared; import com.dremio.exec.proto.UserProtos; import com.dremio.exec.server.SabotContext; +import com.dremio.exec.server.options.SessionOptionManager; +import com.dremio.exec.server.options.SessionOptionManagerFactoryImpl; import com.dremio.sabot.rpc.user.UserRpcUtils; import com.dremio.sabot.rpc.user.UserSession; import com.dremio.service.users.SystemUser; @@ -95,9 +98,11 @@ public Optional isValid(byte[] bytes) { } private UserSession build(String user, String password) { + SessionOptionManager optionsManager = + new SessionOptionManagerFactoryImpl().getOrCreate("flight-session-" + user, context.getOptionManager()); return UserSession.Builder.newBuilder() .withCredentials(UserBitShared.UserCredentials.newBuilder().setUserName(user).build()) - .withOptionManager(context.getOptionManager()) + .withSessionOptionManager(optionsManager) .withUserProperties( UserProtos.UserProperties.newBuilder().addProperties( UserProtos.Property.newBuilder().setKey("password").setValue(password).build() diff --git a/src/main/java/com/dremio/flight/Producer.java b/src/main/java/com/dremio/flight/Producer.java index 4bd7444..888dfc4 100644 --- a/src/main/java/com/dremio/flight/Producer.java +++ b/src/main/java/com/dremio/flight/Producer.java @@ -13,9 +13,9 @@ * See the License for the specific language governing permissions and * limitations under the License. */ + package com.dremio.flight; -import java.util.Iterator; import java.util.List; import java.util.concurrent.CompletableFuture; import java.util.concurrent.ExecutionException; @@ -28,7 +28,6 @@ import org.apache.arrow.flight.Action; import org.apache.arrow.flight.ActionType; import org.apache.arrow.flight.Criteria; -import org.apache.arrow.flight.FlightClient; import org.apache.arrow.flight.FlightDescriptor; import org.apache.arrow.flight.FlightEndpoint; import org.apache.arrow.flight.FlightInfo; @@ -84,9 +83,7 @@ import com.dremio.exec.work.protector.UserResult; import com.dremio.exec.work.protector.UserWorker; import com.dremio.flight.formation.FormationPlugin; -import com.dremio.sabot.rpc.user.UserSession; import com.google.common.base.Joiner; -import com.google.common.collect.ImmutableList; import com.google.common.collect.Lists; import com.google.protobuf.InvalidProtocolBufferException; @@ -334,7 +331,7 @@ public void completed(UserResult result) { } } - @Override +// @Override public void planParallelized(PlanningSet planningSet) { logger.debug("plan parallel called, collecting endpoints"); List endpoints = Lists.newArrayList(); diff --git a/src/main/java/com/dremio/flight/formation/DatasetBuilder.java b/src/main/java/com/dremio/flight/formation/DatasetBuilder.java index a0d74cc..e474fcf 100644 --- a/src/main/java/com/dremio/flight/formation/DatasetBuilder.java +++ b/src/main/java/com/dremio/flight/formation/DatasetBuilder.java @@ -46,8 +46,7 @@ import com.google.common.base.Preconditions; import com.google.common.collect.ImmutableList; import com.google.common.collect.Lists; - -import arrow.flight.com.google.protobuf.ByteString; +import com.google.protobuf.ByteString; public class DatasetBuilder implements DatasetHandle { diff --git a/src/main/java/com/dremio/flight/formation/FormationConfig.java b/src/main/java/com/dremio/flight/formation/FormationConfig.java index 1c0bf1b..9c142ff 100644 --- a/src/main/java/com/dremio/flight/formation/FormationConfig.java +++ b/src/main/java/com/dremio/flight/formation/FormationConfig.java @@ -13,6 +13,7 @@ * See the License for the specific language governing permissions and * limitations under the License. */ + package com.dremio.flight.formation; import javax.inject.Provider; diff --git a/src/main/java/com/dremio/flight/formation/FormationPlugin.java b/src/main/java/com/dremio/flight/formation/FormationPlugin.java index a366d64..d166c70 100644 --- a/src/main/java/com/dremio/flight/formation/FormationPlugin.java +++ b/src/main/java/com/dremio/flight/formation/FormationPlugin.java @@ -43,6 +43,7 @@ import org.apache.arrow.flight.Ticket; import org.apache.arrow.flight.auth.BasicServerAuthHandler; import org.apache.arrow.memory.BufferAllocator; +import org.apache.arrow.vector.types.pojo.Field; import org.apache.arrow.vector.types.pojo.Schema; import org.apache.commons.lang3.tuple.Pair; @@ -71,6 +72,7 @@ import com.dremio.exec.store.StoragePlugin; import com.dremio.exec.store.StoragePluginRulesFactory; import com.dremio.exec.store.dfs.GenericCreateTableEntry; +import com.dremio.exec.store.dfs.IcebergTableProps; import com.dremio.flight.AuthValidator; import com.dremio.flight.PropertyHelper; import com.dremio.flight.SslHelper; @@ -227,7 +229,12 @@ public void close() throws Exception { } @Override - public CreateTableEntry createNewTable(SchemaConfig schemaConfig, NamespaceKey namespaceKey, WriterOptions writerOptions, Map map) { + public void createEmptyTable(SchemaConfig schemaConfig, NamespaceKey namespaceKey, com.dremio.exec.record.BatchSchema batchSchema, WriterOptions writerOptions) { + createNewTable(schemaConfig, namespaceKey, null, writerOptions, null); + } + + @Override + public CreateTableEntry createNewTable(SchemaConfig schemaConfig, NamespaceKey namespaceKey, IcebergTableProps icebergTableProps, WriterOptions writerOptions, Map map) { if (namespaceKey.size() != 2) { throw UserException.unsupportedError().message("Formation plugin currently only supports single part names.").build(logger); } @@ -248,7 +255,12 @@ public Writer getWriter(PhysicalOperator child, String location, WriterOptions o } @Override - public void dropTable(List list, SchemaConfig schemaConfig) { + public void dropTable(List list, boolean b, SchemaConfig schemaConfig) { + + } + + @Override + public void truncateTable(NamespaceKey namespaceKey, SchemaConfig schemaConfig) { } @@ -262,6 +274,21 @@ public void dropView(SchemaConfig schemaConfig, List list) throws IOExce } + @Override + public void addColumns(NamespaceKey namespaceKey, List list, SchemaConfig schemaConfig) { + + } + + @Override + public void dropColumn(NamespaceKey namespaceKey, String s, SchemaConfig schemaConfig) { + + } + + @Override + public void changeColumn(NamespaceKey namespaceKey, String s, Field field, SchemaConfig schemaConfig) { + + } + public FormationFlightProducer getProducer() { return producer; diff --git a/src/main/java/com/dremio/flight/formation/FormationWriter.java b/src/main/java/com/dremio/flight/formation/FormationWriter.java index 7b5c614..19c1b6f 100644 --- a/src/main/java/com/dremio/flight/formation/FormationWriter.java +++ b/src/main/java/com/dremio/flight/formation/FormationWriter.java @@ -13,6 +13,7 @@ * See the License for the specific language governing permissions and * limitations under the License. */ + package com.dremio.flight.formation; import java.io.IOException; diff --git a/src/test/java/com/dremio/flight/TestFlightEndpoint.java b/src/test/java/com/dremio/flight/TestFlightEndpoint.java index 59c5240..6256751 100644 --- a/src/test/java/com/dremio/flight/TestFlightEndpoint.java +++ b/src/test/java/com/dremio/flight/TestFlightEndpoint.java @@ -40,6 +40,7 @@ import org.junit.Assert; import org.junit.BeforeClass; import org.junit.ClassRule; +import org.junit.Ignore; import org.junit.Test; import org.junit.rules.TemporaryFolder; import org.slf4j.Logger; @@ -109,6 +110,7 @@ public void connect() throws Exception { } } + @Ignore @Test public void connectParallel() throws Exception { logger.debug("starting!"); diff --git a/src/test/java/com/dremio/flight/TestSslFlightEndpoint.java b/src/test/java/com/dremio/flight/TestSslFlightEndpoint.java index e2b4a06..ada8bdf 100644 --- a/src/test/java/com/dremio/flight/TestSslFlightEndpoint.java +++ b/src/test/java/com/dremio/flight/TestSslFlightEndpoint.java @@ -57,10 +57,8 @@ import com.dremio.BaseTestQuery; import com.dremio.config.DremioConfig; -import com.dremio.exec.ExecTest; import com.dremio.exec.rpc.ssl.SSLConfig; import com.dremio.exec.rpc.ssl.SSLConfigurator; -import com.dremio.service.InitializerRegistry; import com.dremio.service.users.SystemUser; import com.google.common.base.Preconditions; import com.google.common.collect.Lists;