SQL Server罕見問題及處理辦法分享。本站提示廣大學習愛好者:(SQL Server罕見問題及處理辦法分享)文章只能為提供參考,不一定能成為您想要的結果。以下是SQL Server罕見問題及處理辦法分享正文
寫在後面
在QQ群,微信群,論壇中常常協助運用SQL Server數據庫的冤家處理問題,但是有一些最罕見最根本的問題,每天都有人問,答復多了也不想再解答了,索性把這些問題整理一下,再有人問到直接發鏈接。
一時想法而寫這篇文章,問題能夠不片面,後續會不斷更新。
根底問題搜集資源下載
描繪:XX版本數據庫操作零碎在哪裡下載?
答:http://www.itellyou.cn/ 外面很多東西,有興味的自己看吧
銜接問題
描繪:數據庫銜接不上
答:請確認SQL服務能否啟動,用戶密碼能否正確,銜接的實例稱號,端口能否正確
日志問題
描繪:零碎日志LDF滿了 或 日志文件十分大 如何膨脹?
答:復雜恢復形式下SQL Server會自動截斷日志文件,完好形式下需求日志備份
恢復形式檢查
日志備份的方式
膨脹日志
查詢很久\很慢
描繪:查詢很久都查不出數據,很慢!
答:這樣的狀況呈現普通是查詢語句被其他語句阻塞。在查詢中添加 select * from table with (nolock)假如能查出來闡明阻塞
詳細的阻塞狀況 可以運用sp_who2 或許 sys.dm_exec_requests 視圖查詢
詳細腳本(檢查語句運轉狀況)
WITH sess AS ( SELECT es.session_id, database_name = DB_NAME(er.database_id), er.cpu_time, er.reads, er.writes, er.logical_reads, login_name, er.status, blocking_session_id, wait_type, wait_resource, wait_time, individual_query = SUBSTRING (qt.text, (er.statement_start_offset/2)+1, ((CASE WHEN er.statement_end_offset = -1 THEN LEN(CONVERT(NVARCHAR(MAX), qt.text)) * 2 ELSE er.statement_end_offset END - er.statement_start_offset)/2)+1), parent_query = qt.text, program_name, host_name, nt_domain, start_time, DATEDIFF(MS,er.start_time,GETDATE()) as duration, (SELECT query_plan FROM sys.dm_exec_query_plan(er.plan_handle)) AS query_plan FROM sys.dm_exec_requests er INNER JOIN sys.dm_exec_sessions es ON er.session_id = es.session_id CROSS APPLY sys.dm_exec_sql_text(er.sql_handle)as qt WHERE es.session_id > 50 AND es.session_Id NOT IN (@@SPID) ) SELECT * FROM sess UNION ALL SELECT es.session_id, database_name = '', 0, 0, 0, 0, login_name, es.status, 0, '', '', '', qt.text, parent_query = qt.text, program_name, host_name, nt_domain, es.last_request_start_time, DATEDIFF(MS,es.last_request_start_time,GETDATE()) as duration, NULL AS query_plan FROM sys.dm_exec_sessions es INNER JOIN sys.dm_exec_connections ec ON es.session_id = ec.session_id CROSS APPLY sys.dm_exec_sql_text(ec.most_recent_sql_handle)as qt WHERE ec.most_recent_session_id IN ( SELECT blocking_session_id FROM sess WHERE blocking_session_id NOT IN(SELECT DISTINCT session_id FROM sess) ) ORDER BY 1, 2
分區表問題
描繪:數據量千萬級別了運用分區表提升功能
答:分區表的運用場景次要是管理數據,而提升功能次要是靠IO並行,需求合理規劃多塊物理磁盤,大少數的場景下幾千萬數據單一的形式查詢只需求添加正確的索引即可。
高可用的選擇
答:SQL自帶的高可用或讀寫別離技術次要有:毛病轉移群集、發布訂閱、鏡像、日志傳送、AlwaysON可用組(詳細可以在進階問題的材料中詳細檢查)
普通選用讀寫別離需求依據不同的場景和要求,比方同步的實時性,讀寫別離功用的需求狀況
次要列出幾個優缺陷:
毛病轉移群集:主備形式,單活(輔佐機不可讀),硬件資源糜費,次要場景是數據庫的高可用。
發布訂閱:讀寫別離常用方式,配置靈敏,正本節點可以多個,可以發布訂閱局部數據(即可以對數據挑選),並提供多種發布訂閱形式,缺陷:維護比擬費事,普通不能用作高可用。
鏡像:主備形式,單活(輔佐機不可讀),硬件資源糜費,次要場景是數據庫的高可用。絕對於毛病轉移群集鏡像是數據庫級別的高可用。在鏡像中可以運用快照的方式完成讀寫別離。
日志傳送:次要用於災備,在備用機上可讀,但缺陷是日志復原時不能讀,讀時不能復原。
AlwaysON可用組:綜合性方案,滿足高可用、讀寫別離等需求,要求:SQL Server2012 以上版本
第三方產品:moebius負載平衡集群,完成雙活,讀負載平衡、讀寫別離等。缺陷實時同步不合適相似采集零碎的大規模寫入零碎。
服務無法啟動
答:服務無法啟動有很多緣由,需求詳細問題詳細定位,假如遇到此類問題要首先檢查日志定位問題,日志次要兩局部,SQL啟動日志和windows日志,上面給出兩篇經典解析SQL啟動的文章:
你所不知道的SQL Server數據庫啟動進程(用戶數據庫加載進程的疑問雜症)
你所不知道的SQL Server數據庫啟動進程,以及啟動不起來的各種問題的剖析及處理技巧
數據庫設計,表設計的問題
大少數這樣的問題,在QQ群裡問是基本得不到答案的,很多業務場景不是幾句話可以描繪清楚的。
SQL語句問題
描繪:SQL語句添加或許增加一個條件就變得很慢
答:SQL語句的運轉變化很奇妙,需求了解執行方案,幾句話或許貼個圖無法處理,一些語句的習氣是需求養成的,請參見:
SQL SERVER片面優化-------寫出好語句是習氣
SQL SERVER片面優化-------索引有多重要?
AlwaysOn配置問題
AlwaysOn配置問題請參見桦仔的幾篇十分細致的文章:
從0開端搭建SQL Server AlwaysOn 第一篇(配置域控)
從0開端搭建SQL Server AlwaysOn 第二篇(配置毛病轉移集群)
從0開端搭建SQL Server AlwaysOn 第三篇(配置AlwaysOn)
從0開端搭建SQL Server AlwaysOn 第四篇(配置異地機房節點)
2016的AlwaysOn 搭建:SQL SERVER 2016 AlwaysOn 無域集群+負載平衡搭建與簡測
AlwaysOn新建用戶
首先要明白AlwaysOn可用組中:
1.只要主節點是可以寫入的,輔佐節點只讀
2.權限分紅兩局部,實例級別“登錄名”和數據庫級別“用戶”
3.在主節點創立登錄稱號並選擇數據庫權限後,由於數據同步,所以從庫上曾經有了新創立用戶的數據庫權限,但是沒有登錄名。
4.不能在輔佐節點異樣的方式創立登錄名,這樣就是“用戶孤立”問題
處理辦法:
1.在主節點上直接添加的是“登錄名”,比方創立一個登錄名 KK
2.選擇數據庫權限及用戶映射
3.查詢方才創立“登錄名”的腳本(此腳本也可以用於晉級或遷移數據庫復原後,登錄名同步的問題)
CREATE PROCEDURE #sp_hexadecimal @binvalue varbinary(256), @hexvalue varchar (514) OUTPUT AS DECLARE @charvalue varchar (514) DECLARE @i int DECLARE @length int DECLARE @hexstring char(16) SELECT @charvalue = '0x' SELECT @i = 1 SELECT @length = DATALENGTH (@binvalue) SELECT @hexstring = '0123456789ABCDEF' WHILE (@i <= @length) BEGIN DECLARE @tempint int DECLARE @firstint int DECLARE @secondint int SELECT @tempint = CONVERT(int, SUBSTRING(@binvalue,@i,1)) SELECT @firstint = FLOOR(@tempint/16) SELECT @secondint = @tempint - (@firstint*16) SELECT @charvalue = @charvalue + SUBSTRING(@hexstring, @firstint+1, 1) + SUBSTRING(@hexstring, @secondint+1, 1) SELECT @i = @i + 1 END SELECT @hexvalue = @charvalue GO DECLARE @name sysname DECLARE @type varchar (1) DECLARE @hasaccess int DECLARE @denylogin int DECLARE @is_disabled int DECLARE @PWD_varbinary varbinary (256) DECLARE @PWD_string varchar (514) DECLARE @Principal_id int DECLARE @SID_varbinary varbinary (85) DECLARE @SID_string varchar (514) DECLARE @tmpstr varchar (1024) DECLARE @is_policy_checked varchar (3) DECLARE @is_expiration_checked varchar (3) DECLARE @defaultdb sysname DECLARE @language sysname DECLARE @rolename sysname DECLARE login_curs CURSOR FOR SELECT p.principal_id, p.sid, p.name, p.type, p.is_disabled, p.default_database_name, p.default_language_name, l.hasaccess, l.denylogin FROM sys.server_principals p LEFT JOIN sys.syslogins l ON ( l.name = p.name ) WHERE p.type IN ( 'S', 'G', 'U' ) AND p.name <> 'sa' OPEN login_curs FETCH NEXT FROM login_curs INTO @Principal_id, @SID_varbinary, @name, @type, @is_disabled, @defaultdb, @language, @hasaccess, @denylogin IF (@@fetch_status = -1) BEGIN PRINT 'No login(s) found.' CLOSE login_curs DEALLOCATE login_curs RETURN END SET @tmpstr = '** Generated ' + CONVERT (varchar, GETDATE()) + ' on ' + @@SERVERNAME + ' */' PRINT @tmpstr PRINT '' WHILE (@@fetch_status <> -1) BEGIN IF (@@fetch_status <> -2) BEGIN PRINT '' SET @tmpstr = '-- Login: ' + @name PRINT @tmpstr IF (@type IN ( 'G', 'U')) BEGIN -- NT authenticated account/group SET @tmpstr = 'CREATE LOGIN ' + QUOTENAME( @name ) + ' FROM WINDOWS WITH DEFAULT_DATABASE = [' + @defaultdb + '], DEFAULT_LANGUAGE = [' + @language + ']' END ELSE BEGIN -- SQL Server authentication -- obtain password and sid SET @PWD_varbinary = CAST( LOGINPROPERTY( @name, 'PasswordHash' ) AS varbinary (256) ) EXEC #sp_hexadecimal @PWD_varbinary, @PWD_string OUT EXEC #sp_hexadecimal @SID_varbinary,@SID_string OUT -- obtain password policy state SELECT @is_policy_checked = CASE is_policy_checked WHEN 1 THEN 'ON' WHEN 0 THEN 'OFF' ELSE NULL END FROM sys.sql_logins WHERE name = @name SELECT @is_expiration_checked = CASE is_expiration_checked WHEN 1 THEN 'ON' WHEN 0 THEN 'OFF' ELSE NULL END FROM sys.sql_logins WHERE name = @name SET @tmpstr = 'CREATE LOGIN ' + QUOTENAME( @name ) + ' WITH PASSWORD = ' + @PWD_string + ' HASHED, SID = ' + @SID_string + ', DEFAULT_DATABASE = [' + @defaultdb + '], DEFAULT_LANGUAGE = [' + @language + ']' IF ( @is_policy_checked IS NOT NULL ) BEGIN SET @tmpstr = @tmpstr + ', CHECK_POLICY = ' + @is_policy_checked END IF ( @is_expiration_checked IS NOT NULL ) BEGIN SET @tmpstr = @tmpstr + ', CHECK_EXPIRATION = ' + @is_expiration_checked END END IF (@denylogin = 1) BEGIN -- login is denied access SET @tmpstr = @tmpstr + '; DENY CONNECT SQL TO ' + QUOTENAME( @name ) END ELSE IF (@hasaccess = 0) BEGIN -- login exists but does not have access SET @tmpstr = @tmpstr + '; REVOKE CONNECT SQL TO ' + QUOTENAME( @name ) END IF (@is_disabled = 1) BEGIN -- login is disabled SET @tmpstr = @tmpstr + '; ALTER LOGIN ' + QUOTENAME( @name ) + ' DISABLE' END PRINT @tmpstr PRINT 'GO' DECLARE server_role_members_curs CURSOR FOR SELECT (SELECT [name] FROM sys.server_principals WHERE principal_id = role_principal_id) AS rolename FROM sys.server_role_members WHERE member_principal_id = @Principal_id OPEN server_role_members_curs FETCH NEXT FROM server_role_members_curs INTO @rolename WHILE (@@fetch_status <> -1) BEGIN SELECT @tmpstr = 'EXEC master..sp_addsrvrolemember @loginame = N''' + @name + ''', @rolename = N''' + @rolename + '''' PRINT @tmpstr PRINT 'GO' FETCH NEXT FROM server_role_members_curs INTO @rolename END CLOSE server_role_members_curs DEALLOCATE server_role_members_curs END FETCH NEXT FROM login_curs INTO @Principal_id, @SID_varbinary, @name, @type, @is_disabled, @defaultdb, @language, @hasaccess, @denylogin END CLOSE login_curs DEALLOCATE login_curs GO DROP PROCEDURE #sp_hexadecimal GO
4.找到查詢出的腳本,在輔佐節點運轉(其中次要的就是SID)
進階問題請大家點擊原文閱讀。
以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支持。