মাস্টার ডাটাবেস দুর্নীতিগ্রস্থ, উদাহরণ শুরু হবে না - আমার বিকল্পগুলি কী?


11

সাহায্য করুন! আমার মাস্টার ডাটাবেসটি দূষিত, আমি এসকিউএল উদাহরণটি অনলাইনেও আনতে পারি না! আমার সার্ভারটি ব্যাক আপ পেতে আমার বিকল্পগুলি কী কী?

আমার কাছে মাস্টার ব্যাকআপ রয়েছে, তবে এমএসডিএন পৃষ্ঠা "মাস্টার ডেটাবেস পুনরুদ্ধার করা" আমাকে সিঙ্গল-ইউজার মোডে উদাহরণটি শুরু করতে বলে, যা আমি করতে পারি না!

(দ্রষ্টব্য: আমি এই প্রশ্নটি এসকিউএল সংস্করণ হিসাবে অনির্ধারিত রেখে দিচ্ছি, যাতে আরও ব্যাপকভাবে প্রযোজ্য রেফারেন্স হতে পারে D


(মন্তব্য বা অন্যান্য উত্তর অবশ্যই স্বাগত, তবে আমি ওয়েবে অন্য কোথাও খুঁজে পাইনি এমন কিছু দিক সহ একটি বিস্তৃত উত্তর দেওয়ার প্রয়াসে আমি এটি জিজ্ঞাসা করেছি।)
ব্র্যাডিসি

উত্তর:


12

এখানে আমি কয়েকটি তদন্ত করব। এগুলি সব করবেন না (তাদের কয়েকটি একই উদ্দেশ্য সাধনের জন্য বিভিন্ন কৌশল), তবে বিবেচনা করার মতো:

1. সরাসরি এসকিউএল ত্রুটি লগ পরীক্ষা করুন

এসকিউএল ত্রুটিযুক্ত লগযুক্ত ফোল্ডারে সরাসরি ব্রাউজ ERRORLOGকরুন এবং এসকিউএল উদাহরণটি কেন শুরু হবে না সে সম্পর্কে আরও বিশদ পেতে নোটপ্যাডে অতি সাম্প্রতিকতম লোড করুন । সম্ভবত আপনি দেখতে পাবেন যে সমস্যাটি মোটেও মাস্টার ডাটাবেসের সাথে নয়।

2. একক ব্যবহারকারী মোডে উদাহরণ শুরু করার চেষ্টা করুন

এসকিউএল সার্ভারের-m (একক ব্যবহারকারী মোড) এবং -f(ন্যূনতম কনফিগারেশন মোড) সহ স্টার্টআপ বিকল্পগুলির একটি সম্পূর্ণ তালিকা এখানে রয়েছে । অন্যান্য সমস্যা আপনাকে মাস্টার ডাটাবেসের জন্য পথটি নির্দিষ্ট করতে দেয়, যদি সমস্যা হয়।

আপনি যদি উদাহরণটি শুরু করতে সক্ষম হন তবে মাস্টার ডাটাবেসটি পুনরুদ্ধার করার জন্য আপনি যে এমএসডিএন নিবন্ধটি সংযুক্ত করেছেন সেগুলির পদক্ষেপগুলি অনুসরণ করুন বা টমাস লারকের এই বিশদ পদক্ষেপটি অনুসরণ করুন ।

যদি আপনি করার আগে অন্য কোনও অ্যাপ্লিকেশন সর্বদা একক ব্যবহারকারী সংযোগটি ধরে রাখে তবে প্রথমে এসকিউএল এজেন্টকে অক্ষম করুন যাতে এটি শুরু হয় না। দ্বিতীয়ত, অ্যাপ্লিকেশনটির নামটি নির্দিষ্ট করতে প্যারামিটারটি ব্যবহার করার জন্য এই প্রশ্নের ধারণাগুলি দেখুন-m"Application Name"

৩. masterঅন্য কোনও পরিস্থিতিতে পুনরুদ্ধার করুন এবং এর ফাইলগুলি অনুলিপি করুন

আমি এই অননুমোদিত কৌশলটির অন্য একটি উল্লেখ খুঁজে পেয়েছি , তবে আমি গত সপ্তাহান্তে এটি সফলভাবে ব্যবহার করেছি, তাই এটি চেষ্টা করার মতো হতে পারে।

আপনি যদি একক-ব্যবহারকারীর মোডে উদাহরণটি শুরু করতে না পারেন তবে আপনার অন্য একটি এসকিউএল উদাহরণ রয়েছে ঠিক একই রিলিজ এবং বিল্ড চলমান থাকলে , আপনার মৃত সার্ভার থেকে সর্বশেষ পরিচিত ভাল মাস্টার ডাটাবেস ব্যাকআপটিকে অন্য পরিস্থিতিতে পুনরুদ্ধার করার চেষ্টা করুন:

  • অবশ্যই আলাদা নাম হিসাবে পুনরুদ্ধার করুন ( master_please_god_let_this_work), WITH MOVEযাতে আপনি masterআপনার ভাল সার্ভারে ওভাররাইট না করে
  • পুনরুদ্ধার করুন WITH NORECOVERY। এটি প্রয়োজনীয় কিনা তা নিশ্চিত নন, তবে আমাকে আরও ভাল মনে হয়েছে যে আমি জানতাম যে অন্য সার্ভারটি পুনরুদ্ধার করা মাস্টারের কোনও কিছুই বদলাবে না
  • এটি অফলাইনে সেট করুন: ALTER DATABASE [master_please_god_let_this_work] SET OFFLINE
  • ভাল সার্ভার থেকে ডেড সার্ভারে পুনরুদ্ধার করা এমডিএফ এবং এলডিএফ ফাইলগুলি অনুলিপি করুন
  • পুনঃনামকরণ master.mdfএবং mastlog.ldfআপনার পুনরুদ্ধার সংস্করণের সাথে খারাপ মাস্টার ফাইলগুলি প্রতিস্থাপন করার জন্য প্রয়োজনীয় ফাইল
  • আপনার আঙ্গুলগুলি অতিক্রম করুন এবং উদাহরণটি শুরু করুন
  • .চ্ছিক: পুনরুদ্ধারকৃত সার্ভারে নতুন করে মাস্টারের পুনঃস্থাপন করুন। এটি প্রয়োজনীয় কিনা তা নিশ্চিত নন, যেহেতু আমরা পরিবর্তন না করতে বেশ যত্নশীল ছিলাম master

4. সিস্টেম ডাটাবেস পুনর্নির্মাণ

যদি আপনার কাছে একই সংস্করণটি চালানো অন্য কোনও উদাহরণ না থেকে থাকে, বা যদি আপনি # 3 এ তালিকাভুক্ত অননুমোদিত পদ্ধতি ব্যবহার করতে স্বাচ্ছন্দ্য বোধ করেন না বা যদি আপনার ব্যাকআপ না থাকে master(তবে আপনার ব্যাকআপ কেন নেই ) ? আপনি মূল ইনস্টল ডিস্ক থেকে এসকিউএল সিস্টেম ডেটাবেসগুলি পুনর্নির্মাণ করতে পারেন :

Setup.exe /ACTION=REBUILDDATABASE /...

এটি সম্পূর্ণ হয়ে গেলে, আপনি masterআপনার শেষ ভাল ব্যাকআপ থেকে পুনরুদ্ধার করতে পূর্বে লিঙ্কিত পদক্ষেপগুলি অনুসরণ করতে পারেন । msdbআপনার সমস্ত চাকরী, কাজের সময়সূচী এবং কাজের ইতিহাস রাখতে আপনাকে সাম্প্রতিক ব্যাকআপটি পুনরুদ্ধার করতে হবে।

৫) সমস্ত ইউএসএল ডাটাবেসকে নতুন (বা বিদ্যমান) এসকিউএল ইনস্ট্যান্সে পুনরুদ্ধার করুন

যদি আপনি ইতিমধ্যে অন্য একটি বিদ্যমান উদাহরণটি পেয়েছেন (যথাযথ এসকিউএল সংস্করণ, পর্যাপ্ত ডিস্ক স্পেস), আমি সম্ভবত অন্যান্য সমস্যা সমাধানের পদক্ষেপগুলিতে কাজ করার সময় খুব সাম্প্রতিক ব্যাকআপগুলি থেকে ডাটাবেস পুনরুদ্ধার শুরু করব just

যদি আপনার নতুন (বা পুনরায় ইনস্টল) উদাহরণটিতে একই ডিস্কটিতে অ্যাক্সেস থাকে তবে এগুলি কেবল নতুন ডাটাবেস হিসাবে সংযুক্ত করা আরও দ্রুত হয়:

CREATE DATABASE foo 
ON (FILENAME = 'D:\data\foo.mdf'),
   (FILENAME = 'D:\data\foo_log.ldf')
FOR ATTACH;

Any. যেকোন পরিবর্তন পুনরায় করুন master

একবার আপনি সফলভাবে পুনরুদ্ধার master(উপরের যেকোন কৌশল দ্বারা), আপনাকে যে কোনও পরিবর্তন হারিয়ে গেছে তা তদন্ত করতে হবে, যদি আপনি স্রেফ পুনরুদ্ধার করা ব্যাকআপের পরে সেগুলি করা হয়:

  • সুরক্ষা পরিবর্তন
  • নতুন ডাটাবেস (ফাইলগুলি এখনও ডিস্কে থাকবে, কেবল সেগুলি সংযুক্ত করুন)
  • সার্ভার-ওয়াইড সেটিংস

এগুলি খুঁজে বের করার কোনও যাদু উপায় নেই, আপনার যদি কোনওরকম পরিবর্তন হয় তবে আপনাকে এই ধরণের পরিবর্তনের জন্য আপনার নিজের কোম্পানির ডকুমেন্টেশন ট্রেলে ফিরে যেতে হবে।


1
চমৎকার পোস্ট. +1 টি। আমি আমার মাস্টারকে দূষিত করে একটি পরীক্ষা করেছি, অন্য সার্ভারে একটি ব্যাকআপ পুনরুদ্ধার করেছি এবং তারপরে ফাইলগুলি পুরানো সার্ভারে অনুলিপি করছি। এটি কোনও সমস্যা ছাড়াই কাজ করেছে। যাইহোক, মাস্টারটি দূষিত অবস্থায় আমি ত্রুটিটি পেয়েছি 3411 11
রেসার এসকিউএল

দুর্দান্ত, সেই কৌশলটি যাচাই করার জন্য ধন্যবাদ। আমার ক্ষেত্রে, আমি কখনই আসল ত্রুটি পাই নি, তবে আমার মাস্টার ডিবি কোনও সম্ভাব্য ক্লাস্টার পরিষেবাদির সময়সীমা নির্ধারণের সেটিংসের বাইরে, পুনরুদ্ধারে কয়েক ঘন্টা সময় নিচ্ছিল।
ব্র্যাডিসি

1
@ রাফায়েলপিসিনেল্লি মাস্টার সার্ভারে থাকা সমস্ত কিছু সম্পর্কে "মেটা-ডেটা" রাখেন (সুরক্ষা, অন্যান্য ডাটাবেস, ইত্যাদি), যাতে তা বোঝা যায়। আমার পয়েন্ট # 5 এবং # 6 দেখুন। আপনাকে সেই ডিবিএসগুলি পুনরায় সংযুক্ত করতে হবে এবং আপনার জায়গায় থাকা কোনও সুরক্ষা পুনরায় সেটআপ করতে হবে। বিটিডাব্লু, আমি আশা করি আপনি একটি ল্যাব পরিবেশে এই সব করছেন!
ব্র্যাডিসি

হ্যাঁ, এই কারণেই পরীক্ষা। আমি একটি ত্রুটি পেয়েছি তবে সম্ভবত আমার স্টোরেজে অনুমতি নিয়ে। আবার, সুন্দর পোস্ট। আমি এই শেষ মন্তব্যটি মুছে ফেলব haha।
রেসার এসকিউএল

2

আমি কেবল একটি সম্ভাব্য সমস্যা ও সমাধান যুক্ত করতে চেয়েছিলাম যেটি আমি সবেমাত্র চালিয়েছি - ইভেন্ট ব্যর্থ এবং ক্রমব্যবস্থায় ব্যর্থ কুলিউটিভ আপডেট (এসকিউএল ২০১ C সিই 12) এবং বার্তাগুলির সময় আমার একই অবস্থা হয়েছিল যেখানে "মাস্টার ডাটাবেসটি পুনরুদ্ধার করা যায় না" বলে এসকিউএল সার্ভারটি দৌড়াতে অক্ষম a সম্পূর্ণ ব্যাকআপ থেকে মাস্টার পুনরুদ্ধার করুন, এটি মেরামত করুন বা পুনর্নির্মাণ করুন "" তবে শেষ পর্যন্ত আমি জানতে পেরেছিলাম যে আমি কেবল সিইউ এক্সিকিউটেবলের পুনরায় পুনরায় সাজানো থাকলে এটি "অসম্পূর্ণভাবে ইনস্টলড" হিসাবে আপগ্রেডের স্থিতি সনাক্ত করে এবং আমাকে কেবল চালনার অনুমতি দেয় আবার আপডেট করুন, এর পরে এটি সফলভাবে সমাপ্ত হয়েছে এবং মাস্টার ডাটাবেস এবং অন্য সকল কোনও সমস্যা ছাড়াই খোলে।


তালিকায় ভাল সংযোজন; এটি অন্তর্ভুক্ত করার জন্য ধন্যবাদ
ব্র্যাডসি
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.