我正在尝试获取任务历史记录(当我在GetTaskFromRemoteServer方法中获取同一远程计算机的任务列表时,它正在运行)但每次程序到达“ Console.WriteLine(日志。第一个()。级别)“行,我得到以下异常:System.Diagnostics.Eventing.Reader。 EventLogException 。当我查看错误消息时,它显示“ RPC服务器不可用”。 我检查了RPC服务,它正在运行。
我正在使用David Hall创建的TaskScheduler包( v.2.8.0 )。关于TaskEventLog构造函数,它说“如果使用指定远程计算机的TaskEventLog构造函数,则需要使用模拟登录具有远程计算机权限的帐户”。我想我可能会在这里遗漏一些东西。我不确定我是否正确地执行此部分(使用模拟登录到具有远程计算机权限的帐户)。
public void GetTaskFromRemoteServer(string taskname, string servername, string username, string password, string folderName = null)
{
using (TaskService ts = new TaskService(servername, username, DOMAIN, password))
{
Console.WriteLine("Listing tasks from the following server: " + servername);
TaskFolder tf;
if(folderName != null) tf = ts.GetFolder(folderName);
else tf = ts.RootFolder;
foreach (Task task in tf.Tasks)
{
string curTaskName = task.Name;
if (curTaskName == taskname)
{
Console.WriteLine(curTaskName);
GetTaskHistory(servername, task.Path, username, password);
}
}
}
}
public void GetTaskHistory(string servername, string taskPath, string username, string password)
{
TaskEventLog log = new TaskEventLog(servername, taskPath, DOMAIN, username, password);
Console.WriteLine(log.First().Level);
Console.WriteLine(log.First().TimeCreated.ToString());
Console.WriteLine(log.First().EventId.ToString());
}
Stacktrace:
L'exception System.Diagnostics.Eventing.Reader.EventLogException n'a pas été gérée
HResult=-2146233088
Message=Le serveur RPC n’est pas disponible
Source=System.Core
StackTrace:
à System.Diagnostics.Eventing.Reader.EventLogException.Throw(Int32 errorCode)
à System.Diagnostics.Eventing.Reader.NativeWrapper.EvtQuery(EventLogHandle session, String path, String query, Int32 flags)
à System.Diagnostics.Eventing.Reader.EventLogReader..ctor(EventLogQuery eventQuery, EventBookmark bookmark)
à System.Diagnostics.Eventing.Reader.EventLogReader..ctor(EventLogQuery eventQuery)
à Microsoft.Win32.TaskScheduler.TaskEventLog.GetEnumerator(Boolean reverse)
à Microsoft.Win32.TaskScheduler.TaskEventLog.System.Collections.Generic.IEnumerable<Microsoft.Win32.TaskScheduler.TaskEvent>.GetEnumerator()
à System.Linq.Enumerable.First[TSource](IEnumerable`1 source)
à TaskSchedulerWatcher.TaskSchedulerAccess.GetTaskHistory(String servername, String taskPath, String username, String password) dans c:\Users\abc\Documents\Workspace\TaskSchedulerWatcher\TaskSchedulerWatcher\TaskSchedulerAccess.cs:ligne 49
à TaskSchedulerWatcher.TaskSchedulerAccess.GetTaskFromRemoteServer(String taskname, String servername, String username, String password, String folderName) dans c:\Users\abc\Documents\Workspace\TaskSchedulerWatcher\TaskSchedulerWatcher\TaskSchedulerAccess.cs:ligne 38
à TaskSchedulerWatcher.Program.Main(String[] args) dans c:\Users\abc\Documents\Workspace\TaskSchedulerWatcher\TaskSchedulerWatcher\Program.cs:ligne 18
à System.AppDomain._nExecuteAssembly(RuntimeAssembly assembly, String[] args)
à System.AppDomain.ExecuteAssembly(String assemblyFile, Evidence assemblySecurity, String[] args)
à Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly()
à System.Threading.ThreadHelper.ThreadStart_Context(Object state)
à System.Threading.ExecutionContext.RunInternal(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
à System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
à System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
à System.Threading.ThreadHelper.ThreadStart()
InnerException:
答案 0 :(得分:0)
假设您拥有正确的凭据,我认为这将成为防火墙问题或远程计算机上的Windows设置。
RPC服务器不可用
从远程计算机和其他各种事物访问事件查看器似乎是一个常见问题,而不仅仅局限于基于
的EventLogReader
谷歌上有很多点击,大多数指向防火墙。 id首先应用以下防火墙规则并向后工作。或者测试完全禁用它
COM +网络访问(DCOM-In)
远程事件日志管理(NP-In)
远程事件日志管理(RPC)
远程事件日志管理(RPC-EPMAP)
Windows Management Instrumentation(ASync-In)
Windows Management Instrumentation(DCOM-In)
Windows Management Instrumentation(WMI-In)