我正在尝试运行 oozie 工作流,但出现以下错误:
E0701:XML 架构错误,cvc-pattern-valid:值“模型和映射表更新”对于模式“([a-zA-Z_]([\-_a- zA-Z0-9])*){1,39}' 用于类型 'IDENTIFIER'。
我在查询中使用以下正则表达式。这有什么问题吗?当我通过 Hive 或 CLI 运行时一切正常。
regexp_replace(id_col, '^0|[a-zA-Z]+$', '')
下面是我的workflow.xml
<workflow-app name="proj_map" xmlns="uri:oozie:workflow:0.4">
<start to="sources_creation"/>
<action name="sources_creation">
<hive xmlns="uri:oozie:hive-action:0.2">
<job-tracker>${jobTracker}</job-tracker>
<name-node>${nameNode}</name-node>
<script>/user/sin/oozie/sources_creation.hql</script>
</hive>
<ok to="mockup and mapping table update"/>
<error to="kill"/>
</action>
<action name="mockup and mapping table update">
<hive xmlns="uri:oozie:hive-action:0.2">
<job-tracker>${jobTracker}</job-tracker>
<name-node>${nameNode}</name-node>
<script>/user/sin/oozie/project_mapping.hql</script>
</hive>
<ok to="end"/>
<error to="kill"/>
</action>
<kill name="kill">
<message>Action failed, error message[${wf:errorMessage(wf:lastErrorNode())}]</message>
</kill>
<end name="end"/>
</workflow-app>
最佳答案
Action 名称不能有空格。 <action name="mockup and mapping table update"\> .从操作名称中删除空格。它应该在之后工作。
关于hadoop - E0701 : XML schema error, cvc-pattern-valid oozie 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42197195/
1.1.1 YARN的介绍 为克服Hadoop1.0中HDFS和MapReduce存在的各种问题⽽提出的,针对Hadoop1.0中的MapReduce在扩展性和多框架⽀持⽅⾯的不⾜,提出了全新的资源管理框架YARN. ApacheYARN(YetanotherResourceNegotiator的缩写)是Hadoop集群的资源管理系统,负责为计算程序提供服务器计算资源,相当于⼀个分布式的操作系统平台,⽽MapReduce等计算程序则相当于运⾏于操作系统之上的应⽤程序。 YARN被引⼊Hadoop2,最初是为了改善MapReduce的实现,但是因为具有⾜够的通⽤性,同样可以⽀持其他的分布式计算模
目录:一、简介二、HQL的执行流程三、索引四、索引案例五、Hive常用DDL操作六、Hive常用DML操作七、查询结果插入到表八、更新和删除操作九、查询结果写出到文件系统十、HiveCLI和Beeline命令行的基本使用十一、Hive配置一、简介Hive是一个构建在Hadoop之上的数据仓库,它可以将结构化的数据文件映射成表,并提供类SQL查询功能,用于查询的SQL语句会被转化为MapReduce作业,然后提交到Hadoop上运行。特点:简单、容易上手(提供了类似sql的查询语言hql),使得精通sql但是不了解Java编程的人也能很好地进行大数据分析;灵活性高,可以自定义用户函数(UDF)和
在我的大多数应用程序中,我都有一个current_user方法。为了避免像current_user.name这样的情况出现异常,其中current_user是nil,rails提供了try方法。这个问题是我需要记住在current_user可能是nil的地方使用try。我想使用NullObject模式来消除这种额外的开销。classNullUserdefmethod_missing(method_name,*args)nilendenddefcurrent_userreturnNullUser.newunlessUserSession.find@current_user||=UserS
云计算实验中要求我们在Linux系统安装Hadoop,故来做一个简单的记录。· 注:我的操作系统环境是Ubuntu-20.04.3,安装的JDK版本为jdk1.8.0_301,安装的Hadoop版本为hadoop2.7.1。(不确定其他版本是否会出现版本兼容问题)Hadoop安装步骤如下: 一、更新apt和安装vim编辑器 二、配置本机无密码登录SSH 三、安装JAVA环境 四、下载安装Hadoop 五、伪分布式搭建一、更新apt和安装vim编辑器1、更新aptsudoapt-getupdate2、安装vim
一、设置免密登录1、系统偏好设置-----共享----勾选远程登录,所有用户2、打开终端,输入命令ssh-keygen-trsa,一直回车即可2.查看生成的公钥和私钥 cd~/.ssh ls会看到~/.ssh目录下有两个文件:①私钥:id_rsa②公钥:id_rsa.pub3.将公钥内容写入到~/.ssh/authorized_keys中 cat~/.ssh/id_rsa.pub>>~/.ssh/authorized_keys4.测试在terminal终端输入 sshlocalhost如果出现以下询问输入yes,不需要输入密码就能登录,说明配置成功Areyousureyouw
常见的1种case记录一下,新电脑安装androidstudio导入公司那些gradle还是5.5左右的工程以后,各种不适应。编译问题出现了。老电脑都是好好的。cvc-complex-type.2.4.a:发现了以元素‘base-extension‘开头的无效内容。应以‘{layoutlib}‘之一开头这样的错误。解决方案:小齿轮->projectstructure->SDKLocation->(JDKlocationwasmovedtoGradleSettings)点击GradleSettings。或者AndroidStudio->Preferences->搜索Gradle->GradleJ
我对JS世界比较陌生。我习惯用QT编写UI(构建UI的好工具!)。使用QT,我正在为每个元素创建一个类:如果我有一个包含一些元素的表,我有一个用于每个元素的类和一个用于表的类(可能也用于行)。每个类都包含数据和操作其“DOM”的方法。现在在html中,我正在使用一些在div上包含空骨架的ejs文件,我正在编写一个类以通过jquery对其进行操作。例如:用户列表.ejs:functionUsersList(path){this.path=path;$('#userList>tbody').empty();this.loadAjax();}UsersList.prototype.loadA
我正在使用D3javascript库来呈现一些基本的网络图表。我要加三个的元素block,但D3将元素添加到的末尾阻止。这是完整的html源代码:varchartData=[1,2,3];d3.select("html").select("body").append("svg").data(chartData,function(d){console.log("datad:",d);returnd;}).enter().append("path").attr("d",function(d){returnd;});Chrome的开发者控制台显示生成的html是:varchartData=[
在Stefanov的JSDesignPatterns一书中,他写道“你使用一个var语句并声明多个以逗号分隔的变量”,然后给出了一个“单一var”模式的示例,如下所示:functionfunc(){vara=1,b=2,sum=a+b,myobject={},i,j;Stefanov还写道:“在声明变量时也使用初始值对其进行初始化是一种很好的做法。”“您也可以在声明时做一些实际工作,例如前面代码中sum=a+b的情况。”现在我有一些代码如下,使用单个var模式声明了相同数量的变量,但做了更多的“声明时的实际工作”:varhtml='{purchaseQty}FR: {from
我收到以下代码的linting错误-“错误意外的空对象模式no-empty-pattern”。有谁知道如何解决这个问题?它是一个tsx文件。conststateToProps=({},{data=[],filters={},staticFilters=[{}]})=>{constallFilters=staticFilters?Object.assign({},filters,...staticFilters):filters;constnewData=getFilteredRows(allFilters,data);return{data:newData,unfilteredData