This library assumes a GCC 9+ toolchain, cmake, Impala UDF headers, and relevant boost & openssl libraries are installed in the development environment. We have tested it on RHEL 8. Runtime dependencies such as OpenSSL need to be installed on the target Impala daemons. The CMakeLists.txt
file may specify the minimum cpu target for optimization reasons. By default it is set to Cascade Lake.
Cloudera provides a development library for creating UDFs and UDAs. It is best to find a package version corresponding to targeted version of Impala (or older). You can reach out to Cloudera Support if you have difficulties getting the correct RPM. The package is likely to be called either impala-udf-devel
or impala-udf-devel-client
. As an example, one could use the following for CDP 7.1.9 runtime:
# Set Cloudera username and password according to license info.
wget https://$username:$password@archive.cloudera.com/p/cdh7/7.1.9.0/impala/redhat8/impala-udf-devel-client-4.0.0.7.1.9.0-387.x86_64.rpm
sudo rpm -i impala-udf-devel-client-4.0.0.7.1.9.0-387.x86_64.rpm
sudo yum info impala-udf-devel-client
Notice that Impala 4.0 is shipped with CDP 7.1.9 and the package indicates both the Impala and CDP version numbers in its name.
On RHEL8, one can use so-called GCC toolsets to get a newer version of GCC that has binary compatibility with the base systems you are using. GCC 9 is required to get C++20 features used by this library. Later versions of GCC work just as well.
# Could be gcc-toolset 9+, eg, gcc 9 to 13 on RHEL 8 (GCC 13 tested). Pick the toolchain based on your needs.
sudo yum install gcc-toolset-13 boost cmake openssl openssl-devel
We use OpenSSL for hashing functions, but Cloudera Manager Agent will also require OpenSSL, so that dependency will usually be met in terms of the the target daemons.
For benchmarks, please install the google-benchmark library:
sudo yum install -y google-benchmark-devel google-benchmark
Configuration is done via cmake
but make
handles the build process. UDX tests are also provided. The test artifacts should be able to execute on the target Impala daemon. If they do not additional dependencies may be missing.
# Load the toolchain.
# This example assumes `gcc-toolset-13`` was installed on RHEL 8.
source /opt/rh/gcc-toolset-13/enable
# Configure and compile
cmake .
make
## Run tests
./build/udf-bioutils-test
./build/uda-bioutils-test
## Run benchmarks
./build/udf-bioutils-bmark
Built libraries will need to be put in HDFS / S3 / ADLS and then instantiated within Impala using the appropriate SQL.
Deployment requires pushing our .so
files to the remote, distributed file system and then registering the functions with Impala via query. If we have already deployed and registered our functions and just want to update them, we can just push to the remote storage system and use Impala's REFRESH FUNCTION
syntax.
Suppose we have an install location for the included libraries. We can set an environmental variable like so:
# Set HDFS (or other store) location for the libraries
export UDF_BIOUTILS_PATH="/udx/ncird_id/prod"
We used a folder called /udx
for both UDF and UDAs, a prod vs. dev subfolder, and a group for our organization which is NCIRD/ID. In practice you should set this to where you expect the UDFs to be readable by Impala. If they are not readable, adjust permissions and/or Ranger policies until they are.
The library artifacts are in the build directory and we can use the Hadoop CLI to push them to our remote file system (in combination with our environment variable for the install location). See:
# Set path to the SO location for your data lake
export UDF_BIOUTILS_PATH="/udx/prod"
./install_SO.sh
Next we can generate SQL to register the functions using our above variables:
# Set path to the SO location for your data lake
export UDF_BIOUTILS_PATH="/udx/prod"
# Creates tmp files to execute in Impala
for i in sql/*;do
cat $i|envsubst > $(basename $i .sql).tmp.sql
done
The query files can be executed via CLI or in something like HUE. Finally, it is recommended to use:
-- Supposing `udx` is the DB with your functions
refresh functions `udx`;