আপনার গিট কমিট পুনর্গঠন
গিট একটি শক্তিশালী সংস্করণ নিয়ন্ত্রণ ব্যবস্থা যা বিকাশকারীদের তাদের প্রকল্পে দক্ষতার সাথে পরিবর্তনগুলি পরিচালনা করতে সহায়তা করে। মাঝে মাঝে, আপনি মাস্টার শাখা থেকে একটি নতুন শাখায় সাম্প্রতিক প্রতিশ্রুতিগুলি সরানোর প্রয়োজন খুঁজে পেতে পারেন। এটি বিভিন্ন কারণে হতে পারে, যেমন নতুন বৈশিষ্ট্যগুলিকে আলাদা করা বা পরীক্ষামূলক কাজকে মূল প্রকল্প থেকে আলাদা করা।
এই নির্দেশিকায়, আমরা আপনাকে আপনার সাম্প্রতিক প্রতিশ্রুতিগুলিকে একটি নতুন শাখায় স্থানান্তরিত করতে এবং আপনার মাস্টার শাখাকে পূর্ববর্তী অবস্থায় পুনরায় সেট করার জন্য আপনাকে ধাপে ধাপে নিয়ে যাব। এই নির্দেশাবলী অনুসরণ করে, আপনি একটি পরিষ্কার এবং সংগঠিত প্রতিশ্রুতি বজায় রাখবেন, আপনার প্রকল্পটি সমস্ত দলের সদস্যদের জন্য পরিচালনাযোগ্য এবং বোধগম্য থাকবে তা নিশ্চিত করে।
| আদেশ | বর্ণনা |
|---|---|
| git checkout -b newbranch | 'নতুন শাখা' নামে একটি নতুন শাখা তৈরি করুন এবং অবিলম্বে এটিতে স্যুইচ করুন। |
| git reset --hard HEAD~3 | সমস্ত পরিবর্তন বাতিল করে বর্তমান শাখাটিকে সেই অবস্থায় পুনরায় সেট করে যা আগে তিনটি কমিটের মধ্যে ছিল। |
| git push origin newbranch | 'নতুন শাখা' শাখাটিকে 'অরিজিন' নামের দূরবর্তী সংগ্রহস্থলে ঠেলে দেয়। |
| git push origin master --force | স্থানীয় 'মাস্টার' শাখার সাথে মেলে দূরবর্তী 'মাস্টার' শাখাটিকে জোরপূর্বক আপডেট করে, এমনকি যদি এটি ইতিহাস পুনর্লিখন করে। |
| git branch newbranch | এটিতে স্যুইচ না করে 'নতুন শাখা' নামে একটি নতুন শাখা তৈরি করে। |
| git cherry-pick C D E | বর্তমান শাখায় নির্দিষ্ট কমিট (C, D, এবং E) দ্বারা প্রবর্তিত পরিবর্তনগুলি প্রয়োগ করে। |
| git log --oneline --graph | কমিট ইতিহাসের একটি সংক্ষিপ্ত, গ্রাফিক্যাল উপস্থাপনা প্রদর্শন করে। |
গিট কমান্ডের বিস্তারিত ব্যাখ্যা
প্রদত্ত স্ক্রিপ্টগুলি প্রদর্শন করে যে কীভাবে সাম্প্রতিক প্রতিশ্রুতিগুলিকে একটি নতুন শাখায় সরানো যায় এবং পুনরায় সেট করা যায় পূর্ববর্তী রাজ্যে শাখা। প্রথম, আদেশ নামে একটি নতুন শাখা তৈরি করে এবং এটিতে সুইচ করে। এই দ্বারা অনুসরণ করা হয় git reset --hard HEAD~3, যা রিসেট করে রাজ্যের শাখা এটি আগে তিনটি কমিটের মধ্যে ছিল, কার্যকরভাবে সর্বশেষ প্রতিশ্রুতিগুলিকে সরিয়ে দেয়। এই কমান্ডটি অবাঞ্ছিত পরিবর্তনগুলি বাতিল করে কমিট ইতিহাস পরিষ্কার করার জন্য অত্যন্ত গুরুত্বপূর্ণ।
পরবর্তী, কমান্ড নতুন তৈরি করা শাখাটিকে দূরবর্তী সংগ্রহস্থলে ঠেলে দেয়, এটিকে সহযোগিতার জন্য উপলব্ধ করে। চূড়ান্ত করতে, জোর করে রিমোট আপডেট করে শাখা স্থানীয় রাজ্যের সাথে মেলে, এমনকি যদি এটি ইতিহাস পুনর্লিখন জড়িত থাকে। দ্বিতীয় স্ক্রিপ্ট হাইলাইট git branch newbranch এটিতে স্যুইচ না করে একটি নতুন শাখা তৈরি করার জন্য, এবং এক শাখা থেকে অন্য শাখায় নির্দিষ্ট প্রতিশ্রুতি প্রয়োগ করতে। অবশেষে, প্রতিশ্রুতির ইতিহাসের একটি চাক্ষুষ উপস্থাপনা প্রদান করে, পরিবর্তনগুলি যাচাই করতে সহায়তা করে।
Git-এ একটি নতুন শাখায় সাম্প্রতিক প্রতিশ্রুতিগুলি সরানো৷
গিট কমান্ড ব্যবহার করে
# Create a new branch and switch to itgit checkout -b newbranch# Reset the master branch to the previous stategit checkout mastergit reset --hard HEAD~3# Push the new branch to the remote repositorygit push origin newbranch# Force push the reset master branch to the remote repositorygit push origin master --force
গিট-এ একটি নতুন শাখা তৈরি করা এবং স্যুইচ করা
গিট ব্যাশ ব্যবহার করা
# Step 1: Check the current branchgit branch# Step 2: Create a new branchgit branch newbranch# Step 3: Move commits to the new branchgit checkout newbranchgit cherry-pick C D E# Step 4: Verify the branchesgit log --oneline --graph
গিট শাখা এবং ইতিহাস ব্যবস্থাপনা বোঝা
Git এর সাথে কাজ করার আরেকটি গুরুত্বপূর্ণ দিক হল সংগ্রহস্থল পরিষ্কার এবং বজায় রাখার জন্য শাখা ইতিহাস পরিচালনা করা। একটি নতুন শাখায় সাম্প্রতিক প্রতিশ্রুতিগুলি স্থানান্তরিত করার সময়, সহযোগিতার উপর প্রভাব বোঝা অপরিহার্য। উদাহরণস্বরূপ, ফোর্স-পুশিং এর সাথে পরিবর্তন হয় টিম মেম্বারদের কাজ ব্যাহত করতে পারে যদি তারা ইতিমধ্যেই তাদের কাজের উপর ভিত্তি করে থাকে। অতএব, এই ধরনের পরিবর্তন করার আগে আপনার দলের সাথে যোগাযোগ করা অত্যন্ত গুরুত্বপূর্ণ।
তাছাড়া, আপনি ব্যবহার করতে পারেন একটি রৈখিক প্রকল্প ইতিহাস বজায় রাখার জন্য। রিবেসিং আপনাকে কমিটগুলি সরাতে বা একত্রিত করতে দেয়, নিশ্চিত করে যে প্রতিশ্রুতি ইতিহাস সংগঠিত এবং অনুসরণ করা সহজ। এই অভ্যাসটি বিশেষত দীর্ঘস্থায়ী বৈশিষ্ট্য শাখাগুলিতে কার্যকর যেখানে আপনি অপ্রয়োজনীয় মার্জ কমিট তৈরি না করে মাস্টার শাখা থেকে আপডেটগুলি অন্তর্ভুক্ত করতে চান৷ এই কৌশলগুলি আয়ত্ত করা আপনার গিট ওয়ার্কফ্লো এবং সহযোগিতাকে উল্লেখযোগ্যভাবে উন্নত করবে।
- আমি কিভাবে Git এ একটি নতুন শাখা তৈরি করব?
- কমান্ড ব্যবহার করুন একটি নতুন শাখা তৈরি করতে।
- উদ্দেশ্য কি ?
- এটি বর্তমান শাখাটিকে একটি নির্দিষ্ট অবস্থায় পুনরায় সেট করে, সেই বিন্দুর পরে সমস্ত পরিবর্তন বাতিল করে।
- আমি কিভাবে আমার গিট ইতিহাসের একটি ভিজ্যুয়াল উপস্থাপনা দেখতে পারি?
- ব্যবহার করুন একটি সংক্ষিপ্ত, গ্রাফিক্যাল কমিট ইতিহাস দেখতে।
- কেন আমি ব্যবহার এড়াতে হবে ?
- ফোর্স-পুশিং দূরবর্তী ইতিহাস ওভাররাইট করতে পারে এবং সহযোগীদের কাজ ব্যাহত করতে পারে। সাবধানতার সাথে এটি ব্যবহার করুন।
- কি করে করতে?
- এটি বর্তমান শাখায় নির্দিষ্ট কমিট থেকে পরিবর্তন প্রযোজ্য।
- মার্জ কমিট ছাড়াই কিভাবে আমি মাস্টার ব্রাঞ্চ থেকে আপডেটগুলিকে অন্তর্ভুক্ত করতে পারি?
- ব্যবহার করুন সর্বশেষ মাস্টার শাখার উপরে আপনার পরিবর্তনগুলি পুনরায় প্রয়োগ করতে।
- একটি রৈখিক প্রকল্প ইতিহাস বজায় রাখার সুবিধা কি?
- এটি কমিট ইতিহাসকে বোঝা এবং অনুসরণ করা সহজ করে তোলে, যা সহযোগিতার জন্য উপযোগী।
- আমি কিভাবে Git এ শাখা স্যুইচ করব?
- ব্যবহার করুন একটি বিদ্যমান শাখায় স্যুইচ করতে।
- আমি কি কমিটগুলি পুনরুদ্ধার করতে পারি যা রিসেট করা হয়েছিল ?
- হ্যাঁ, ব্যবহার করুন কমিট হ্যাশ খুঁজে পেতে এবং এটিতে পুনরায় সেট করতে।
সাম্প্রতিক গিট কমিটগুলি সরানোর জন্য পদক্ষেপ
Git এর সাথে কাজ করার আরেকটি গুরুত্বপূর্ণ দিক হল সংগ্রহস্থল পরিষ্কার এবং বজায় রাখার জন্য শাখা ইতিহাস পরিচালনা করা। একটি নতুন শাখায় সাম্প্রতিক প্রতিশ্রুতিগুলি স্থানান্তরিত করার সময়, সহযোগিতার উপর প্রভাব বোঝা অপরিহার্য। উদাহরণস্বরূপ, ফোর্স-পুশিং এর সাথে পরিবর্তন হয় টিম মেম্বারদের কাজ ব্যাহত করতে পারে যদি তারা ইতিমধ্যেই তাদের কাজের উপর ভিত্তি করে থাকে। অতএব, এই ধরনের পরিবর্তন করার আগে আপনার দলের সাথে যোগাযোগ করা অত্যন্ত গুরুত্বপূর্ণ।
তাছাড়া, আপনি ব্যবহার করতে পারেন একটি রৈখিক প্রকল্প ইতিহাস বজায় রাখার জন্য। রিবেসিং আপনাকে কমিটগুলি সরাতে বা একত্রিত করতে দেয়, নিশ্চিত করে যে প্রতিশ্রুতি ইতিহাস সংগঠিত এবং অনুসরণ করা সহজ। এই অভ্যাসটি বিশেষত দীর্ঘস্থায়ী বৈশিষ্ট্য শাখাগুলিতে কার্যকর যেখানে আপনি অপ্রয়োজনীয় মার্জ কমিট তৈরি না করে মাস্টার শাখা থেকে আপডেটগুলি অন্তর্ভুক্ত করতে চান৷ এই কৌশলগুলি আয়ত্ত করা আপনার গিট ওয়ার্কফ্লো এবং সহযোগিতাকে উল্লেখযোগ্যভাবে উন্নত করবে।
একটি পরিষ্কার এবং দক্ষ প্রকল্প ইতিহাস বজায় রাখার জন্য শাখা পরিচালনার জন্য গিট কমান্ডগুলি আয়ত্ত করা অপরিহার্য। সাম্প্রতিক প্রতিশ্রুতিগুলিকে একটি নতুন শাখায় স্থানান্তরিত করে এবং মাস্টার শাখা পুনরায় সেট করার মাধ্যমে, আপনি পরিবর্তনগুলিকে আলাদা করতে পারেন এবং আপনার প্রধান শাখাকে স্থিতিশীল রাখতে পারেন। যেমন কমান্ড বোঝা , , এবং আপনার কর্মপ্রবাহ এবং সহযোগিতাকে ব্যাপকভাবে উন্নত করতে পারে। তাদের কাজের ব্যাঘাত এড়াতে গুরুত্বপূর্ণ পরিবর্তন করার আগে সর্বদা আপনার দলের সাথে যোগাযোগ করুন।