TCMEventLog.NTEventLog.1中发生错误:ReportEvent失败

Nic*_*kov 7 tridion

我正在使用Tridion 2009 SP1.我正在尝试做的是在组件完成某个工作流程过程后启动一个事件.直觉上我尝试使用OnProcessInstanceFinishPost事件,但是,当用户(admin)显式单击"Finish Process"时,才会触发此事件; 当所有活动完成并且"到达'停止'标志结束标记(如在Visio图中)之后,该过程正常完成时,不会触发此事件.

所以我使用了OnActivityInstanceFinishPost事件.问题是在OnActivityInstanceFinishPost事件中我得到记录器并尝试记录一条简单的消息,例如"Hello World",但事件查看器总是显示错误:"TCMEventLog.NTEventLog.1中发生错误:ReportEvent失败".并且事件没有被执行.

请注意,在OnProcessInstanceFinishPost事件中,完全相同的代码可以正常工作而不会出错.

我已经检查过这是否是身份用户权限的问题,但用户是Tridion的管理员,所以这不可能.我已经检查了SDLTridionworld论坛,但没有运气,当然,我已经将代码简化为一个日志记录语句,以确保它不是我的代码中的东西.

这是代码:

public void OnActivityInstanceFinishPost(ActivityInstance ActivityInstance, string finishMessage, string nextActivity, string dynamicAssignee)
{
    TDSE tdse = new TDSEClass() as TDSE;
    tdse.Impersonate(_identity);
    tdse.Initialize();

    Logging logger = tdse.GetLogging() as Logging;

    logger.LogEvent("Entered event OnActivityInstanceFinishPost. nextActivity="+nextActivity, EnumSeverity.severityInfo, EnumEventCategory.EVENT_CATEGORY_EVENT_SYSTEM);
}
Run Code Online (Sandbox Code Playgroud)

这是完整的错误:

Log Name:      Tridion Content Manager
Source:        Kernel
Date:          4/9/2012 10:14:07 PM
Event ID:      100
Task Category: Logging
Level:         Error
Keywords:      Classic
User:          SYSTEM
Computer:      xxxxxxxxxxxxxx
Description:
An error occured in TCMEventLog.NTEventLog.1:
ReportEvent failed.
Event Xml:
<Event xmlns="http://schemas.microsoft.com/win/2004/08/events/event">
  <System>
    <Provider Name="Kernel" />
    <EventID Qualifiers="49152">100</EventID>
    <Level>2</Level>
    <Task>9</Task>
    <Keywords>0x80000000000000</Keywords>
    <TimeCreated SystemTime="2012-04-10T03:14:07.000Z" />
    <EventRecordID>546126</EventRecordID>
    <Channel>Tridion Content Manager</Channel>
    <Computer>xxxxxxxxxxxxxxxxxxxxxxxxx</Computer>
    <Security UserID="S-1-5-18" />
  </System>
  <EventData>
    <Data>An error occured in TCMEventLog.NTEventLog.1: ReportEvent failed.</Data>
  </EventData>
</Event>
Run Code Online (Sandbox Code Playgroud)

Dom*_*nin 2

该错误表明 Tridion 无法写入日志消息。我假设您已经有一些证据表明这是由工作流活动完成触发的。

我不知道是什么导致了错误,但对于日志记录失败,通常与权限有关。

这将取决于您的工作流程,哪个用户实际触发 OnActivityInstanceFinishPost 事件。如果该活动由用户手动完成,则该用户将是执行该事件的 Windows 身份(或者如果配置了 Tridion 模拟,则为模拟用户)。如果它是自动活动,那么它将由为工作流代理服务配置的身份执行。我建议检查每个帐户是否能够正确登录。