অ্যাফিনিটি "সিপিইউ ব্যবহারটি সামঞ্জস্য করে না" (যেমন আপনার ক্ষেত্রে সিপিইউগুলিকে কম কাজ সম্পাদন করে), এটি আপনাকে সিপিইউ বন্ধ করতে দেয় (সম্ভবত এটি একই মেশিনে অন্য কোনও ক্ষেত্রে উপলব্ধ করার জন্য) বা সিপিইউ সেট করতে পারে শুধুমাত্র I / O সাহায্য করুন। এমনকি আপনার একাধিক সিপিইউ থাকলেও আপনি আপনার লক্ষ্যটিকে সহায়তা করতে প্রাক্তনটিকে ব্যবহার করতে সক্ষম হবেন না এবং আমাদের পক্ষে পরবর্তীটি অনুমান করা অসম্ভব কারণ আপনার সিপিইউ ব্যবহারটি এত বেশি কীভাবে চালাচ্ছে তা আমরা জানি না। এটি অত্যন্ত দুর্বল ইনডেক্সিং, অতিরিক্ত সংকলন, প্রচুর পরিমাণে স্কেলারের ইউডিএফ, আই / ও থ্রেশিংয়ের কারণে হতে পারে, কে জানে? (এবং আই / ও এর কারণ হবার কারণ হ'ল যদি আপনার ডাটাবেসটি 3 জিবি বা তার বেশি হয় তবে এটি নিয়মিত বাফার পুল মেমরির মধ্যে ডেটা অদলবদল করতে হবে এবং এটি সিপিইউতে লাগে))
সিপিইউ ক্যাশে এছাড়াও একটি খরগোশের গর্ত যা আপনার নীচে নামার দরকার নেই। আপনার সিপিইউ ক্যাশে নিয়ে সমস্যার কারণে আপনার সিপিইউ 95% এ ছোঁড়াচ্ছে বলে আমি অত্যন্ত সন্দেহ করি।
সিপিইউ চাপের উত্সকে সংকুচিত করতে এবং আপনি সঞ্চিত প্রক্রিয়া ব্যবহার করছেন তা ধরে নেওয়ার জন্য, আপনি গ্লেন বেরি ( এখান থেকে উত্সাহিত ) থেকে এই ডায়াগোনস্টিক কোয়েরিটি একবার দেখে নিতে পারেন - নিশ্চিত করুন যে আপনি এটি সঠিক ডাটাবেসের প্রসঙ্গে চালাচ্ছেন:
-- Top Cached SPs By Total Worker time (SQL Server 2012).
-- Worker time relates to CPU cost (Query 44) (SP Worker Time)
SELECT TOP (25)
p.name AS [SP Name],
qs.total_worker_time AS [TotalWorkerTime],
qs.total_worker_time/qs.execution_count AS [AvgWorkerTime],
qs.execution_count,
ISNULL(qs.execution_count/DATEDIFF(Second, qs.cached_time, GETDATE()), 0)
AS [Calls/Second],
qs.total_elapsed_time,
qs.total_elapsed_time/qs.execution_count AS [avg_elapsed_time],
qs.cached_time
FROM sys.procedures AS p WITH (NOLOCK)
INNER JOIN sys.dm_exec_procedure_stats AS qs WITH (NOLOCK)
ON p.[object_id] = qs.[object_id]
WHERE qs.database_id = DB_ID()
ORDER BY qs.total_worker_time DESC OPTION (RECOMPILE);
-- This helps you find the most expensive cached stored procedures from a CPU perspective
-- You should look at this if you see signs of CPU pressure
আপনি যদি সঞ্চিত পদ্ধতি ব্যবহার না করে থাকেন তবে জন স্যামসনের এই উদাহরণটি অ্যাডহক কোয়েরিগুলিকে আলাদা করতে সহায়তা করতে পারে ( এখান থেকে উত্সাহিত ):
SELECT TOP (25)
qs.sql_handle,
qs.execution_count,
qs.total_worker_time AS Total_CPU,
total_CPU_inSeconds = --Converted from microseconds
qs.total_worker_time/1000000,
average_CPU_inSeconds = --Converted from microseconds
(qs.total_worker_time/1000000) / qs.execution_count,
qs.total_elapsed_time,
total_elapsed_time_inSeconds = --Converted from microseconds
qs.total_elapsed_time/1000000,
st.text,
qp.query_plan
FROM sys.dm_exec_query_stats AS qs
CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) AS st
CROSS apply sys.dm_exec_query_plan (qs.plan_handle) AS qp
ORDER BY qs.total_worker_time DESC OPTION (RECOMPILE);
আপনি অ্যাডাম মাচানিকের sp_WhoIsAtive , একটি সঞ্চিত পদ্ধতি যা বর্তমানে চলমান সমস্ত প্রশ্নের দ্রুত বিশ্লেষণ করতে পারে এবং আপনি চান (তবে আপনার ক্ষেত্রে যেমন @sort_order = '[CPU] DESC') এটি সাজানোর অনুমতি দিতে পারেন এমন একটি সঞ্চিত পদ্ধতিও একবার দেখতে পারেন ।
আমি প্রথমে যা করব, যদিও - বিশেষত যদি এটি অনুসন্ধান এবং উদ্ধারকারী দলগুলির জন্য সত্যই মিশন সমালোচনা হয় - তবে আরও ভাল হার্ডওয়্যার কেনা উচিত। আপনার অ্যাপ্লিকেশনটি পরিষেবা দেওয়ার জন্য আপনার আরও সিপিইউ এবং আরও বেশি র্যাম থাকা উচিত। আপনার একেবারে আরও ভাল উচ্চ প্রাপ্যতা প্রয়োজন (যেমন ক্লাস্টারিং, মিররিং বা উপলভ্যতা গোষ্ঠী)। কোনও কারণ নেই যে কোনও শারীরিক মেশিনের পুনরায় বুট করা আপনার অ্যাপ্লিকেশনটিকে পুরোপুরি অফলাইনে নেবে - আমাদের সেই সমস্যার জন্য আরও ভাল সমাধান রয়েছে। এবং পরিশেষে, আমি অনুমান করি যে এই "সার্ভার" -এর মধ্যে কেবল একটি স্পিনি ডিস্ক ড্রাইভ রয়েছে। এর অর্থ হ'ল সমস্ত আই / ও - ওএস থেকে, এসকিউএল সার্ভার ডেটা ফাইলগুলি, লগ ফাইলগুলি, টেম্পডিবি ইত্যাদি etc. সমস্তই একটি একক নিয়ামকের মধ্য দিয়ে যায় এবং একক ড্রাইভে পড়ুন / লেখার ক্রিয়াকলাপ ভাগ করে দেয়। আরও ডিস্ক পান। আপনি যেখানে পারেন সেখানে এসএসডি পান। RAID ব্যবহার করুন এবং I / O যতটা সম্ভব ছড়িয়ে দেওয়ার চেষ্টা করুন।
এই সমস্ত বলেছে যে সমস্যার সময়ে হার্ডওয়্যার নিক্ষেপ করা কেবলমাত্র ফিক্সের অংশ হবে না। অতিরিক্ত সিপিইউ ব্যবহারের কারণ হ'ল আপনাকে একেবারে আলাদা করতে হবে এবং তারপরে আপনি যে কোনও হার্ডওয়্যারই থাকুন না কেন সমস্যা সমাধান করুন attack
আরও কিছু ধারণার জন্য এই স্ট্যাকওভারফ্লো প্রশ্নটি দেখুন:
/programming/945063/how-do-i-find-out-what-is-hammering-my-sql-server