রিমোট অ্যাক্সেস: ssh এবং এর ব্যবহার

নেটওয়ার্কিং এবং রিমোট অ্যাক্সেস - ইউনিক্স/লিনাক্স (UNIX / LINUX) - Computer Programming

231

রিমোট অ্যাক্সেস: ssh এবং এর ব্যবহার

SSH (Secure Shell) একটি প্রোটোকল যা রিমোট সিস্টেমে নিরাপদভাবে অ্যাক্সেস প্রদান করে। এটি মূলত কমান্ড-লাইন ভিত্তিক একটি টুল যা দূরবর্তী কম্পিউটার বা সার্ভারে লগইন এবং কমান্ড চালানোর জন্য ব্যবহৃত হয়। SSH একটি নিরাপদ পদ্ধতি, কারণ এটি ইন্টারনেটের মাধ্যমে ডেটা এনক্রিপ্ট করে পাঠায়, যা কোনো তৃতীয় পক্ষের দ্বারা অবৈধভাবে ডেটা গ্রহণ বা পরিবর্তন করার ঝুঁকি কমিয়ে দেয়।


1. SSH কী এবং কেন এটি ব্যবহৃত হয়?

SSH (Secure Shell) হলো একটি প্রোটোকল যা রিমোট কম্পিউটার বা সার্ভারের সাথে নিরাপদ যোগাযোগ প্রতিষ্ঠা করতে ব্যবহৃত হয়। এটি কমান্ড লাইনের মাধ্যমে সিস্টেম অ্যাডমিনিস্ট্রেশন কাজ বা অন্যান্য ফাইল ট্রান্সফার পরিচালনা করার জন্য নিরাপদ পদ্ধতি প্রদান করে।

SSH ব্যবহারের প্রধান সুবিধাগুলি হলো:

  • নিরাপত্তা: SSH এনক্রিপশন ব্যবহার করে, যা ডেটা স্থানান্তরের সময় নিরাপত্তা নিশ্চিত করে।
  • সক্ষমতা: SSH ব্যবহার করে আপনি দূরবর্তী সিস্টেমে লগইন করতে পারেন এবং সেখান থেকে কোনো কাজ চালাতে পারেন।
  • আধুনিক প্রোটোকল: পাসওয়ার্ড সুরক্ষা ছাড়াও পাবলিক কী এবং প্রাইভেট কী এর মাধ্যমে আরও নিরাপদ লগইন নিশ্চিত করা যায়।

2. ssh কমান্ডের মৌলিক ব্যবহার

SSH কমান্ডের মাধ্যমে রিমোট সিস্টেমে লগইন করা হয়। এটি সাধারণত নিম্নলিখিত সিনট্যাক্সে ব্যবহৃত হয়:

ssh [username]@[hostname]
  • [username]: দূরবর্তী সিস্টেমে লগইন করার জন্য আপনার ব্যবহারকারীর নাম।
  • [hostname]: রিমোট সিস্টেমের IP অ্যাড্রেস বা ডোমেইন নাম।

উদাহরণ:

ssh user@192.168.1.100

এই কমান্ডটি 192.168.1.100 আইপি ঠিকানাযুক্ত রিমোট সিস্টেমে user ব্যবহারকারী হিসেবে লগইন করবে।

যদি আপনি প্রথমবার SSH ব্যবহার করেন, তবে SSH হোস্টের কী আপনাকে প্রমাণ করতে হবে। আপনি yes দিয়ে এগিয়ে যেতে পারেন, এরপর আপনার পাসওয়ার্ড প্রবেশ করালে আপনি সিস্টেমে লগইন হতে পারবেন।


3. SSH পাসওয়ার্ড ছাড়া লগইন (পাবলিক-কি অথেনটিকেশন)

পাসওয়ার্ড ছাড়া SSH লগইন সেটআপ করতে পাবলিক-কি অথেনটিকেশন ব্যবহার করা হয়, যা অধিক নিরাপদ। এর জন্য আপনাকে একটি পাবলিক কী এবং প্রাইভেট কী জেনারেট করতে হবে এবং সেগুলি দূরবর্তী সিস্টেমে কপি করতে হবে।

৩.১: SSH কী জেনারেট করা

প্রথমে আপনার লোকাল মেশিনে একটি পাবলিক-প্রাইভেট কী পেয়ার জেনারেট করুন:

ssh-keygen -t rsa

এটি একটি RSA কী পেয়ার তৈরি করবে। আপনাকে কিপ্যাথ (ফাইলের নাম) এবং পাসফ্রেজ প্রদান করতে বলা হবে, যা নিরাপত্তা বাড়ায়।

৩.২: পাবলিক কী রিমোট মেশিনে কপি করা

এখন আপনাকে আপনার পাবলিক কী রিমোট মেশিনে কপি করতে হবে, যাতে আপনি পাসওয়ার্ড ছাড়া SSH লগইন করতে পারেন। এর জন্য ssh-copy-id কমান্ড ব্যবহার করা হয়:

ssh-copy-id user@192.168.1.100

এটি আপনার পাবলিক কী রিমোট মেশিনের ~/.ssh/authorized_keys ফাইলে যুক্ত করবে।

৩.৩: SSH পাসওয়ার্ড ছাড়া লগইন

এখন আপনি পাসওয়ার্ড ছাড়া SSH মাধ্যমে রিমোট সিস্টেমে লগইন করতে পারবেন:

ssh user@192.168.1.100

এটি আপনার প্রাইভেট কী ব্যবহার করবে এবং সিস্টেমে লগইন করবে, যদি আপনার কী পেয়ার সঠিকভাবে সেট করা থাকে।


4. SSH এর বিভিন্ন অপশন

ssh কমান্ডে কিছু অতিরিক্ত অপশন রয়েছে, যা বিশেষ পরিস্থিতিতে ব্যবহার করা যেতে পারে:

৪.১: পোর্ট নম্বর নির্দিষ্ট করা

যদি রিমোট সিস্টেমে SSH সার্ভারটি কোনো অস্বাভাবিক পোর্টে চলছে (যেমন ডিফল্ট ২২ পোর্টের পরিবর্তে), আপনি -p অপশন দিয়ে পোর্ট নম্বর নির্দিষ্ট করতে পারেন:

ssh -p 2222 user@192.168.1.100

এখানে 2222 হল পোর্ট নম্বর।

৪.২: SSH এর মাধ্যমে একসাথে একাধিক কমান্ড চালানো

আপনি SSH ব্যবহার করে রিমোট সিস্টেমে একাধিক কমান্ড চালাতে পারেন, যেমন:

ssh user@192.168.1.100 'ls -l; df -h'

এটি ls -l এবং df -h কমান্ড দুটি একযোগে চালাবে এবং আউটপুট দেখাবে।

৪.৩: SSH ত্বরা ফাইল ট্রান্সফার (SCP বা SFTP ব্যবহার)

ফাইল ট্রান্সফার করতে SCP (Secure Copy Protocol) বা SFTP (Secure File Transfer Protocol) ব্যবহার করা হয়। উদাহরণস্বরূপ:

SCP:

scp localfile.txt user@192.168.1.100:/remote/directory/

SFTP:

sftp user@192.168.1.100

5. SSH এর মাধ্যমে পোর্ট ফরওয়ার্ডিং

SSH পোর্ট ফরওয়ার্ডিং ব্যবহার করে আপনি রিমোট সিস্টেমে থাকা পোর্টে স্থানীয়ভাবে অ্যাক্সেস পেতে পারেন। এটি সাধারণত নিরাপদ টানেলিং জন্য ব্যবহৃত হয়।

৫.১: লুকাল পোর্ট ফরওয়ার্ডিং

ssh -L 8080:localhost:80 user@192.168.1.100

এই কমান্ডটি আপনার লোকাল সিস্টেমের 8080 পোর্টকে রিমোট সিস্টেমের 80 পোর্টের সাথে যুক্ত করবে।

৫.২: রিমোট পোর্ট ফরওয়ার্ডিং

ssh -R 8080:localhost:80 user@192.168.1.100

এই কমান্ডটি রিমোট সিস্টেমের 8080 পোর্টকে আপনার লোকাল সিস্টেমের 80 পোর্টের সাথে যুক্ত করবে।


6. SSH সেশনের জন্য টার্মিনাল মেনু

  • exit: SSH সেশন বন্ধ করতে।
  • Ctrl + C: চলমান প্রক্রিয়া বন্ধ করতে।
  • Ctrl + D: লগ আউট করতে।

সারসংক্ষেপ

SSH একটি নিরাপদ এবং শক্তিশালী প্রোটোকল যা আপনাকে দূরবর্তী সিস্টেম বা সার্ভারে নিরাপদভাবে লগইন এবং কমান্ড চালাতে সক্ষম করে। এটি ইন্টারনেট বা ল্যানের মাধ্যমে সিস্টেম অ্যাডমিনিস্ট্রেশন এবং ফাইল ট্রান্সফারের জন্য ব্যাপকভাবে ব্যবহৃত হয়। SSH এর মাধ্যমে পাসওয়ার্ড ছাড়া লগইন, পোর্ট ফরওয়ার্ডিং, এবং নিরাপদ ফাইল ট্রান্সফারের মতো সুবিধা পাওয়া যায়।

Content added By
Promotion

Are you sure to start over?

Loading...