UDF 的使用

UDF:User Defined Function,用户自定义函数。某些场景我们需要使用hive的函数来处理一些数据,像count(),sum()这些函数都是内置的。如果我们想要使用一些没有自带的函数功能,则需要自定义功能函数,就可以通过写UDF来完成。

实现一个UDF的方式较为简单:只需要继承UDF类,并重写evaluate方法。

  1. public class HelloUDF extends UDF{
  2. public String evaluate(String str){
  3. try {
  4. return "Hello " + str;
  5. } catch (Exception e) {
  6. // TODO: handle exception
  7. e.printStackTrace();
  8. return "ERROR";
  9. }
  10. }
  • UDF 函数(需要注册后才能使用):

    • 通用类型的UDF函数:指Hive的hql和Spark的sql都可以用的UDF函数,一般编译成jar包
    • Spark类型的UDF函数:Spark专用的UDF,需要先建立好相应的scala/python脚本,通过scala或python函数来注册,注册之后也可以在sql中使用
  • 自定义函数 PythonUDF和ScalaUDF只能在Spark引擎中使用

    • python函数,基于python编写的函数
    • scala 函数,基于scala编写的函数

点击linkis管理台:首页>>UDF管理 UDF 的使用 - 图1

进入有”UDF管理”和”函数管理”两栏,其中在函数管理栏是一般的方法函数,比如python和scala函数,这种不需要注册即可在脚本里像普通函数一样使用,UDF则需要注册后才能使用。 UDF 的使用 - 图2

新增通用类型的UDF函数:

需要先编译好相应的Jar包,并上传至对应用户的工作空间中(如果是使用的dss全家桶,可以通过scriptis进行上传,如果单独至使用了linkis,需要手动上传至对应的目录)

UDF 的使用 - 图3

点击新增UDF按钮,有两种类型的UDF可以新增,选“通用”类型及为通过jar包方式注册,注册格式需要写UDF实现类的全限定类名。

UDF 的使用 - 图4

例如下图 UDFServiceImpl 的全限定类名就是:org.apache.linkis.udf.service.impl.UDFServiceImpl

UDF 的使用 - 图5

新增Spark类型的UDF函数:

如果是选择“spark”类型,则选择定义好的scala或python函数来注册,自定义函数需要写 scala 或 python 类型脚本。注册之后也可以在sql中使用,类似:select hello(“abc”)。

注意:

  1. 注册时应该填写新建脚本中的方法名。
  2. 新增udf后对应的jar包或者脚本内容会上传到bml存储。如果本地修改了资源需要更新后才能生效。

UDF 的使用 - 图6

点击对应udf的编辑按钮。

UDF 的使用 - 图7

如果需要更新udf的内容,则需要编辑该udf重新上传,并对该udf生成一个新的版本。如果脚本内容没有改变,而只是修改了其他内容如:使用格式,则只更新信息,不会生成新的版本。

UDF 的使用 - 图8

点击对应udf的删除按钮即可,注意:会删除该udf的所有版本。

UDF 的使用 - 图9

如果要使你创建的UDF生效在程序中使用,则需要加载该UDF。“加载”/“取消加载”的入口处为:进入scriptis左侧UDF函数->个人函数,创建的UDF均在个人函数列表处。

注1:新增UDF时如果没有在页面上主动取消勾选,则会默认勾选加载。此时需要kill掉对应引擎使之新起一个引擎,操作才会生效。

注2:加载/取消加载udf的操作,需要kill掉对应引擎使之新起一个引擎,操作才会生效。

列表中非个人函数介绍:

BDAP函数:由bdap创建的给用户使用的函数,如脱敏函数等。注:bdap函数需要主动加载才能使用。

系统函数:系统默认的自带函数,不需要用户自己加载就能在代码中使用。

共享函数:其他人共享给你的函数,你需要加载它就能使用

过期函数:也是共享函数,只不过共享者标记了它为过期,暂不影响使用

按照参数中的 ids 加载udf

参数名说明默认值
linkis.user.udf.all.load是否加载用户选中的所有 UDFtrue
linkis.user.udf.custom.idsUDF ID 列表,用 , 分隔-

调用样例:

  1. POST /api/rest_j/v1/entrance/submit
  2. Content-Type: application/json
  3. Token-Code: dss-AUTH
  4. Token-User: linkis
  5. {
  6. "executionContent": {
  7. "code": "show databases",
  8. "runType": "sql"
  9. },
  10. "params": {
  11. "configuration": {
  12. "startup": {
  13. "linkis.user.udf.all.load": false
  14. "linkis.user.udf.custom.ids": "1,2,3"
  15. }
  16. }
  17. },
  18. "labels": {
  19. "engineType": "spark-2.4.3",
  20. "userCreator": "linkis-IDE"
  21. }
  22. }

前提:共享功能需要用户为管理员才能使用,否则前端页面不会提供操作入口。

点击udf的共享按钮:会弹出内容框,输入你想要共享的用户列表(逗号分隔)。

注:共享给他人后需要他人主动加载该UDF才能使用。

共享之后,被共享用户可以在“共享函数”中找到,勾选加载即可使用。

如用户离职时可能需要移交个人udf给他人。点击移交按钮,选择你的移交对象,点击确定。

对于共享给他人的UDF,如果已经被共享用户所加载,则不能直接删除该udf,只能标记该udf为过期。暂时只作标记作用,不影响使用。

点击某udf的“版本列表”按钮,可以查看该udf的所有版本。对于每个版本提供如下功能:

创建新版本:将对应版本拷贝一份至最新版本。

下载:将udf文件从bml下载至本地。

查看源码:对于python/scala脚本类型则可以直接查看源码,jar类型不支持。

发布:共享udf可以对其点击发布某个版本,使该版本对被共享用户生效。注:被共享用户使用的是udf已发布的最新版本,个人用户使用的始终是最新版本。