搜尋本站文章

2017-08-19

[Windows] PING add timestamp - 加上時間戳記


PING 是一項診斷網路連線狀態的基礎工具。

但回傳結果是未包含 timestamp(時間戳記) 值,可以使用以下方式加入,這對於之後的追蹤除錯是很有用的。




範例:PING add timestamp - 加上時間戳記



下載範例檔案
20170819_PING add timestamp.txt

參數說明

192.168.1.1 請修改 IP 值,本範例的 IP 是 192.168.1.1
C:\Temp\PingTest_01.txt 請修改為適合的資料檔案存放路徑
-n 2 設定 要傳送的回應要求數目,本範例設定為 2 。預設值為 4。
例如:-n 100
測試傳送 100 個封包,可以此觀察回應時間的:最小值、最大值、平均值、已傳送、已收到、已遺失(是否有掉包)。

注意事項
1. 在 CMD 命令列視窗,使用 Run_as_administrator (以系統管理者身分執行) 來執行。




示範畫面

-- 040_執行_Ping_TimeStamp



-- 041_執行_Ping_TimeStamp_ENG



-- 050_執行PING_TimeStamp_檔案_內容



-- 051_執行PING_TimeStamp_檔案_內容_ENG



-- 060_PING_TimeStamp_Notepad_1



-- 061_PING_TimeStamp_Notepad__ENG



-- 070_PING_TimeStamp_Notepad_2



-- 071_PING_TimeStamp_Notepad_2_ENG



-- 100_預設 PING 的執行結果



-- 200_以系統管理者身分執行



-- 201_Run_as_administrator



-- 250_n為10,觀察封包的回應狀態






參考資料

Ping
https://technet.microsoft.com/EN-US/library/bb490968.aspx

6 Ways to Timestamp Ping Results
https://www.raymond.cc/blog/timestamp-ping-with-hrping/

Ping with timestamp
https://stackoverflow.com/questions/24906268/ping-with-timestamp
























2017-08-18

[PowerShell] Identify SSD


PowerShell:使用 Get-PhysicalDisk 指令的 MediaType,找出磁碟是否為 SSD


範例01:Identify SSD

# Identify SSD
Get-PhysicalDisk | Select FriendlyName, MediaType, BusType


-- 01_Get-PhysicalDisk 識別SSD



範例02:Getting all physical disks

# Getting all physical disks
Get-PhysicalDisk



-- 02_Get-PhysicalDisk




範例03:Getting all information from all physical disks

# Getting all information from all physical disks
Get-PhysicalDisk | Select *



-- 03_查詢全部磁碟的各項資訊






-- 10_VM_Get-PhysicalDisk



-- 11_VM_Get-PhysicalDisk


-- 12_VM_Get-PhysicalDisk_SELECT





參考資料

PowerTip: Use PowerShell to Identify SSD
https://blogs.technet.microsoft.com/heyscriptingguy/2013/03/17/powertip-use-powershell-to-identify-ssd/

Configuring Storage Spaces with a NVDIMM-N write-back cache
https://docs.microsoft.com/en-us/sql/relational-databases/performance/configuring-storage-spaces-with-a-nvdimm-n-write-back-cache

Determining Disk Type with Get-PhysicalDisk
https://www.pdq.com/blog/determining-disk-type-with-get-physicaldisk/

2017-08-09

[SQL Server] SSMS 17.2, Performance Dashboard built-in, 中文版本


SQL Server Management Studio(SSMS) 17.2  內建 Performance Dashboard(效能儀表板)
適用:SQL Server 2008 到 SQL Server 2017

-- 113_新增_效能儀表板



-- 114_中文版本的效能儀表板



-- 112_關於 SSMS 17.2





安裝與功能展示

安裝 SSMS 17.2 中文版本
https://goo.gl/photos/TZHqVjLHqrdh48xK7



參考資料

Download SQL Server Management Studio 17.2
https://docs.microsoft.com/en-us/sql/ssms/download-sql-server-management-studio-ssms

New in SSMS: Performance Dashboard built-in
https://blogs.msdn.microsoft.com/sql_server_team/new-in-ssms-performance-dashboard-built-in/

SQL Server Management Studio - Changelog (SSMS)
https://docs.microsoft.com/en-us/sql/ssms/sql-server-management-studio-changelog-ssms

[SQL Server] Performance Dashboard Reports - CPU bottlenecks, IO bottlenecks, missing Index ,Blocking, Latch
http://sharedderrick.blogspot.tw/2017/07/sql-server-performance-dashboard.html

[SQL Server] Performance Dashboard Reports - Reports Demo
http://sharedderrick.blogspot.tw/2017/07/sql-server-2012-performance-dashboard.html

下載與安裝 SSMS 17.1 中文版本
http://sharedderrick.blogspot.tw/2017/05/ssms-171.html

2017-08-06

[SQL Server] sp_whoisactive: find out long running queries (找出費時、耗資源的查詢) (2)


延續 先前文章:[SQL Server] sp_whoisactive: find out long running queries (找出費時、耗資源的查詢)


補充 常用的範例

-- EX01_sp_WhoIsActive:增加顯示 執行計畫、交易資訊、封鎖資訊等
USE master
GO
EXEC sp_WhoIsActive @get_plans=1, @get_transaction_info=1, @find_block_leaders=1
GO
 
-- EX02_sp_WhoIsActive:增加顯示 執行計畫、交易資訊、封鎖資訊、系統資訊等
USE master
GO
EXEC sp_WhoIsActive @get_plans=1, @get_transaction_info=1, 
 @find_block_leaders=1, @get_task_info=2
GO

-- EX03_sp_WhoIsActive:增加顯示 執行計畫、交易資訊、封鎖資訊、系統資訊、
-- 取得更多關聯的 ad hoc 查詢或 執行預存程序的呼叫程序、
-- 取得此工作階段(Session)上的更多參考資訊
USE master
GO
EXEC sp_WhoIsActive @get_plans=1, @get_transaction_info=1, @find_block_leaders=1,
  @get_task_info=2, @get_outer_command = 1, @get_additional_info = 2
GO



sp_whoisactive 參數說明 2

目前已有24個以上的參數,善用 @help = 1 來查詢使用方式。

參數 說明
@get_outer_command = 1 嘗試取得更多關聯的 ad hoc 查詢或 執行預存程序的呼叫程序
Get the associated outer ad hoc query or stored procedure call, if available
@sort_order ='[blocked_session_count] ASC'
排序
Column(s) by which to sort output, optionally with sort directions. 
Valid column choices:
session_id, physical_io, reads, physical_reads, writes, tempdb_allocations, tempdb_current, CPU, context_switches, used_memory, physical_io_delta, 
reads_delta, physical_reads_delta, writes_delta, tempdb_allocations_delta,  tempdb_current_delta, CPU_delta, context_switches_delta, used_memory_delta, 
tasks, tran_start_time, open_tran_count, blocking_session_id, blocked_session_count,  percent_complete, host_name, login_name, database_name, start_time, login_time
Note that column names in the list must be bracket-delimited. 
Commas and/or white space are not required. 
@get_additional_info = 1
取得此工作階段(Session)上的更多參考資訊。

Get additional non-performance-related information about the session or request text_size, language, date_format, date_first, quoted_identifier, arithabort, ansi_null_dflt_on,  ansi_defaults, ansi_warnings, ansi_padding, ansi_nulls, concat_null_yields_null, transaction_isolation_level, lock_timeout, deadlock_priority, row_count, command_type.

If a SQL Agent job is running, an subnode called agent_info will be populated with some or all of the following: job_id, job_name, step_id, step_name, msdb_query_error (in the event of an error)

If @get_task_info is set to 2 and a lock wait is detected, a subnode called block_info will be populated with some or all of the following: lock_type, database_name, object_id, file_id, hobt_id,  applock_hash, metadata_resource, metadata_class_id, object_name, schema_name.
@help = 1 顯示出可用的參數與說明



sp_whoisactive 使用範例

-- 010_使用help_線上說明



-- 011_get_outer_command=1_ 取得此工作階段(Session)上的更多參考資訊



-- 012_get_outer_command=1_ 取得此工作階段(Session)上的更多參考資訊_2



-- 013_增加顯示:封鎖鏈結、封鎖計數,但沒有排序



-- 014_顯示:封鎖鏈結、封鎖計數,並依據 blocked_session_count 排序



-- 015_取得此工作階段(Session)上的更多參考資訊



-- 016_取得此工作階段(Session)上的更多參考資訊_xml_交易隔離層級



-- 021_顯示 執行計畫、交易資訊、封鎖資訊、系統資訊、取得更多關聯的 ad hoc 查詢或 執行預存程序的呼叫程序、取得此工作階段(Session)上的更多參考資訊



-- 022_延續 021_顯示 執行計畫...



-- 023_延續 021_顯示 執行計畫...


-- 024_延續 021_顯示 執行計畫...


-- 025_延續 021_顯示 執行計畫...




sp_whoisactive 使用範例程式碼(2)



-- EX01-sp_WhoIsActive:線上說明
USE master
GO
EXEC sp_WhoIsActive @help = 1
GO
-- EX02-sp_WhoIsActive: @get_outer_command= 1 , 
-- 嘗試取得更多關聯的 ad hoc 查詢或 執行預存程序的呼叫程序
USE master
GO
EXEC sp_WhoIsActive @get_outer_command = 1
GO


-- EX03-sp_WhoIsActive:增加顯示:封鎖鏈結、封鎖計數,
-- 並依據 blocked_session_count 排序
USE master
GO
EXEC sp_WhoIsActive @find_block_leaders = 1 , 
 @sort_order ='[blocked_session_count] ASC'
GO
-- EX04-sp_WhoIsActive:取得此工作階段(Session)上的更多參考資訊
USE master
GO
EXEC sp_WhoIsActive @get_additional_info = 1
GO


-- EX05-sp_WhoIsActive:
-- 增加顯示 執行計畫、交易資訊、封鎖資訊、系統資訊、
-- 取得更多關聯的 ad hoc 查詢或 執行預存程序的呼叫程序、取得此工作階段(Session)上的更多參考資訊
USE master
GO
EXEC sp_WhoIsActive @get_plans=1, @get_transaction_info=1, @find_block_leaders=1, 
 @get_task_info=2, @get_outer_command = 1, @get_additional_info = 2
GO





參考資料
[SQL Server] sp_whoisactive: find out long running queries (找出費時、耗資源的查詢)
http://sharedderrick.blogspot.tw/2017/07/sql-server-spwhoisactive-find-out-long.html

sp_whoisactive
http://whoisactive.com/

Looking for sp_whoisactive?
http://sqlblog.com/blogs/adam_machanic/archive/2017/07/26/looking-for-sp-whoisactive.aspx

sp_whoisactive Documentation
http://whoisactive.com/docs/

2017-08-05

[SQL Server] Stress testing, SQLQueryStress parameter, 壓力測試, 搭配使用 參數 (2)


延續先前文章:[SQL Server] SQLQueryStress, Stress testing, 壓力測試

本文討論:
SQLQueryStress: 搭配 參數(Parameter),以預存程序(Stored Procedure)、T-SQL 參數(Parameter) 為例

-- 001_SQLQueryStress: 搭配 預存程序(Stored Procedure) 與 參數(Parameter)



-- 002_SQLQueryStress: 搭配 T-SQL 參數(Parameter)




SQLQueryStress: 搭配 參數(Parameter),以預存程序(Stored Procedure)、T-SQL 參數(Parameter) 為例

任務01:SQLQueryStress: 搭配 預存程序(Stored Procedure) 與 參數(Parameter)

-- 010_設定要執行 參數化 程式




-- 011_點選_Parameter_Substitution



-- 012_準備設定_Parameter_Query



-- 013_點選_Database_設定資料庫連線資訊



-- 014_輸入要取出參數值的程式碼



-- 015_點選_Get_Columns



-- 016_下拉_點選_Column



-- 017_已經取得資料行



-- 018_點選_DataType



-- 018_02_預存程序,設定參數



-- 019_SQL_Profiler_錄製_帶入參數值來執行



-- 020_SSMS_觀察執行的預存程序_次數



-- 021_SSMS_觀察執行的預存程序_次數_2



-- 022_SSMS_觀察執行的預存程序_次數_3



-- 023_SSMS_觀察執行的預存程序_次數_4




任務02:SQLQueryStress: 搭配 T-SQL 參數(Parameter) 

-- 100_參數化的查詢式



-- 101_設定_Parameter_Query



-- 102_執行 SQLQueryStress



-- 103_SSMS_參數化_執行次數



-- 104_SSMS_參數化_執行次數_2



-- 105_SSMS_參數化_執行次數_3



-- 106_SQL_Profiler_參數化查詢式_帶入參數





範例程式碼

01-執行預存程序 [CustOrdersDetail],參數:@OrderID

-- 00-執行預存程序 [dbo].[CustOrdersDetail],輸入參數:@OrderID
USE Northwind
GO
EXEC [dbo].[CustOrdersDetail] @OrderID=10248
GO

02-SQLQueryStress 要執行的範例程式碼

-- 01-SQLQueryStress 要執行的範例程式碼
EXEC [dbo].[CustOrdersDetail] @OrderID=10248;

-- 02-在 Parameter Substitution 要執行的範例程式碼
SELECT OrderID FROM Orders;

--
SELECT * FROM [Order Details] WHERE OrderID =10248;

03-Query: Execution count for stored procedure

-- 10-Query: Execution count for stored procedure
-- 查詢 預存程序 的執行次數
USE master
GO
SELECT  DB_NAME(st.dbid) 'DB' ,OBJECT_SCHEMA_NAME(st.objectid,dbid) 'Schema',
 OBJECT_NAME(st.objectid,dbid) 'SP' ,MAX(cp.usecounts) 'ExecutionCount'
 , cp.objtype, cp.cacheobjtype, st.text
FROM sys.dm_exec_cached_plans cp CROSS APPLY sys.dm_exec_sql_text(cp.plan_handle) st
WHERE DB_NAME(st.dbid) IS NOT NULL
 AND cp.objtype = 'Proc' AND  DB_NAME(st.dbid) ='Northwind' -- Filter
GROUP BY cp.plan_handle, DB_NAME(st.dbid), OBJECT_SCHEMA_NAME(objectid,st.dbid),
 OBJECT_NAME(objectid,st.dbid), cp.objtype, cp.cacheobjtype,  st.text
ORDER BY MAX(cp.usecounts) DESC
GO

--
SELECT * FROM sys.dm_exec_cached_plans cp CROSS APPLY sys.dm_exec_sql_text(cp.plan_handle) st
WHERE DB_NAME(st.dbid) ='Northwind' -- Filter
GO




參考資料

[SQL Server] SQLQueryStress, Stress testing, 壓力測試