- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在尝试使用此项目中提供的 jpmml 级联库中的级联框架执行 pmml 模型 https://github.com/jpmml/jpmml-cascading
我已完成所有步骤,并能够使用 mvn clean install 命令生成 example-1.2-SNAPSHOT-job.jar。
但是,当我使用以下命令执行同一个 jar 时:
hadoop jar example-1.2-SNAPSHOT-job.jar /tmp/cascading/model.pmml file:///tmp/cascading/input.csv file:///tmp/cascading/output
由于无权在默认DEFAULT 队列上提交作业,我正处于exceptions 之下我们的 hadoop 集群中的队列仅出于管理目的而被阻止,普通用户无法在不提供队列名称的情况下运行 hadoop 作业。
Exception:
16/01/06 04:41:37 ERROR ipc.FailoverRPC: FailoverProxy: Failing this Call: submitJob for error(RemoteException): org.apache.hadoop.ipc.RemoteException(org.apache.hadoop.security.AccessControlException): **User test cannot perform operation SUBMIT_JOB on queue default.**
Please run "hadoop queue -showacls" command to find the queues you have access to .
at org.apache.hadoop.mapred.ACLsManager.checkAccess(ACLsManager.java:179)
at org.apache.hadoop.mapred.ACLsManager.checkAccess(ACLsManager.java:136)
at org.apache.hadoop.mapred.ACLsManager.checkAccess(ACLsManager.java:113)
at org.apache.hadoop.mapred.JobTracker.submitJob(JobTracker.java:4524)
at sun.reflect.GeneratedMethodAccessor17.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at org.apache.hadoop.ipc.WritableRpcEngine$Server$WritableRpcInvoker.call(WritableRpcEngine.java:481)
at org.apache.hadoop.ipc.RPC$Server.call(RPC.java:928)
at org.apache.hadoop.ipc.Server$Handler$1.run(Server.java:2000)
at org.apache.hadoop.ipc.Server$Handler$1.run(Server.java:1996)
at java.security.AccessController.doPrivileged(Native Method)
at javax.security.auth.Subject.doAs(Subject.java:415)
at org.apache.hadoop.security.UserGroupInformation.doAs(UserGroupInformation.java:1566)
at org.apache.hadoop.ipc.Server$Handler.run(Server.java:1994)
我看不到存储库中提供 hadoop 作业队列的位置。
谁能建议我如何传递 hadoop 作业队列名称?
注意:
I have tried to pass the property mapred.job.queue.name passing the queue name but still job is showing same error through command line and in the code itself.
I have also tried to run the job using oozie shell action node and passing the queue name there in application workflow but I believe that would be applicable for the oozie job only not the hadoop jobs which gets executed through shell action node.
最佳答案
您使用了错误的设置。您应该使用 Hadoop 2.x 的设置。
以下配置属性(存在于 mapred-site.xml
中)控制对作业队列的提交。
Hadoop 1.x
mapred.acls.enabled
:是否应启用 ACL 检查以在执行队列操作时检查用户的权限。默认设置为 false
。
mapred.job.queue.name
:作业提交到的队列。默认值为 default
。
Hadoop 2.x
mapreduce.cluster.acls.enabled
:是否应启用 ACL 检查以在执行队列操作时检查用户的权限。默认设置为 false
。
mapreduce.job.queuename
:作业提交到的队列。默认值为 default
。
您可以通过不同的方式设置这些值:
-D
选项传递。例如您可以将其作为 -Dmapreduce.job.queuename=default
传递。在作业的 Driver
中设置它 (Hadoop 2.x):
Configuration conf = new Configuration();
conf.set("mapreduce.job.queuename", "default");
Job job = Job.getInstance(conf, "JobName");
mapred-site.xml
文件中设置。关于hadoop - 如何在 jpmml 级联中传递 Hadoop 作业队列名称?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34632690/
我在 JPMML (scala) 中使用带有许多输入字段的 PMML 模型时遇到问题。下面是一个最小的示例:加载 300x150 像素的图像并将其用作 PCA (python) 的输入: img =
我有一个 scikit 模型,正在使用 JPMML 在我的 java 应用程序中使用。我尝试使用训练期间使用的列的名称来设置 InputFields,但“inField.getName().getVa
我正在尝试使用此项目中提供的 jpmml 级联库中的级联框架执行 pmml 模型 https://github.com/jpmml/jpmml-cascading 我已完成所有步骤,并能够使用 mvn
今天,我使用 Jpmml 在我的代码中加载 pmml 模型。但“评估”方法需要很长时间。这是今天的工作代码: String modelPath = "...."; ModelEvalu
我有一个从 SAS Miner 生成的 PMML,我无法使用 JPMML 1.1.4 对其进行正确评估。 JPMML 1.1.4 表示它支持 PMML 4.2,而 PMML 表示它是 PMML 4.2
我是一名优秀的程序员,十分优秀!