如何在远程计算机上获取任务历史记录?

时间:2018-04-03 08:32:03

标签: c# rpc taskscheduler

我正在尝试获取任务历史记录(当我在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: 

1 个答案:

答案 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)