您的位置:首页 > 理论基础

事件ID 18456:用户<域\计算机名>登录失败。 原因: 基于令牌的服务器访问验证失败,出现基础结构错误

2015-04-22 12:14 489 查看
事件类型: 审核失败

事件来源: MSSQLSERVER

事件种类: 登录 

事件 ID: 18456

日期: 2015-4-22

事件: 11:11:21

用户: 域\计算机名

计算机: 域

描述:

用户 '域\计算机名$' 登录失败。 原因: 基于令牌的服务器访问验证失败,出现基础结构错误。请检查以前的错误。 [客户端: 192.168.1.183]

有关更多信息,请参阅在 http://go.microsoft.com/fwlink/events.asp 的帮助和支持中心。

数据:

0000: 18 48 00 00 0e 00 00 00   .......

0008: 0c 00 00 00 53 00 5a 00   ....

0010: 31 00 43 00 41 00 52 00   

0018: 44 00 31 00 2d 00 44 00   

0020: 42 00 00 00 07 00 00 00   B......

0028: 6d 00 61 00 73 00 74 00   

0030: 65 00 72 00 00 00         e.r...  



分析及解决:

现在我们只知道是这台计算机: [域\计算机名 ],IP为:192.168.1.183 ,这台计算机要连接到当前的数据库服务器,才提示“审核失败”

但是不清楚是什么进程或服务连接过来的!所以这错误也没什么可分析了!~

现在打开 【Sql Server Profiler】监控以下事件,注意要选择列【ClientProcessID】

Error and Warnings \ ErrorLog

Error and Warnings \ ErrorLog



开启跟踪一段时间,直到出现该错误!~



这是可以看到 进程号 ClientProcessID=2136

登录到服务器 192.168.1.183 ,打开【任务管理器】找到 进程号ClientProcessID=2136 的服务



打开计算机服务,发现是这个服务是以“本地系统” 运行的,改为 域管理员或者其他账户运行,不再出现了! 

出现这种情况,大都是账户权限不足。

附加:(或者使用T-SQL跟踪)

-- Create a Queue
declare @rc int
declare @TraceID int
declare @maxfilesize bigint --跟踪文件的大小,单位是MB,默认不设置为5MB
declare @TraceFilePath nvarchar(500)-- 跟踪文件的路径
set @maxfilesize = 20
set @TraceFilePath=N'G:\ErrorLog_Trace'

exec @rc = sp_trace_create @TraceID output, 0,@TraceFilePath, @maxfilesize, NULL
if (@rc != 0) goto error

-- Set the events
declare @on bit
set @on = 1
exec sp_trace_setevent @TraceID, 22, 7, @on
exec sp_trace_setevent @TraceID, 22, 31, @on
exec sp_trace_setevent @TraceID, 22, 8, @on
exec sp_trace_setevent @TraceID, 22, 64, @on
exec sp_trace_setevent @TraceID, 22, 1, @on
exec sp_trace_setevent @TraceID, 22, 9, @on
exec sp_trace_setevent @TraceID, 22, 41, @on
exec sp_trace_setevent @TraceID, 22, 49, @on
exec sp_trace_setevent @TraceID, 22, 6, @on
exec sp_trace_setevent @TraceID, 22, 10, @on
exec sp_trace_setevent @TraceID, 22, 14, @on
exec sp_trace_setevent @TraceID, 22, 26, @on
exec sp_trace_setevent @TraceID, 22, 3, @on
exec sp_trace_setevent @TraceID, 22, 11, @on
exec sp_trace_setevent @TraceID, 22, 35, @on
exec sp_trace_setevent @TraceID, 22, 51, @on
exec sp_trace_setevent @TraceID, 22, 12, @on
exec sp_trace_setevent @TraceID, 22, 20, @on
exec sp_trace_setevent @TraceID, 22, 60, @on
exec sp_trace_setevent @TraceID, 21, 7, @on
exec sp_trace_setevent @TraceID, 21, 31, @on
exec sp_trace_setevent @TraceID, 21, 8, @on
exec sp_trace_setevent @TraceID, 21, 64, @on
exec sp_trace_setevent @TraceID, 21, 1, @on
exec sp_trace_setevent @TraceID, 21, 9, @on
exec sp_trace_setevent @TraceID, 21, 41, @on
exec sp_trace_setevent @TraceID, 21, 49, @on
exec sp_trace_setevent @TraceID, 21, 6, @on
exec sp_trace_setevent @TraceID, 21, 10, @on
exec sp_trace_setevent @TraceID, 21, 14, @on
exec sp_trace_setevent @TraceID, 21, 26, @on
exec sp_trace_setevent @TraceID, 21, 3, @on
exec sp_trace_setevent @TraceID, 21, 11, @on
exec sp_trace_setevent @TraceID, 21, 35, @on
exec sp_trace_setevent @TraceID, 21, 51, @on
exec sp_trace_setevent @TraceID, 21, 12, @on
exec sp_trace_setevent @TraceID, 21, 20, @on
exec sp_trace_setevent @TraceID, 21, 60, @on

-- Set the Filters
declare @intfilter int
declare @bigintfilter bigint

set @intfilter = NULL
exec sp_trace_setfilter @TraceID, 9, 0, 1, @intfilter

exec sp_trace_setfilter @TraceID, 10, 0, 7, N'SQL Server Profiler - 179c8ff5-5879-48dd-a4cc-921575b43b84'

-- Set the trace status to start
exec sp_trace_setstatus @TraceID, 1

-- display trace id for future references
select TraceID=@TraceID
goto finish

error:
select ErrorCode=@rc

finish:
go
/*
select * from ::fn_trace_getinfo(0)
select * from sys.traces
select * from ::fn_trace_gettable('G:\ErrorLog_Trace.trc',1)

select ClientProcessID,NTUserName,ApplicationName,HostName,LoginName,StartTime,TextData
from ::fn_trace_gettable('G:\ErrorLog_Trace.trc',1)

exec sp_trace_setstatus 2,0 --停止跟踪
exec sp_trace_setstatus 2,2 --删除跟踪

*/
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐