HBASE-20615 emphasize shaded artifacts in client tarball.

Conflicts:
	bin/hbase

Signed-off-by: Josh Elser <elserj@apache.org>
This commit is contained in:
Sean Busbey 2018-05-18 11:11:42 -05:00
parent 1725094e6b
commit 133892aae2
8 changed files with 395 additions and 103 deletions

204
bin/hbase
View File

@ -71,11 +71,18 @@ if [ -d "${HBASE_HOME}/target" ]; then
in_dev_env=true in_dev_env=true
fi fi
# Detect if we are in the omnibus tarball
in_omnibus_tarball="false"
if [ -f "${HBASE_HOME}/bin/hbase-daemons.sh" ]; then
in_omnibus_tarball="true"
fi
read -d '' options_string << EOF read -d '' options_string << EOF
Options: Options:
--config DIR Configuration direction to use. Default: ./conf --config DIR Configuration direction to use. Default: ./conf
--hosts HOSTS Override the list in 'regionservers' file --hosts HOSTS Override the list in 'regionservers' file
--auth-as-server Authenticate to ZooKeeper using servers configuration --auth-as-server Authenticate to ZooKeeper using servers configuration
--internal-classpath Skip attempting to use client facing jars (WARNING: unstable results between versions)
EOF EOF
# if no args specified, show usage # if no args specified, show usage
if [ $# = 0 ]; then if [ $# = 0 ]; then
@ -87,16 +94,18 @@ if [ $# = 0 ]; then
echo " shell Run the HBase shell" echo " shell Run the HBase shell"
echo " hbck Run the hbase 'fsck' tool" echo " hbck Run the hbase 'fsck' tool"
echo " snapshot Tool for managing snapshots" echo " snapshot Tool for managing snapshots"
echo " wal Write-ahead-log analyzer" if [ "${in_omnibus_tarball}" = "true" ]; then
echo " hfile Store file analyzer" echo " wal Write-ahead-log analyzer"
echo " zkcli Run the ZooKeeper shell" echo " hfile Store file analyzer"
echo " master Run an HBase HMaster node" echo " zkcli Run the ZooKeeper shell"
echo " regionserver Run an HBase HRegionServer node" echo " master Run an HBase HMaster node"
echo " zookeeper Run a ZooKeeper server" echo " regionserver Run an HBase HRegionServer node"
echo " rest Run an HBase REST server" echo " zookeeper Run a ZooKeeper server"
echo " thrift Run the HBase Thrift server" echo " rest Run an HBase REST server"
echo " thrift2 Run the HBase Thrift2 server" echo " thrift Run the HBase Thrift server"
echo " clean Run the HBase clean up script" echo " thrift2 Run the HBase Thrift2 server"
echo " clean Run the HBase clean up script"
fi
echo " classpath Dump hbase CLASSPATH" echo " classpath Dump hbase CLASSPATH"
echo " mapredcp Dump CLASSPATH entries required by mapreduce" echo " mapredcp Dump CLASSPATH entries required by mapreduce"
echo " pe Run PerformanceEvaluation" echo " pe Run PerformanceEvaluation"
@ -184,9 +193,99 @@ for f in $HBASE_HOME/hbase-jars/hbase*.jar; do
fi fi
done done
#If avail, add Hadoop to the CLASSPATH and to the JAVA_LIBRARY_PATH
# Allow this functionality to be disabled
if [ "$HBASE_DISABLE_HADOOP_CLASSPATH_LOOKUP" != "true" ] ; then
HADOOP_IN_PATH=$(PATH="${HADOOP_HOME:-${HADOOP_PREFIX}}/bin:$PATH" which hadoop 2>/dev/null)
fi
# Add libs to CLASSPATH # Add libs to CLASSPATH
for f in $HBASE_HOME/lib/*.jar; do declare shaded_jar
CLASSPATH=${CLASSPATH}:$f;
if [ "${INTERNAL_CLASSPATH}" != "true" ]; then
# find our shaded jars
declare shaded_client
declare shaded_client_byo_hadoop
declare shaded_mapreduce
for f in "${HBASE_HOME}"/lib/shaded-clients/hbase-shaded-client*.jar; do
if [[ "${f}" =~ byo-hadoop ]]; then
shaded_client_byo_hadoop="${f}"
else
shaded_client="${f}"
fi
done
for f in "${HBASE_HOME}"/lib/shaded-clients/hbase-shaded-mapreduce*.jar; do
shaded_mapreduce="${f}"
done
# If command can use our shaded client, use it
declare -a commands_in_client_jar=("classpath" "version")
for c in "${commands_in_client_jar[@]}"; do
if [ "${COMMAND}" = "${c}" ]; then
if [ -n "${HADOOP_IN_PATH}" ] && [ -f "${HADOOP_IN_PATH}" ]; then
# If we didn't find a jar above, this will just be blank and the
# check below will then default back to the internal classpath.
shaded_jar="${shaded_client_byo_hadoop}"
else
# If we didn't find a jar above, this will just be blank and the
# check below will then default back to the internal classpath.
shaded_jar="${shaded_client}"
fi
break
fi
done
# If command needs our shaded mapreduce, use it
# N.B "mapredcp" is not included here because in the shaded case it skips our built classpath
declare -a commands_in_mr_jar=("hbck" "snapshot" "canary" "regionsplitter" "pre-upgrade")
for c in "${commands_in_mr_jar[@]}"; do
if [ "${COMMAND}" = "${c}" ]; then
# If we didn't find a jar above, this will just be blank and the
# check below will then default back to the internal classpath.
shaded_jar="${shaded_mapreduce}"
break
fi
done
# Some commands specifically only can use shaded mapreduce when we'll get a full hadoop classpath at runtime
if [ -n "${HADOOP_IN_PATH}" ] && [ -f "${HADOOP_IN_PATH}" ]; then
declare -a commands_in_mr_need_hadoop=("backup" "restore" "rowcounter" "cellcounter")
for c in "${commands_in_mr_need_hadoop[@]}"; do
if [ "${COMMAND}" = "${c}" ]; then
# If we didn't find a jar above, this will just be blank and the
# check below will then default back to the internal classpath.
shaded_jar="${shaded_mapreduce}"
break
fi
done
fi
fi
if [ -n "${shaded_jar}" ] && [ -f "${shaded_jar}" ]; then
CLASSPATH="${CLASSPATH}:${shaded_jar}"
# fall through to grabbing all the lib jars and hope we're in the omnibus tarball
#
# N.B. shell specifically can't rely on the shaded artifacts because RSGroups is only
# available as non-shaded
#
# N.B. pe and ltt can't easily rely on shaded artifacts because they live in hbase-mapreduce:test-jar
# and need some other jars that haven't been relocated. Currently enumerating that list
# is too hard to be worth it.
#
else
for f in $HBASE_HOME/lib/*.jar; do
CLASSPATH=${CLASSPATH}:$f;
done
# make it easier to check for shaded/not later on.
shaded_jar=""
fi
for f in "${HBASE_HOME}"/lib/client-facing-thirdparty/*.jar; do
if [[ ! "${f}" =~ ^.*/htrace-core-3.*\.jar$ ]] && \
[ "${f}" != "htrace-core.jar$" ] && \
[[ ! "${f}" =~ ^.*/slf4j-log4j.*$ ]]; then
CLASSPATH="${CLASSPATH}:${f}"
fi
done done
# default log directory & file # default log directory & file
@ -199,9 +298,9 @@ fi
function append_path() { function append_path() {
if [ -z "$1" ]; then if [ -z "$1" ]; then
echo $2 echo "$2"
else else
echo $1:$2 echo "$1:$2"
fi fi
} }
@ -212,18 +311,34 @@ if [ "$HBASE_LIBRARY_PATH" != "" ]; then
JAVA_LIBRARY_PATH=$(append_path "$JAVA_LIBRARY_PATH" "$HBASE_LIBRARY_PATH") JAVA_LIBRARY_PATH=$(append_path "$JAVA_LIBRARY_PATH" "$HBASE_LIBRARY_PATH")
fi fi
#If avail, add Hadoop to the CLASSPATH and to the JAVA_LIBRARY_PATH #If configured and available, add Hadoop to the CLASSPATH and to the JAVA_LIBRARY_PATH
# Allow this functionality to be disabled if [ -n "${HADOOP_IN_PATH}" ] && [ -f "${HADOOP_IN_PATH}" ]; then
if [ "$HBASE_DISABLE_HADOOP_CLASSPATH_LOOKUP" != "true" ] ; then HADOOP_JAVA_LIBRARY_PATH=$(HADOOP_CLASSPATH="$CLASSPATH" "${HADOOP_IN_PATH}" \
HADOOP_IN_PATH=$(PATH="${HADOOP_HOME:-${HADOOP_PREFIX}}/bin:$PATH" which hadoop 2>/dev/null) org.apache.hadoop.hbase.util.GetJavaProperty java.library.path)
if [ -f ${HADOOP_IN_PATH} ]; then if [ -n "$HADOOP_JAVA_LIBRARY_PATH" ]; then
HADOOP_JAVA_LIBRARY_PATH=$(HADOOP_CLASSPATH="$CLASSPATH" ${HADOOP_IN_PATH} \ JAVA_LIBRARY_PATH=$(append_path "${JAVA_LIBRARY_PATH}" "$HADOOP_JAVA_LIBRARY_PATH")
org.apache.hadoop.hbase.util.GetJavaProperty java.library.path 2>/dev/null)
if [ -n "$HADOOP_JAVA_LIBRARY_PATH" ]; then
JAVA_LIBRARY_PATH=$(append_path "${JAVA_LIBRARY_PATH}" "$HADOOP_JAVA_LIBRARY_PATH")
fi
CLASSPATH=$(append_path "${CLASSPATH}" `${HADOOP_IN_PATH} classpath 2>/dev/null`)
fi fi
CLASSPATH=$(append_path "${CLASSPATH}" "$(${HADOOP_IN_PATH} classpath 2>/dev/null)")
else
# Otherwise, if we're providing Hadoop we should include htrace 3 if we were built with a version that needs it.
for f in "${HBASE_HOME}"/lib/client-facing-thirdparty/htrace-core-3*.jar "${HBASE_HOME}"/lib/client-facing-thirdparty/htrace-core.jar; do
if [ -f "${f}" ]; then
CLASSPATH="${CLASSPATH}:${f}"
break
fi
done
# Some commands require special handling when using shaded jars. For these cases, we rely on hbase-shaded-mapreduce
# instead of hbase-shaded-client* because we make use of some IA.Private classes that aren't in the latter. However,
# we don't invoke them using the "hadoop jar" command so we need to ensure there are some Hadoop classes available
# when we're not doing runtime hadoop classpath lookup.
#
# luckily the set of classes we need are those packaged in the shaded-client.
for c in "${commands_in_mr_jar[@]}"; do
if [ "${COMMAND}" = "${c}" ] && [ -n "${shaded_jar}" ]; then
CLASSPATH="${CLASSPATH}:${shaded_client:?We couldn\'t find the shaded client jar even though we did find the shaded MR jar. for command ${COMMAND} we need both. please use --internal-classpath as a workaround.}"
break
fi
done
fi fi
# Add user-specified CLASSPATH last # Add user-specified CLASSPATH last
@ -248,11 +363,11 @@ if [ -d "${HBASE_HOME}/build/native" -o -d "${HBASE_HOME}/lib/native" ]; then
JAVA_PLATFORM=`CLASSPATH=${CLASSPATH} ${JAVA} org.apache.hadoop.util.PlatformName | sed -e "s/ /_/g"` JAVA_PLATFORM=`CLASSPATH=${CLASSPATH} ${JAVA} org.apache.hadoop.util.PlatformName | sed -e "s/ /_/g"`
fi fi
if [ -d "$HBASE_HOME/build/native" ]; then if [ -d "$HBASE_HOME/build/native" ]; then
JAVA_LIBRARY_PATH=$(append_path "$JAVA_LIBRARY_PATH" ${HBASE_HOME}/build/native/${JAVA_PLATFORM}/lib) JAVA_LIBRARY_PATH=$(append_path "$JAVA_LIBRARY_PATH" "${HBASE_HOME}/build/native/${JAVA_PLATFORM}/lib")
fi fi
if [ -d "${HBASE_HOME}/lib/native" ]; then if [ -d "${HBASE_HOME}/lib/native" ]; then
JAVA_LIBRARY_PATH=$(append_path "$JAVA_LIBRARY_PATH" ${HBASE_HOME}/lib/native/${JAVA_PLATFORM}) JAVA_LIBRARY_PATH=$(append_path "$JAVA_LIBRARY_PATH" "${HBASE_HOME}/lib/native/${JAVA_PLATFORM}")
fi fi
fi fi
@ -445,9 +560,24 @@ elif [ "$COMMAND" = "clean" ] ; then
"$bin"/hbase-cleanup.sh --config ${HBASE_CONF_DIR} $@ "$bin"/hbase-cleanup.sh --config ${HBASE_CONF_DIR} $@
exit $? exit $?
elif [ "$COMMAND" = "mapredcp" ] ; then elif [ "$COMMAND" = "mapredcp" ] ; then
# If we didn't find a jar above, this will just be blank and the
# check below will then default back to the internal classpath.
shaded_jar="${shaded_mapreduce}"
if [ "${INTERNAL_CLASSPATH}" != "true" ] && [ -f "${shaded_jar}" ]; then
echo -n "${shaded_jar}"
for f in "${HBASE_HOME}"/lib/client-facing-thirdparty/*.jar; do
if [[ ! "${f}" =~ ^.*/htrace-core-3.*\.jar$ ]] && \
[ "${f}" != "htrace-core.jar$" ] && \
[[ ! "${f}" =~ ^.*/slf4j-log4j.*$ ]]; then
echo -n ":${f}"
fi
done
echo ""
exit 0
fi
CLASS='org.apache.hadoop.hbase.util.MapreduceDependencyClasspathTool' CLASS='org.apache.hadoop.hbase.util.MapreduceDependencyClasspathTool'
elif [ "$COMMAND" = "classpath" ] ; then elif [ "$COMMAND" = "classpath" ] ; then
echo $CLASSPATH echo "$CLASSPATH"
exit 0 exit 0
elif [ "$COMMAND" = "pe" ] ; then elif [ "$COMMAND" = "pe" ] ; then
CLASS='org.apache.hadoop.hbase.PerformanceEvaluation' CLASS='org.apache.hadoop.hbase.PerformanceEvaluation'
@ -494,8 +624,20 @@ else
fi fi
HEAP_SETTINGS="$JAVA_HEAP_MAX $JAVA_OFFHEAP_MAX" HEAP_SETTINGS="$JAVA_HEAP_MAX $JAVA_OFFHEAP_MAX"
# by now if we're running a command it means we need logging
for f in ${HBASE_HOME}/lib/client-facing-thirdparty/slf4j-log4j*.jar; do
if [ -f "${f}" ]; then
CLASSPATH="${CLASSPATH}:${f}"
break
fi
done
# Exec unless HBASE_NOEXEC is set. # Exec unless HBASE_NOEXEC is set.
export CLASSPATH export CLASSPATH
if [ "${DEBUG}" = "true" ]; then
echo "classpath=${CLASSPATH}" >&2
HBASE_OPTS="${HBASE_OPTS} -Xdiag"
fi
if [ "${HBASE_NOEXEC}" != "" ]; then if [ "${HBASE_NOEXEC}" != "" ]; then
"$JAVA" -Dproc_$COMMAND -XX:OnOutOfMemoryError="kill -9 %p" $HEAP_SETTINGS $HBASE_OPTS $CLASS "$@" "$JAVA" -Dproc_$COMMAND -XX:OnOutOfMemoryError="kill -9 %p" $HEAP_SETTINGS $HBASE_OPTS $CLASS "$@"

View File

@ -84,6 +84,16 @@ do
exit 1 exit 1
fi fi
shift shift
elif [ "--internal-classpath" = "$1" ]
then
shift
# shellcheck disable=SC2034
INTERNAL_CLASSPATH="true"
elif [ "--debug" = "$1" ]
then
shift
# shellcheck disable=SC2034
DEBUG="true"
else else
# Presume we are at end of options and break # Presume we are at end of options and break
break break

View File

@ -174,6 +174,19 @@
</plugins> </plugins>
</build> </build>
<dependencies> <dependencies>
<!-- client artifacts for downstream use -->
<dependency>
<groupId>org.apache.hbase</groupId>
<artifactId>hbase-shaded-client</artifactId>
</dependency>
<dependency>
<groupId>org.apache.hbase</groupId>
<artifactId>hbase-shaded-client-byo-hadoop</artifactId>
</dependency>
<dependency>
<groupId>org.apache.hbase</groupId>
<artifactId>hbase-shaded-mapreduce</artifactId>
</dependency>
<!-- Intra-project dependencies --> <!-- Intra-project dependencies -->
<dependency> <dependency>
<groupId>org.apache.hbase</groupId> <groupId>org.apache.hbase</groupId>
@ -295,14 +308,6 @@
<groupId>jline</groupId> <groupId>jline</groupId>
<artifactId>jline</artifactId> <artifactId>jline</artifactId>
</dependency> </dependency>
<dependency>
<groupId>org.apache.hbase</groupId>
<artifactId>hbase-shaded-client</artifactId>
</dependency>
<dependency>
<groupId>org.apache.hbase</groupId>
<artifactId>hbase-shaded-mapreduce</artifactId>
</dependency>
</dependencies> </dependencies>
<profiles> <profiles>
<profile> <profile>

View File

@ -32,7 +32,8 @@
<directory>${project.basedir}/..</directory> <directory>${project.basedir}/..</directory>
<outputDirectory>.</outputDirectory> <outputDirectory>.</outputDirectory>
<includes> <includes>
<include>CHANGES.txt</include> <include>CHANGES.md</include>
<include>RELEASENOTES.md</include>
<include>README.txt</include> <include>README.txt</include>
</includes> </includes>
<fileMode>0644</fileMode> <fileMode>0644</fileMode>
@ -56,7 +57,6 @@
<include>hbase-config.sh</include> <include>hbase-config.sh</include>
<include>hbase-jruby</include> <include>hbase-jruby</include>
<include>hirb.rb</include> <include>hirb.rb</include>
<include></include>
</includes> </includes>
<fileMode>0755</fileMode> <fileMode>0755</fileMode>
<directoryMode>0755</directoryMode> <directoryMode>0755</directoryMode>
@ -88,5 +88,44 @@
<include>*.dylib</include> <include>*.dylib</include>
</includes> </includes>
</fileSet> </fileSet>
<!-- This is only necessary until maven fixes the intra-project dependency bug
in maven 3.0. Until then, we have to include the test jars for sub-projects. When
fixed, the below dependencySet stuff is sufficient for pulling in the test jars as
well, as long as they are added as dependencies in this project. Right now, we only
have 1 submodule to accumulate, but we can copy/paste as necessary until maven is
fixed. -->
<!-- Used by PE and ltt -->
<fileSet>
<directory>${project.basedir}/../hbase-server/target/</directory>
<outputDirectory>lib</outputDirectory>
<includes>
<include>${server.test.jar}</include>
</includes>
<fileMode>0644</fileMode>
</fileSet>
<fileSet>
<directory>${project.basedir}/../hbase-mapreduce/target/</directory>
<outputDirectory>lib</outputDirectory>
<includes>
<include>${mapreduce.test.jar}</include>
</includes>
<fileMode>0644</fileMode>
</fileSet>
<fileSet>
<directory>${project.basedir}/../hbase-common/target/</directory>
<outputDirectory>lib</outputDirectory>
<includes>
<include>${common.test.jar}</include>
</includes>
<fileMode>0644</fileMode>
</fileSet>
<fileSet>
<directory>${project.basedir}/../hbase-zookeeper/target/</directory>
<outputDirectory>lib</outputDirectory>
<includes>
<include>${zookeeper.test.jar}</include>
</includes>
<fileMode>0644</fileMode>
</fileSet>
</fileSets> </fileSets>
</component> </component>

View File

@ -31,73 +31,37 @@
<componentDescriptor>src/main/assembly/client-components.xml</componentDescriptor> <componentDescriptor>src/main/assembly/client-components.xml</componentDescriptor>
</componentDescriptors> </componentDescriptors>
<moduleSets> <moduleSets>
<!-- include regular jars so the shell can use them -->
<moduleSet> <moduleSet>
<useAllReactorProjects>true</useAllReactorProjects> <useAllReactorProjects>true</useAllReactorProjects>
<includes> <includes>
<!-- Keep this list sorted by name --> <include>org.apache.hbase:hbase-shell</include>
<include>org.apache.hbase:hbase-annotations</include>
<include>org.apache.hbase:hbase-client</include>
<include>org.apache.hbase:hbase-common</include>
<include>org.apache.hbase:hbase-hadoop-compat</include>
<include>org.apache.hbase:hbase-hadoop2-compat</include>
<include>org.apache.hbase:hbase-mapreduce</include>
<include>org.apache.hbase:hbase-metrics</include>
<include>org.apache.hbase:hbase-metrics-api</include>
<include>org.apache.hbase:hbase-procedure</include>
<include>org.apache.hbase:hbase-protocol</include>
<include>org.apache.hbase:hbase-protocol-shaded</include>
<include>org.apache.hbase:hbase-server</include>
<include>org.apache.hbase:hbase-zookeeper</include>
</includes> </includes>
<!-- Binaries for the dependencies also go in the hbase-jars directory -->
<binaries> <binaries>
<outputDirectory>lib</outputDirectory>
<unpack>false</unpack> <unpack>false</unpack>
<dependencySets> <outputDirectory>lib</outputDirectory>
<!-- Exclude jruby-complete from hbase_home/lib --> <dependencySets>
<dependencySet> <dependencySet>
<!-- Exclude libraries that we put in their own dirs under lib/ -->
<excludes> <excludes>
<exclude>org.jruby:jruby-complete</exclude>
<exclude>com.sun.jersey:*</exclude> <exclude>com.sun.jersey:*</exclude>
<exclude>com.sun.jersey.contribs:*</exclude> <exclude>com.sun.jersey.contribs:*</exclude>
<!-- Exclude jars which typical clients don't need --> <exclude>jline:jline</exclude>
<exclude>org.apache.hbase:hbase-external-blockcache</exclude> <exclude>com.github.stephenc.findbugs:findbugs-annotations</exclude>
<exclude>org.apache.hbase:hbase-http</exclude> <exclude>commons-logging:commons-logging</exclude>
<exclude>org.apache.hbase:hbase-replication</exclude> <exclude>log4j:log4j</exclude>
<exclude>org.apache.hbase:hbase-rest</exclude> <exclude>org.apache.hbase:hbase-shaded-client</exclude>
<exclude>org.apache.hbase:hbase-rsgroup</exclude> <exclude>org.apache.hbase:hbase-shaded-client-byo-hadoop</exclude>
<exclude>org.apache.hbase:hbase-shaded-client</exclude> <exclude>org.apache.hbase:hbase-shaded-mapreduce</exclude>
<exclude>org.apache.hbase:hbase-shaded-mapreduce</exclude> <exclude>org.apache.htrace:htrace-core4</exclude>
<!-- At present, hbase-shell doesn't actually contain <exclude>org.apache.htrace:htrace-core</exclude>
any Java code we need to include. Ruby files are <exclude>org.apache.yetus:audience-annotations</exclude>
copied elsewhere in this descriptor. --> <exclude>org.slf4j:slf4j-api</exclude>
<exclude>org.apache.hbase:hbase-shell</exclude> <exclude>org.slf4j:slf4j-log4j12</exclude>
<exclude>org.apache.hbase:hbase-thrift</exclude>
<exclude>org.jruby:jruby-complete</exclude>
</excludes> </excludes>
</dependencySet> </dependencySet>
</dependencySets> </dependencySets>
</binaries>
</moduleSet>
<moduleSet>
<useAllReactorProjects>true</useAllReactorProjects>
<includes>
<include>org.apache.hbase:hbase-shaded-client</include>
<include>org.apache.hbase:hbase-shaded-mapreduce</include>
</includes>
<!-- Binaries for the dependencies also go in the hbase-jars directory -->
<binaries>
<outputDirectory>shaded-lib</outputDirectory>
<unpack>false</unpack>
<dependencySets>
<dependencySet>
<includes>
<!-- Keep this list sorted by name -->
<include>org.apache.hbase:hbase-shaded-client</include>
<include>org.apache.hbase:hbase-shaded-mapreduce</include>
</includes>
<useTransitiveDependencies>false</useTransitiveDependencies>
</dependencySet>
</dependencySets>
</binaries> </binaries>
</moduleSet> </moduleSet>
</moduleSets> </moduleSets>
@ -123,15 +87,66 @@
</file> </file>
</files> </files>
<dependencySets>
<dependencySet>
<outputDirectory>lib/shaded-clients</outputDirectory>
<includes>
<include>org.apache.hbase:hbase-shaded-client</include>
<include>org.apache.hbase:hbase-shaded-mapreduce</include>
<include>org.apache.hbase:hbase-shaded-client-byo-hadoop</include>
</includes>
</dependencySet>
<!-- Add jruby-complete to hbase_home/lib/ruby. <!-- Add jruby-complete to hbase_home/lib/ruby.
Update JRUBY_PACKAGED_WITH_HBASE in bin/hbase and hbase.cmd if you would like to update outputDirectory below --> Update JRUBY_PACKAGED_WITH_HBASE in bin/hbase and hbase.cmd if you would like to update outputDirectory below -->
<dependencySets>
<dependencySet> <dependencySet>
<outputDirectory>lib/ruby</outputDirectory> <outputDirectory>lib/ruby</outputDirectory>
<includes> <includes>
<include>org.jruby:jruby-complete</include> <include>org.jruby:jruby-complete</include>
</includes> </includes>
</dependencySet> </dependencySet>
<!-- Include third party dependencies the shaded clients expose in the lib directory
N.B. this will conflict with the omnibus tarball but these should be precisely
the same artifacts so blind overwrite of either should be fine.
-->
<dependencySet>
<outputDirectory>lib/client-facing-thirdparty</outputDirectory>
<useTransitiveDependencies>true</useTransitiveDependencies>
<!-- Unfortunately, we have to whitelist these because Maven
currently doesn't use the dependency-reduced-pom after
the shaded module has done its thing. That means if we
did this as "transitives of the shaded modules" we'd
get a duplication of all the jars we already have in our
shaded artifacts. See MNG-5899.
Check that things match by listing files and making
sure the runtime scoped things are all present in the
tarball. e.g.:
for module in hbase-shaded-mapreduce hbase-shaded-client; do
mvn dependency:list -f hbase-shaded/${module}/dependency-reduced-pom.xml
done | \
grep -E "runtime|compile" | \
grep -v -E "junit|(optional)" | \
cut -d ' ' -f 3- | \
sort -u
TODO we should check this in nightly
Alternatively, we could
stop waiting for Maven to fix this and build the client
tarball in a different build.
-->
<includes>
<include>com.github.stephenc.findbugs:findbugs-annotations</include>
<include>commons-logging:commons-logging</include>
<include>log4j:log4j</include>
<include>org.apache.htrace:htrace-core4</include>
<include>org.apache.htrace:htrace-core</include>
<include>org.apache.yetus:audience-annotations</include>
<include>org.slf4j:slf4j-api</include>
<include>org.slf4j:slf4j-log4j12</include>
</includes>
</dependencySet>
</dependencySets> </dependencySets>
</assembly> </assembly>

View File

@ -37,7 +37,8 @@
<directory>${project.basedir}/..</directory> <directory>${project.basedir}/..</directory>
<outputDirectory>.</outputDirectory> <outputDirectory>.</outputDirectory>
<includes> <includes>
<include>CHANGES.txt</include> <include>CHANGES.md</include>
<include>RELEASENOTES.md</include>
<include>README.txt</include> <include>README.txt</include>
</includes> </includes>
<fileMode>0644</fileMode> <fileMode>0644</fileMode>

View File

@ -62,18 +62,51 @@
<outputDirectory>lib</outputDirectory> <outputDirectory>lib</outputDirectory>
<unpack>false</unpack> <unpack>false</unpack>
<dependencySets> <dependencySets>
<!-- Exclude jruby-complete from hbase_home/lib -->
<dependencySet> <dependencySet>
<!-- Exclude libraries that we put in their own dirs under lib/ -->
<excludes> <excludes>
<exclude>org.jruby:jruby-complete</exclude> <exclude>org.jruby:jruby-complete</exclude>
<exclude>com.sun.jersey:*</exclude> <exclude>com.sun.jersey:*</exclude>
<exclude>com.sun.jersey.contribs:*</exclude> <exclude>com.sun.jersey.contribs:*</exclude>
<exclude>jline:jline</exclude> <exclude>jline:jline</exclude>
<exclude>org.apache.hbase:hbase-shaded-client</exclude>
<exclude>org.apache.hbase:hbase-shaded-client-byo-hadoop</exclude>
<exclude>org.apache.hbase:hbase-shaded-mapreduce</exclude>
<exclude>com.github.stephenc.findbugs:findbugs-annotations</exclude>
<exclude>commons-logging:commons-logging</exclude>
<exclude>log4j:log4j</exclude>
<exclude>org.apache.htrace:htrace-core4</exclude>
<exclude>org.apache.htrace:htrace-core</exclude>
<exclude>org.apache.yetus:audience-annotations</exclude>
<exclude>org.slf4j:slf4j-api</exclude>
<exclude>org.slf4j:slf4j-log4j12</exclude>
</excludes> </excludes>
</dependencySet> </dependencySet>
</dependencySets> </dependencySets>
</binaries> </binaries>
</moduleSet> </moduleSet>
<!-- Include shaded clients in their own directory -->
<moduleSet>
<useAllReactorProjects>true</useAllReactorProjects>
<includes>
<include>org.apache.hbase:hbase-shaded-client</include>
<include>org.apache.hbase:hbase-shaded-mapreduce</include>
<include>org.apache.hbase:hbase-shaded-client-byo-hadoop</include>
</includes>
<binaries>
<outputDirectory>lib/shaded-clients</outputDirectory>
<unpack>false</unpack>
<dependencySets>
<dependencySet>
<includes>
<include>org.apache.hbase:hbase-shaded-client</include>
<include>org.apache.hbase:hbase-shaded-mapreduce</include>
<include>org.apache.hbase:hbase-shaded-client-byo-hadoop</include>
</includes>
</dependencySet>
</dependencySets>
</binaries>
</moduleSet>
</moduleSets> </moduleSets>
<!-- Include the generated LICENSE and NOTICE files --> <!-- Include the generated LICENSE and NOTICE files -->
<files> <files>
@ -97,15 +130,56 @@
</file> </file>
</files> </files>
<!-- Add jruby-complete to hbase_home/lib/ruby.
Update JRUBY_PACKAGED_WITH_HBASE in bin/hbase and hbase.cmd if you would like to update outputDirectory below -->
<dependencySets> <dependencySets>
<!-- Add jruby-complete to hbase_home/lib/ruby.
Update JRUBY_PACKAGED_WITH_HBASE in bin/hbase and hbase.cmd if you would like to update outputDirectory below -->
<dependencySet> <dependencySet>
<outputDirectory>lib/ruby</outputDirectory> <outputDirectory>lib/ruby</outputDirectory>
<includes> <includes>
<include>org.jruby:jruby-complete</include> <include>org.jruby:jruby-complete</include>
</includes> </includes>
</dependencySet> </dependencySet>
<!-- Include third party dependencies the shaded clients expose in the lib directory
-->
<dependencySet>
<outputDirectory>lib/client-facing-thirdparty</outputDirectory>
<useTransitiveDependencies>true</useTransitiveDependencies>
<!-- Unfortunately, we have to whitelist these because Maven
currently doesn't use the dependency-reduced-pom after
the shaded module has done its thing. That means if we
did this as "transitives of the shaded modules" we'd
get a duplication of all the jars we already have in our
shaded artifacts. See MNG-5899.
Check that things match by listing files and making
sure the runtime scoped things are all present in the
tarball. e.g.:
for module in hbase-shaded-mapreduce hbase-shaded-client; do
mvn dependency:list -f hbase-shaded/${module}/dependency-reduced-pom.xml
done | \
grep -E "runtime|compile" | \
grep -v -E "junit|(optional)" | \
cut -d ' ' -f 3- | \
sort -u
TODO we should check this in nightly
Alternatively, we could
stop waiting for Maven to fix this and build the client
tarball in a different build.
-->
<includes>
<include>com.github.stephenc.findbugs:findbugs-annotations</include>
<include>commons-logging:commons-logging</include>
<include>log4j:log4j</include>
<include>org.apache.htrace:htrace-core4</include>
<include>org.apache.htrace:htrace-core</include>
<include>org.apache.yetus:audience-annotations</include>
<include>org.slf4j:slf4j-api</include>
<include>org.slf4j:slf4j-log4j12</include>
</includes>
</dependencySet>
<dependencySet> <dependencySet>
<outputDirectory>lib/zkcli</outputDirectory> <outputDirectory>lib/zkcli</outputDirectory>
<includes> <includes>

View File

@ -1434,6 +1434,7 @@
<annotations.test.jar>hbase-annotations-${project.version}-tests.jar</annotations.test.jar> <annotations.test.jar>hbase-annotations-${project.version}-tests.jar</annotations.test.jar>
<rsgroup.test.jar>hbase-rsgroup-${project.version}-tests.jar</rsgroup.test.jar> <rsgroup.test.jar>hbase-rsgroup-${project.version}-tests.jar</rsgroup.test.jar>
<mapreduce.test.jar>hbase-mapreduce-${project.version}-tests.jar</mapreduce.test.jar> <mapreduce.test.jar>hbase-mapreduce-${project.version}-tests.jar</mapreduce.test.jar>
<zookeeper.test.jar>hbase-zookeeper-${project.version}-tests.jar</zookeeper.test.jar>
<shell-executable>bash</shell-executable> <shell-executable>bash</shell-executable>
<surefire.version>2.21.0</surefire.version> <surefire.version>2.21.0</surefire.version>
<surefire.provider>surefire-junit47</surefire.provider> <surefire.provider>surefire-junit47</surefire.provider>
@ -1715,6 +1716,11 @@
<artifactId>hbase-shaded-client</artifactId> <artifactId>hbase-shaded-client</artifactId>
<version>${project.version}</version> <version>${project.version}</version>
</dependency> </dependency>
<dependency>
<groupId>org.apache.hbase</groupId>
<artifactId>hbase-shaded-client-byo-hadoop</artifactId>
<version>${project.version}</version>
</dependency>
<dependency> <dependency>
<groupId>org.apache.hbase</groupId> <groupId>org.apache.hbase</groupId>
<artifactId>hbase-shaded-mapreduce</artifactId> <artifactId>hbase-shaded-mapreduce</artifactId>