昨天刚装好了oracle10g却总是碰到RemoteOperationException: ERROR: Wrong password for user;

解决Oracle 10g 错误密码问题
本文解决了在使用Oracle 10g OEM过程中遇到的RemoteOperationException: ERROR: Wrong password for user问题。通过调整本地安全策略,为所需用户分配Logon as a Batch Job权限来解决该问题。


昨天刚装好了oracle10g却总是碰到RemoteOperationException: ERROR: Wrong password for user;
查了半天也没搞懂为什么,明明用户和密码是对的。后来看一位网友发的文章才明白是本地策略的问题。

现抄录下来供大家参考:

在OEM中有些操作需要输入操作系统的用户名密码才能继续下去,但是以前无论怎样输入,总是会返回RemoteOperationException: ERROR: Wrong password for user.(错误的用户名密码)的错误。
今天好好的查了一下,终于明白了问题的所在。

解决的方法就是在用户策略里面将你需要使用的用户授予Logon as a Batch Job的权限。

1. Click on START => Programs => Administrative Tools => Local Security Policy (or also via START => Settings => Control Panel => Administrative Tools) 打开控制面板中的管理工具中的本地安全策略
2. Under Local Policies on the left, select User Rights Assignment folder
然后是本地策略-用户权限分配
3. Look at the right side of the window and scroll down to the "Logon as Batch Job" privilege and select it. 然后找到Logon as a Batch Job(作为批处理作业登陆)这一项
4. Either select Action from the menu bar then Security or right-click on the "Logon as a Batch Job" privilege then Security.
5. Select the Add button which evokes a Select Users/Groups box.
6. From the "Look In" field, select the local workstation/server.
7. Select the User administrator.
8. Select Add then OK.
然后打开将administrator这个用户添加一下就ok了!  

public bool StartJob(string jobName, Dictionary<int, NMC.Scheduling.Route> routes, string src, string dest, int cycleNum, string mode, bool isProcess, bool isUnload, bool isHigh, string runID, Dictionary<string, string> preProcesses, string category, ref string err) { try { err = ""; bool needCool = false; foreach (KeyValuePair<int, NMC.Scheduling.Route> kvp in routes) { this.GetLogger().WarnFormat("Slot{{0}}: Route({1})", kvp.Key, kvp.Value.Name); for (int i = 0; i < kvp.Value.GetStepNum(); ++i) { this.GetLogger().WarnFormat(" Step({0})", i); bool containCoolingChamber = false; bool allCoolingChamberOK = true; for (int j = 0; j < kvp.Value.RouteSteps[i].GetVisitNum(); ++j) { this.GetLogger().WarnFormat(" Visit({0}).StationName: {1}", j, kvp.Value.RouteSteps[i].GetVisit(j).StationName); this.GetLogger().WarnFormat(" Visit({0}).SlotID: {1}", j, kvp.Value.RouteSteps[i].GetVisit(j).SlotID); this.GetLogger().WarnFormat(" Visit({0}).ProcessRecipe: {1}", j, kvp.Value.RouteSteps[i].GetVisit(j).ProcessRecipe); if (!string.IsNullOrEmpty(kvp.Value.RouteSteps[i].GetVisit(j).ProcessRecipe)) { this.mCtrlNodes[this.mUniqueCtrlNode].GetRecipeInfo("SCOPE", kvp.Value.RouteSteps[i].GetVisit(j).ProcessRecipe); // RemoteOperationException, yangy 20170605: check recipe exist or not } // <><><> yangy: add 'else' check ??? post alarm when no process recipe attached <><><> // xianghf_20191015, for CXMT: wafer need be cool down before move to LL // when ChA/ChB were set as cooling chamber, but no recipe is linked to ChA where ChA parallel with ChB in sequence // if (this.mCoolingChkEnabled) { if (this.mHighTempModules.Contains(kvp.Value.RouteSteps[i].GetVisit(j).StationName)) { needCool = true; // 并行chamber中任意一chamber为high, 则设置needCool为true } if (this.mCoolingModules.Contains(kvp.Value.RouteSteps[i].GetVisit(j).StationName)) //&& !string.IsNullOrEmpty(kvp.Value.RouteSteps[i].GetVisit(j).ProcessRecipe)) { containCoolingChamber = true; for (int p = 0; p < kvp.Value.RouteSteps[i].GetVisitNum(); ++p) { if (!this.mCoolingModules.Contains(kvp.Value.RouteSteps[i].GetVisit(p).StationName)) { allCoolingChamberOK = false; break; } else if (string.IsNullOrEmpty(kvp.Value.RouteSteps[i].GetVisit(p).ProcessRecipe)) { allCoolingChamberOK = false; break; } } } } } if (this.mCoolingChkEnabled) { // 并行chamber中所有cooling chamber必须link recipe if (containCoolingChamber && allCoolingChamberOK) { needCool = false; } } } if (needCool) { this.GetLogger().ErrorFormat("Coordinator::StartJob(): There is NO cooling recipe in job '{0}'.", jobName); #if SCOPE_LANG_CH { err = string.Format("任务 '{0}' 中缺少冷却工艺步骤!", jobName); AlarmManager.GetIns().PostAlarmAndForget(string.Format("{0}[{1}]", jobName, runID), AlarmType.StartJobFailed, string.Format("'{2}'关联的任务'{0}[{1}]'启动失败!", jobName, runID, src), err); } #else { err = string.Format("There is NO cooling recipe in job '{0}'.", jobName); AlarmManager.GetIns().PostAlarmAndForget(string.Format("{0}[{1}]", jobName, runID), AlarmType.StartJobFailed, string.Format("Start job '{0}[{1}]' on '{2}' failed!", jobName, runID, src), err); } #endif // AlarmManager.GetIns().PostAlarmAndForget(string.Format("{0}[{1}]", jobName, runID), AlarmType.StartJobFailed, string.Format("Start job '{0}[{1}]' on '{2}' failed!", jobName, runID, src), err); return false; } } // <><><> check dup base on 'jobName' if (TaskManager.GetIns().GetTaskID(jobName) > 0) { this.GetLogger().ErrorFormat("Coordinator::StartJob(): Job named '{0}' has been existed.", jobName); #if SCOPE_LANG_CH { err = string.Format("任务 '{0}' 已经存在!", jobName); AlarmManager.GetIns().PostAlarmAndForget(string.Format("{0}[{1}]", jobName, runID), AlarmType.StartJobFailed, string.Format("'{2}'关联的任务'{0}[{1}]'启动失败!", jobName, runID, src), err); } #else { err = string.Format("Job '{0}' has been existed.", jobName); AlarmManager.GetIns().PostAlarmAndForget(string.Format("{0}[{1}]", jobName, runID), AlarmType.StartJobFailed, string.Format("Start job '{0}[{1}]' on '{2}' failed!", jobName, runID, src), err); } #endif //err = string.Format("Job '{0}' has been existed.", jobName); //AlarmManager.GetIns().PostAlarmAndForget(string.Format("{0}[{1}]", jobName, runID), AlarmType.StartJobFailed, string.Format("Start job '{0}[{1}]' on '{2}' failed!", jobName, runID, src), err); return false; } if (TaskManager.GetIns().IsOverridePreJob(src, routes)) { this.GetLogger().ErrorFormat("Coordinator::StartJob(): Job named '{0}' overrides the previous job.", jobName); #if SCOPE_LANG_CH { err = string.Format("任务 '{0}'与已其它任务有重合!", jobName); AlarmManager.GetIns().PostAlarmAndForget(string.Format("{0}[{1}]", jobName, runID), AlarmType.StartJobFailed, string.Format("'{2}'关联的任务'{0}[{1}]'启动失败!", jobName, runID, src), err); } #else { err = string.Format("Job '{0}' overrides the previous job.", jobName); AlarmManager.GetIns().PostAlarmAndForget(string.Format("{0}[{1}]", jobName, runID), AlarmType.StartJobFailed, string.Format("Start job '{0}[{1}]' on '{2}' failed!", jobName, runID, src), err); } #endif //err = string.Format("Job '{0}' overrides the previous job.", jobName); //AlarmManager.GetIns().PostAlarmAndForget(string.Format("{0}[{1}]", jobName, runID), AlarmType.StartJobFailed, string.Format("Start job '{0}[{1}]' on '{2}' failed!", jobName, runID, src), err); return false; } } catch (Exception ex) { this.GetLogger().ErrorFormat("Coordinator::StartJob(): {0}", ex.Message); err = ex.Message; #if SCOPE_LANG_CH { AlarmManager.GetIns().PostAlarmAndForget(string.Format("{0}[{1}]", jobName, runID), AlarmType.StartJobFailed, string.Format("'{2}'关联的任务'{0}[{1}]'启动失败!", jobName, runID, src), err); } #else { AlarmManager.GetIns().PostAlarmAndForget(string.Format("{0}[{1}]", jobName, runID), AlarmType.StartJobFailed, string.Format("Start job '{0}[{1}]' on '{2}' failed!", jobName, runID, src), err); } #endif //AlarmManager.GetIns().PostAlarmAndForget(string.Format("{0}[{1}]", jobName, runID), AlarmType.StartJobFailed, string.Format("Start job '{0}[{1}]' on '{2}' failed!", jobName, runID, src), err); return false; } // <><> yangy 20160505: add Time Synchronizer check //// try { if (TimeSynchronizer.GetIns().CriticalZoneBegin(ref err)) { return TaskManager.GetIns().StartTask(new Job(jobName, routes, src, dest, cycleNum, (JobMode)Enum.Parse(typeof(JobMode), mode), isProcess, isUnload, isHigh, runID, preProcesses, "", category)); } return false; } catch (Exception ex) { this.GetLogger().ErrorFormat("Coordinator::StartJob(): {0}", ex.Message); #if SCOPE_LANG_CH { AlarmManager.GetIns().PostAlarmAndForget(string.Format("{0}[{1}]", jobName, runID), AlarmType.StartJobFailed, string.Format("'{2}'关联的任务'{0}[{1}]'启动失败!", jobName, runID, src), err); } #else { AlarmManager.GetIns().PostAlarmAndForget(string.Format("{0}[{1}]", jobName, runID), AlarmType.StartJobFailed, string.Format("Start job '{0}[{1}]' on '{2}' failed!", jobName, runID, src), err); } #endif //err = ex.Message; //AlarmManager.GetIns().PostAlarmAndForget(string.Format("{0}[{1}]", jobName, runID), AlarmType.StartJobFailed, string.Format("Start job '{0}[{1}]' on '{2}' failed!", jobName, runID, src), err); return false; } finally { TimeSynchronizer.GetIns().CriticalZoneEnd(); } }
09-03
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值