Database Security এবং User Management গাইড ও নোট

Microsoft Technologies - এমএস এসকিউএল সার্ভার (MS SQl Server)
299

Database Security এবং User Management SQL Server বা অন্য ডেটাবেস সিস্টেমে অত্যন্ত গুরুত্বপূর্ণ বিষয়। সঠিক সিকিউরিটি ব্যবস্থাপনা এবং ব্যবহারকারীর অধিকার নিয়ন্ত্রণের মাধ্যমে ডেটাবেসের নিরাপত্তা নিশ্চিত করা যায় এবং অপ্রত্যাশিত অ্যাক্সেস বা ডেটা লিকের ঝুঁকি কমানো যায়।

এই গাইডে Database Security এবং User Management এর মৌলিক ধারণা এবং এর কার্যকরী প্রয়োগ আলোচনা করা হবে।


1. Database Security কী? (What is Database Security?)

Database Security একটি প্রক্রিয়া যা ডেটাবেসের তথ্য সুরক্ষিত রাখতে বিভিন্ন পদ্ধতি এবং কৌশল ব্যবহার করে। এটি ডেটাবেসের ডেটা, অ্যাপ্লিকেশন, এবং ব্যবহারকারীদের নিরাপত্তা নিশ্চিত করার জন্য বিভিন্ন প্রযুক্তি, কনফিগারেশন এবং পলিসি ব্যবহারের একটি সম্মিলিত প্রয়াস।

ডেটাবেস সিকিউরিটির প্রধান লক্ষ্য হল:

  • Unauthorized Access Prevention: অননুমোদিত ব্যবহারকারীদের অ্যাক্সেস প্রতিরোধ করা।
  • Data Integrity: ডেটার সঠিকতা এবং সম্পূর্ণতা বজায় রাখা।
  • Confidentiality: ডেটা গোপনীয়তা নিশ্চিত করা।
  • Availability: ডেটা যেন সহজে প্রবেশযোগ্য থাকে, সেটি নিশ্চিত করা।

1.1. Database Security এর গুরুত্বপূর্ণ উপাদান

  • Authentication: ব্যবহারকারীদের সঠিকভাবে চিহ্নিত করা।
  • Authorization: নির্দিষ্ট ব্যবহারকারীদের নির্দিষ্ট ডেটাবেস অবজেক্টে প্রবেশাধিকার প্রদান করা।
  • Encryption: ডেটা এনক্রিপ্ট করে নিরাপদ রাখা, যাতে ডেটা আক্রমণকারীদের কাছ থেকে সুরক্ষিত থাকে।
  • Auditing: ডেটাবেসের কার্যকলাপ এবং ব্যবহারকারীদের কর্মকাণ্ড ট্র্যাক করা।

2. User Management in SQL Server

User Management SQL Server-এ ব্যবহারকারীদের অ্যাক্সেস এবং অধিকার নিয়ন্ত্রণ করার একটি প্রক্রিয়া। এটি নিশ্চিত করে যে, সঠিক ব্যবহারকারীকে সঠিক সময়ে এবং সঠিকভাবে ডেটাবেসে প্রবেশের অনুমতি দেওয়া হয়েছে।

2.1. SQL Server এ User তৈরি (Creating a User in SQL Server)

SQL Server-এ User তৈরি করার জন্য প্রথমে একটি Login তৈরি করতে হয়, তারপর সেই Login-এর মাধ্যমে একটি User তৈরি করা হয়। নিচে একটি উদাহরণ দেওয়া হলো:

2.1.1. Login তৈরি করা
CREATE LOGIN new_user WITH PASSWORD = 'YourStrongPassword';
GO

এই কোডে:

  • new_user: নতুন লোগিনের নাম।
  • PASSWORD: লোগিন পাসওয়ার্ড।
2.1.2. User তৈরি করা
USE YourDatabase;
CREATE USER new_user FOR LOGIN new_user;
GO

এটি YourDatabase ডেটাবেসে new_user নামের একটি নতুন ব্যবহারকারী তৈরি করবে।

2.2. User এর জন্য Permission প্রদান (Granting Permissions to Users)

ডেটাবেসে User তৈরি করার পর, সেই User কে নির্দিষ্ট অ্যাক্সেস বা অনুমতি দেওয়া হয়। SQL Server-এ এই অনুমতিগুলো বিভিন্ন পর্যায়ে প্রদান করা যায়:

  • SELECT: টেবিল থেকে ডেটা পড়ার অনুমতি।
  • INSERT: টেবিলের মধ্যে নতুন ডেটা ইনসার্ট করার অনুমতি।
  • UPDATE: টেবিলের ডেটা আপডেট করার অনুমতি।
  • DELETE: টেবিল থেকে ডেটা মুছে ফেলার অনুমতি।
2.2.1. Permission প্রদান করার উদাহরণ
GRANT SELECT, INSERT, UPDATE ON dbo.Employee TO new_user;
GO

এই কোডটি new_user কে Employee টেবিলের উপর SELECT, INSERT, এবং UPDATE অনুমতি প্রদান করবে।

2.3. User Role Management (Role Management)

SQL Server এ বিভিন্ন প্রি-ডিফাইন্ড Role থাকে, যা ব্যবহারকারীদের বিভিন্ন পর্যায়ের অ্যাক্সেস দেয়। যেমন:

  • db_datareader: ডেটাবেসের সকল টেবিল থেকে ডেটা পড়ার অনুমতি দেয়।
  • db_datawriter: ডেটাবেসের সকল টেবিলে ডেটা ইনসার্ট বা আপডেট করার অনুমতি দেয়।
  • db_owner: ডেটাবেসের সমস্ত কার্যক্রম সম্পাদন করার পূর্ণ অনুমতি দেয়।
2.3.1. User কে Role দেওয়া
EXEC sp_addrolemember 'db_datareader', 'new_user';
GO

এই কোডটি new_user কে db_datareader রোল অ্যাসাইন করবে, যার মাধ্যমে সে ডেটাবেসের সকল টেবিল থেকে ডেটা পড়তে পারবে।


3. Auditing এবং Logging

Auditing এবং Logging ডেটাবেসে কী ঘটছে তা ট্র্যাক করার জন্য গুরুত্বপূর্ণ প্রক্রিয়া। এগুলি ব্যবহারকারী এবং সিস্টেমের কার্যকলাপ রেকর্ড করতে ব্যবহৃত হয়, যাতে সিকিউরিটি নিশ্চিত করা যায় এবং কোনো সন্দেহজনক কার্যকলাপ সনাক্ত করা যায়।

3.1. Auditing কী? (What is Auditing?)

Auditing হল একটি প্রক্রিয়া যেখানে ডেটাবেসের সকল কার্যকলাপ এবং ব্যবহারকারীর কার্যকলাপের একটি লগ রাখা হয়। এটি ডেটাবেস নিরাপত্তার জন্য গুরুত্বপূর্ণ, কারণ এটি ট্র্যাক করতে সহায়তা করে কোন ব্যবহারকারী কোন কাজ করেছেন এবং কখন করেছেন।

SQL Server-এ Audit করতে হলে SQL Server Audit ফিচার ব্যবহার করা হয়। এটি ডেটাবেসের অ্যাক্সেস, পরিবর্তন এবং অন্যান্য কার্যকলাপ রেকর্ড করে।

3.1.1. SQL Server Audit শুরু করা
CREATE SERVER AUDIT AuditExample
TO FILE (FILEPATH = 'C:\AuditLogs\');
GO

CREATE SERVER AUDIT SPECIFICATION AuditSpec
FOR SERVER AUDIT AuditExample
ADD (SUCCESSFUL_LOGIN_GROUP, FAILED_LOGIN_GROUP)
WITH (STATE = ON);
GO

এই কোডটি একটি Audit তৈরি করবে যা সফল এবং ব্যর্থ লগইন চেষ্টা ট্র্যাক করবে এবং লগফাইলে সংরক্ষণ করবে।

3.2. Logging কী? (What is Logging?)

Logging হল ডেটাবেসে হওয়া কার্যকলাপের একটি বিস্তারিত রেকর্ড রাখা। সাধারণত, এটি ডেটাবেস অ্যাপ্লিকেশন বা সার্ভার সাইড কার্যকলাপ ট্র্যাক করতে ব্যবহৃত হয়।

SQL Server-এ Error Log ব্যবহৃত হয় সিস্টেমের গুরুত্বপূর্ণ ঘটনা ট্র্যাক করতে। এটি ডেটাবেসের ত্রুটি, সতর্কতা, এবং অন্যান্য কার্যকলাপ সংক্রান্ত তথ্য সংরক্ষণ করে।

3.2.1. SQL Server Error Log দেখতে
EXEC xp_readerrorlog;
GO

এই কোডটি SQL Server-এর ত্রুটি লগ এবং অন্যান্য সিস্টেমের কার্যকলাপের রেকর্ড দেখাবে।


4. Database Security Best Practices

ডেটাবেস সিকিউরিটির উন্নতির জন্য কিছু Best Practices অনুসরণ করা যেতে পারে:

  • Strong Password Policies: শক্তিশালী পাসওয়ার্ড নীতি ব্যবহার করুন।
  • Least Privilege Principle: ব্যবহারকারীকে তাদের কাজের জন্য প্রয়োজনীয় কমপক্ষে অ্যাক্সেস প্রদান করুন।
  • Data Encryption: সংবেদনশীল ডেটা এনক্রিপ্ট করুন যাতে সেটি নিরাপদ থাকে।
  • Regular Audits: নিয়মিত অডিট পরিচালনা করুন এবং সন্দেহজনক কার্যকলাপ মনিটর করুন।
  • Backup Security: ডেটাবেস ব্যাকআপ নিরাপদে সংরক্ষণ করুন এবং নিয়মিত পরীক্ষা করুন।

সারাংশ

Database Security এবং User Management ডেটাবেসের সুরক্ষা নিশ্চিত করতে এবং ব্যবহারকারীদের অ্যাক্সেস নিয়ন্ত্রণে রাখতে অপরিহার্য। Authentication, Authorization, Auditing, এবং Encryption হল প্রধান কৌশল যা ডেটাবেসের নিরাপত্তা নিশ্চিত করতে সাহায্য করে। User Management ব্যবস্থাপনা সঠিকভাবে পরিচালিত হলে, আপনি নিরাপদে ডেটাবেস পরিচালনা করতে পারবেন এবং একাধিক ব্যবহারকারীর জন্য অনুমতি প্রদান ও নিয়ন্ত্রণ করতে সক্ষম হবেন।

Content added By

Authentication Modes (Windows, SQL Server) এবং User Creation

352

SQL Server-এ Authentication Modes এবং User Creation হল ডেটাবেসের নিরাপত্তা ব্যবস্থাপনার গুরুত্বপূর্ণ অংশ। Authentication Modes নিয়ন্ত্রণ করে কে এবং কীভাবে SQL Server-এ লগইন করতে পারে, এবং User Creation ব্যবহৃত হয় নতুন ব্যবহারকারী বা অ্যাকাউন্ট তৈরি করার জন্য। এখানে দুটি প্রধান authentication mode রয়েছে: Windows Authentication এবং SQL Server Authentication


1. Authentication Modes in SQL Server

SQL Server-এ দুটি প্রধান authentication mode রয়েছে:

  • Windows Authentication Mode
  • SQL Server Authentication Mode

1.1. Windows Authentication Mode

এই মুডে, SQL Server ব্যবহারকারীর পরিচয় যাচাই করার জন্য Windows operating system এর ব্যবহারকারী অ্যাকাউন্ট ব্যবহার করে। SQL Server এই মোডে Windows লগইন ব্যবহারকারীদের অ্যাক্সেস প্রদান করে, এবং এখানে পাসওয়ার্ড সংরক্ষিত থাকে Windows OS-এ। এই মোডে, ব্যবহারকারীরা শুধুমাত্র তাদের Windows অ্যাকাউন্ট ব্যবহার করে SQL Server-এ লগইন করতে পারেন।

Windows Authentication Mode এর সুবিধা:

  • নিরাপত্তা: Windows-এর নিরাপত্তা ব্যবস্থাপনাই ব্যবহার করা হয়।
  • সহজ ব্যবস্থাপনা: Windows গ্রুপ এবং পলিসি ব্যবহার করে সহজে ইউজার অ্যাক্সেস কন্ট্রোল করা যায়।
  • পাসওয়ার্ড ম্যানেজমেন্ট: পাসওয়ার্ডগুলো Windows অপারেটিং সিস্টেমের মাধ্যমে ম্যানেজ করা হয়।

1.2. SQL Server Authentication Mode

এই মোডে, SQL Server নিজের ব্যবস্থাপনায় ইউজার নাম এবং পাসওয়ার্ড যাচাই করে। এটি একটি নির্দিষ্ট পাসওয়ার্ড দ্বারা SQL Server-এ লগইন করার সুযোগ দেয়, এবং এটি Windows এর সিকিউরিটি সিস্টেম থেকে স্বাধীন।

SQL Server Authentication Mode এর সুবিধা:

  • SQL Server ম্যানেজড পাসওয়ার্ড: SQL Server পাসওয়ার্ড নিজেই ম্যানেজ করে, যা Windows authentication এর বাইরে।
  • সঠিক পরিবেশে ব্যবহার উপযোগী: SQL Server Authentication Mode ব্যবহার করা যেতে পারে যখন Windows Authentication ব্যবহার সম্ভব না হয়, যেমন কিছু কাস্টম অ্যাপ্লিকেশনে বা অন্য সার্ভার অপারেটিং সিস্টেমে।

1.3. Mixed Mode Authentication

SQL Server-এ Mixed Mode Authentication ব্যবহার করা হলে, Windows Authentication এবং SQL Server Authentication উভয়ই একসাথে ব্যবহৃত হতে পারে। এর মাধ্যমে, SQL Server একটি ব্যবহারকারীকে Windows বা SQL Server পাসওয়ার্ড ব্যবহারের মাধ্যমে লগইন করার সুযোগ দেয়।

Mixed Mode Authentication এর সুবিধা:

  • উভয় authentication method ব্যবহার করা যায়, ফলে Windows Authentication এবং SQL Server Authentication উভয় ধরনের ব্যবহারকারীকে অনুমতি দেওয়া যায়।

2. User Creation in SQL Server

SQL Server-এ নতুন ব্যবহারকারী তৈরি করতে Login এবং User দুটি প্রধান পদক্ষেপ রয়েছে। Login ব্যবহারকারীকে SQL Server সার্ভারে অ্যাক্সেস দেয়, এবং User সেই লগইনের সাথে সম্পর্কিত ডেটাবেস-ভিত্তিক অ্যাক্সেস দেয়।

2.1. Login Creation

Login একটি SQL Server-এ প্রবেশের অনুমতি দেয়। লগইন তৈরির জন্য ব্যবহার করা হয় Windows Authentication বা SQL Server Authentication

Windows Authentication Mode-এ Login Creation:

  1. SQL Server Management Studio (SSMS) ওপেন করুন।
  2. Object Explorer থেকে আপনার সার্ভার সিলেক্ট করুন।
  3. Security -> Logins তে রাইট ক্লিক করুন এবং New Login নির্বাচন করুন।
  4. Login Name এ Windows লগইন নাম দিন (যেমন: DOMAIN\username).
  5. Authentication তে Windows Authentication সিলেক্ট করুন।
  6. User Mapping ট্যাব থেকে প্রয়োজনীয় ডেটাবেস সিলেক্ট করুন এবং প্রয়োজনীয় রোল সিলেক্ট করুন।
  7. OK ক্লিক করুন।

SQL Server Authentication Mode-এ Login Creation:

  1. SQL Server Management Studio (SSMS) ওপেন করুন।
  2. Object Explorer থেকে আপনার সার্ভার সিলেক্ট করুন।
  3. Security -> Logins তে রাইট ক্লিক করুন এবং New Login নির্বাচন করুন।
  4. Login Name এ লগইন নাম দিন।
  5. Authentication তে SQL Server Authentication সিলেক্ট করুন এবং পাসওয়ার্ড দিন।
  6. User Mapping ট্যাব থেকে ডেটাবেস সিলেক্ট করুন এবং প্রয়োজনীয় রোল নির্বাচন করুন।
  7. OK ক্লিক করুন।

2.2. User Creation in SQL Server

এটি একটি নির্দিষ্ট ডেটাবেসে ব্যবহারকারীর অ্যাক্সেস প্রদান করে। User তৈরির জন্য, আগে একটি Login তৈরি করতে হবে এবং তারপরে সেই লগইনকে ডেটাবেসে অ্যাক্সেস দেওয়ার জন্য User তৈরি করতে হবে।

  1. SQL Server Management Studio (SSMS) ওপেন করুন।
  2. ডেটাবেস সিলেক্ট করুন যেখানে আপনি নতুন User তৈরি করতে চান।
  3. Security -> Users তে রাইট ক্লিক করুন এবং New User নির্বাচন করুন।
  4. User Name দিন এবং Login Name এর পাশে তৈরি করা লগইনটি সিলেক্ট করুন।
  5. Default Schema যদি প্রয়োজন হয়, সেটি দিন।
  6. Roles ট্যাব থেকে প্রযোজ্য রোল সিলেক্ট করুন (যেমন: db_owner, db_datareader, db_datawriter)।
  7. OK ক্লিক করুন।

2.3. T-SQL ব্যবহার করে Login এবং User Creation

T-SQL কোডের মাধ্যমে লগইন এবং ইউজার তৈরি করা যেতে পারে। নিচে উদাহরণ দেওয়া হলো:

SQL Server Authentication Mode-এ Login এবং User Creation:

-- লগইন তৈরি করা
CREATE LOGIN myLogin WITH PASSWORD = 'StrongPassword123';

-- ইউজার তৈরি করা
USE MyDatabase;
CREATE USER myUser FOR LOGIN myLogin;
ALTER ROLE db_datareader ADD MEMBER myUser;  -- ইউজারকে db_datareader রোল দেওয়া

Windows Authentication Mode-এ Login এবং User Creation:

-- Windows Authentication দিয়ে লগইন তৈরি করা
CREATE LOGIN [DOMAIN\myUser] FROM WINDOWS;

-- ইউজার তৈরি করা
USE MyDatabase;
CREATE USER myUser FOR LOGIN [DOMAIN\myUser];
ALTER ROLE db_datareader ADD MEMBER myUser;  -- ইউজারকে db_datareader রোল দেওয়া

3. User Permission Assignment

একবার ব্যবহারকারী তৈরি হলে, আপনি তাদের বিভিন্ন ডেটাবেসের কাজ করার অনুমতি (permissions) প্রদান করতে পারেন। SQL Server-এ GRANT, REVOKE, এবং DENY কমান্ডের মাধ্যমে ব্যবহারকারীর অনুমতি কনফিগার করা হয়।

-- ইউজারকে SELECT অনুমতি দেওয়া
GRANT SELECT ON dbo.MyTable TO myUser;

-- ইউজারকে UPDATE অনুমতি দেওয়া
GRANT UPDATE ON dbo.MyTable TO myUser;

-- ইউজারকে DELETE অনুমতি থেকে রোধ করা
DENY DELETE ON dbo.MyTable TO myUser;

সারাংশ

SQL Server-এ Authentication Modes এবং User Creation দুটি গুরুত্বপূর্ণ বিষয় যা নিরাপত্তা ব্যবস্থাপনায় সাহায্য করে। Windows Authentication ব্যবহার করলে Windows OS-এ লগইন করা ব্যবহারকারীরা SQL Server-এ প্রবেশ করতে পারে, আর SQL Server Authentication ব্যবহারকারীরা SQL Server দ্বারা পরিচালিত পাসওয়ার্ড ব্যবহার করে প্রবেশ করতে পারেন। Mixed Mode ব্যবহারে উভয় Authentication Method ব্যবহার করা যায়। User Creation প্রক্রিয়ায় লগইন তৈরি করে, তারপর সেই লগইন দিয়ে ব্যবহারকারীকে নির্দিষ্ট ডেটাবেসে অ্যাক্সেস প্রদান করা হয়।

Content added By

Roles এবং Permissions ম্যানেজমেন্ট

290

Roles এবং Permissions হল SQL Server-এ ডেটাবেস নিরাপত্তা ব্যবস্থার গুরুত্বপূর্ণ অংশ। এগুলি ডেটাবেস অ্যাক্সেস কন্ট্রোল এবং ব্যবহারকারীদের বিভিন্ন ডেটাবেস অপারেশনের উপর নিয়ন্ত্রণ নিশ্চিত করতে ব্যবহৃত হয়। SQL Server-এ Roles ব্যবহারকারীদের জন্য বিভিন্ন ধরনের ভূমিকা (role) নির্ধারণ করতে সাহায্য করে এবং Permissions নির্ধারণ করে যে, কোন ব্যবহারকারী কোন ডেটাবেস অবজেক্টে (যেমন টেবিল, ভিউ, বা স্টোরড প্রসিডিউর) কি ধরনের অ্যাক্সেস পাবে।


1. Roles (ভূমিকা)

Role হল একটি গ্রুপ বা সেট যা এক বা একাধিক Permissions ধারণ করে। SQL Server-এ দুটি ধরনের Roles রয়েছে: Server Roles এবং Database Roles

1.1. Server Roles

Server Roles হল সার্ভার লেভেল ভূমিকা, যা সার্ভারের মধ্যে একাধিক ডেটাবেসের ওপর অ্যাক্সেস এবং নিয়ন্ত্রণ পরিচালনা করে। কিছু সাধারণ Server Roles হল:

  • sysadmin: এই রোলটি সর্বোচ্চ অধিকার প্রদান করে এবং সমস্ত সার্ভার এবং ডেটাবেস অপারেশন সম্পাদন করতে সক্ষম।
  • serveradmin: সার্ভারের কনফিগারেশন এবং চালনা সম্পর্কিত কাজ পরিচালনা করে।
  • securityadmin: সার্ভার এবং ডেটাবেসে নিরাপত্তা কনফিগারেশন এবং নিরাপত্তা সম্পর্কিত কাজগুলো পরিচালনা করে।
  • dbcreator: নতুন ডেটাবেস তৈরি এবং ডেটাবেস মুছে ফেলার ক্ষমতা প্রদান করে।

1.2. Database Roles

Database Roles ডেটাবেস স্তরের ভূমিকা, যা ব্যবহারকারীকে ডেটাবেসের ভিতরে নির্দিষ্ট কাজ সম্পাদন করতে অনুমতি দেয়। কিছু সাধারণ Database Roles হল:

  • db_owner: এই রোলটি সমস্ত ডেটাবেস কার্যক্রম সম্পাদন করার অধিকার দেয়, যেমন টেবিল তৈরি, ডেটা আপডেট করা, ডেটাবেস কনফিগারেশন পরিবর্তন করা ইত্যাদি।
  • db_datareader: এই রোলটি ব্যবহারকারীকে ডেটাবেসের সমস্ত টেবিল এবং ভিউ থেকে ডেটা পড়ার অনুমতি দেয়।
  • db_datawriter: এই রোলটি ব্যবহারকারীকে ডেটাবেসের টেবিল এবং ভিউতে ডেটা সন্নিবেশ, আপডেট এবং মুছে ফেলার অনুমতি দেয়।
  • db_ddladmin: এই রোলটি ব্যবহারকারীকে ডেটাবেসের অবজেক্ট (যেমন টেবিল, ভিউ, ইনডেক্স) তৈরি এবং মুছে ফেলতে অনুমতি দেয়।

1.3. Role তৈরি করা

নিজস্ব Role তৈরি করতে পারেন, যা নির্দিষ্ট কাজ বা অ্যাক্সেস কন্ট্রোলের জন্য নির্ধারণ করা হয়:

CREATE ROLE SalesRole;

এটি একটি SalesRole নামক নতুন রোল তৈরি করবে। এরপর, আপনি এটি ব্যবহারকারীকে অ্যাসাইন করতে পারেন:

EXEC sp_addrolemember 'SalesRole', 'JohnDoe';

এখানে, JohnDoe ব্যবহারকারীকে SalesRole রোলে অ্যাসাইন করা হয়েছে।


2. Permissions (অনুমতি)

Permissions হল সেই অধিকার যা ডেটাবেস অবজেক্টের ওপর নির্দিষ্ট অপারেশন চালানোর অনুমতি দেয়। SQL Server-এ আপনি বিভিন্ন ধরনের Permissions নির্ধারণ করতে পারেন, যেমন:

  • SELECT: টেবিল বা ভিউ থেকে ডেটা পড়ার অনুমতি।
  • INSERT: টেবিল বা ভিউতে নতুন ডেটা সন্নিবেশ করার অনুমতি।
  • UPDATE: টেবিল বা ভিউতে বিদ্যমান ডেটা আপডেট করার অনুমতি।
  • DELETE: টেবিল বা ভিউ থেকে ডেটা মুছে ফেলার অনুমতি।
  • EXECUTE: স্টোরড প্রসিডিউর বা ফাংশন চালানোর অনুমতি।

2.1. Permissions অ্যাসাইন করা

GRANT স্টেটমেন্ট ব্যবহার করে ব্যবহারকারীদের নির্দিষ্ট Permissions প্রদান করা হয়:

GRANT SELECT, INSERT ON Employees TO JohnDoe;

এখানে, JohnDoe ব্যবহারকারীকে Employees টেবিলের SELECT এবং INSERT অপারেশনের অনুমতি দেয়া হয়েছে।

2.2. Permissions প্রত্যাহার করা

যদি কোনো ব্যবহারকারীকে নির্দিষ্ট Permissions প্রত্যাহার করতে চান, তবে REVOKE স্টেটমেন্ট ব্যবহার করতে পারেন:

REVOKE INSERT ON Employees FROM JohnDoe;

এটি JohnDoe ব্যবহারকারীর Employees টেবিলের INSERT অনুমতি প্রত্যাহার করবে।

2.3. Permissions বাতিল করা

DENY স্টেটমেন্ট ব্যবহার করে নির্দিষ্ট Permissions পুরোপুরি বাতিল করা যেতে পারে, যার ফলে ব্যবহারকারী সেই অনুমতি পাবেন না, এমনকি অন্য রোলের মাধ্যমে যদি অনুমতি দেওয়া হয় তাও কার্যকর হবে না।

DENY DELETE ON Employees TO JohnDoe;

এটি JohnDoe ব্যবহারকারীকে Employees টেবিলের DELETE অনুমতি বাতিল করবে।


3. Roles এবং Permissions এর ব্যবস্থাপনা

SQL Server-এ Roles এবং Permissions ব্যবস্থাপনার কিছু গুরুত্বপূর্ণ বিষয়:

  • Roles ব্যবহারকারীকে নির্দিষ্ট কাজের জন্য অনুমতি প্রদান করে এবং Permissions নির্দিষ্ট ডেটাবেস অবজেক্টের উপর কাজ করার অনুমতি দেয়।
  • ব্যবহারকারীকে একাধিক Roles অ্যাসাইন করা যেতে পারে, এবং একটি রোলের মধ্যে একাধিক Permissions থাকতে পারে।
  • Permissions শুধু নির্দিষ্ট ডেটাবেস অবজেক্টের জন্যই নয়, বরং সার্ভার লেভেলেও নির্ধারণ করা যেতে পারে (যেমন, সার্ভার রোল বা ডেটাবেস রোলের মাধ্যমে)।

3.1. Roles এবং Permissions এর মধ্যকার সম্পর্ক

  • Roles ব্যবহৃত হয় Permissions গ্রুপ করতে এবং ব্যবহারকারীদের সহজে অ্যাক্সেস প্রদান করতে।
  • একাধিক ব্যবহারকারীকে একই Permissions দেওয়া হলে, রোল ব্যবহারের মাধ্যমে তা আরও কার্যকরী ও সহজ হয়ে ওঠে।

4. Security Model

SQL Server-এ রোল এবং পারমিশন ব্যবস্থাপনা Security Model এর অংশ। এই মডেলটি ব্যবহারকারীদের বিভিন্ন ধরনের অ্যাক্সেস কন্ট্রোল করে, যাতে ডেটাবেসের নিরাপত্তা নিশ্চিত হয়। এটি আপনাকে বিভিন্ন স্তরের নিরাপত্তা প্রদান করে, যেমন:

  • Server-level security: সার্ভার পরিচালনাকারী ব্যবহারকারীরা সার্ভার এবং ডেটাবেসের সব অ্যাক্সেস পরিচালনা করতে পারে।
  • Database-level security: ডেটাবেসের ব্যবহারকারীরা ডেটাবেসের নির্দিষ্ট ডেটা অবজেক্টের অ্যাক্সেস নিয়ন্ত্রণ করতে পারে।
  • Object-level security: নির্দিষ্ট ডেটাবেস অবজেক্ট (যেমন টেবিল, ভিউ, স্টোরড প্রসিডিউর) এর উপর অ্যাক্সেস কন্ট্রোল করা যায়।

Roles এবং Permissions ব্যবস্থাপনা SQL Server-এর শক্তিশালী নিরাপত্তা ফিচার, যা ডেটাবেসের তথ্য এবং অ্যাক্সেস নিয়ন্ত্রণকে অত্যন্ত সুসংহত এবং কার্যকর করে।

Content added By

Schema Level Security এবং Object Level Security

276

SQL Server-এ Security এর দুটি গুরুত্বপূর্ণ স্তর রয়েছে: Schema Level Security এবং Object Level Security। এগুলি ডেটাবেসের মধ্যে তথ্য সুরক্ষা এবং অ্যাক্সেস কন্ট্রোল বজায় রাখার জন্য ব্যবহৃত হয়। এই দুটি স্তর ব্যবহার করে আপনি নির্দিষ্ট স্কিমা বা অবজেক্টের ওপর অনুমতি (permissions) এবং নিরাপত্তা নীতি নির্ধারণ করতে পারেন।


1. Schema Level Security

Schema Level Security মূলত ডেটাবেসের schema স্তরে নিরাপত্তা কন্ট্রোল ব্যবস্থাপনাকে নির্দেশ করে। Schema একটি স্কেলাবল ধারণা যা ডেটাবেসের টেবিল, ভিউ, স্টোরড প্রোসিজার, ফাংশন এবং অন্যান্য অবজেক্টকে একত্রিত করে। এক বা একাধিক স্কিমাতে অন্তর্ভুক্ত অবজেক্টগুলির ওপর ব্যবহারকারী বা রোলগুলির অ্যাক্সেস কন্ট্রোল করা হয়।

1.1. Schema এর ধারণা

SQL Server এ, একটি schema একটি কন্টেইনার হিসেবে কাজ করে, যা একটি ডেটাবেসের অবজেক্টগুলিকে গ্রুপ করে রাখে। একটি schema এর মধ্যে থাকা সমস্ত অবজেক্ট একই মালিকানাধীন হতে পারে এবং এটি একাধিক ব্যবহারকারী বা রোলের মাধ্যমে অ্যাক্সেসযোগ্য হতে পারে। সাধারণভাবে, schema নিরাপত্তা সেটিংস দ্বারা প্রভাবিত হয়, যার মাধ্যমে আপনি স্কিমার মধ্যে থাকা অবজেক্টগুলোর ওপর নিয়ন্ত্রণ রাখতে পারেন।

1.2. Schema Level Permissions

Schema Level Security ব্যবহারের মাধ্যমে, আপনি পুরো schema এর ওপর একটি নির্দিষ্ট ব্যবহারকারী বা রোলের জন্য বিভিন্ন অনুমতি প্রদান করতে পারেন। যেমন:

  • SELECT: একটি schema-এর টেবিল বা ভিউ থেকে ডেটা পড়ার অনুমতি।
  • INSERT: একটি schema-এর টেবিল বা ভিউতে ডেটা সন্নিবেশ করার অনুমতি।
  • UPDATE: একটি schema-এর টেবিল বা ভিউতে ডেটা পরিবর্তন করার অনুমতি।
  • DELETE: একটি schema-এর টেবিল বা ভিউ থেকে ডেটা মুছে ফেলার অনুমতি।
  • ALTER: schema-র অবজেক্টগুলির কাঠামো পরিবর্তন করার অনুমতি।
  • CONTROL: schema-র সম্পূর্ণ নিয়ন্ত্রণ, যেমন, অবজেক্ট তৈরি এবং মুছে ফেলা।

1.3. Schema Level Security এর উদাহরণ

ধরা যাক, আপনি Sales নামের একটি schema তৈরি করেছেন এবং এই schema-এর মধ্যে টেবিল, ভিউ, প্রোসিজার ইত্যাদি রয়েছে। আপনি যদি Sales schema-এর সমস্ত অবজেক্টে একটি নির্দিষ্ট ব্যবহারকারীকে অ্যাক্সেস দিতে চান, তবে নিম্নলিখিত SQL কোডটি ব্যবহার করতে পারেন:

GRANT SELECT, INSERT, UPDATE, DELETE ON SCHEMA::Sales TO SalesUser;

এটি SalesUser নামক ব্যবহারকারীকে Sales schema এর সমস্ত অবজেক্টে SELECT, INSERT, UPDATE, এবং DELETE অনুমতি দেবে।


2. Object Level Security

Object Level Security হল SQL Server এ ডেটাবেসের অবজেক্ট যেমন টেবিল, ভিউ, স্টোরড প্রোসিজার, ফাংশন ইত্যাদির উপর নিরাপত্তা কন্ট্রোল। এটি আপনাকে আরও সূক্ষ্ম নিয়ন্ত্রণ দিতে সাহায্য করে, যেখানে আপনি একটি নির্দিষ্ট অবজেক্টের ওপর নির্দিষ্ট ব্যবহারকারী বা রোলের অ্যাক্সেস অনুমতি কাস্টমাইজ করতে পারেন।

2.1. Object Level Permissions

Object Level Security এর মাধ্যমে আপনি বিশেষ অবজেক্টের জন্য GRANT, DENY, অথবা REVOKE অপারেশন করতে পারেন। এখানে কিছু সাধারণ permissions উল্লেখ করা হল:

  • SELECT: টেবিল বা ভিউ থেকে ডেটা পড়ার অনুমতি।
  • INSERT: টেবিল বা ভিউতে ডেটা সন্নিবেশ করার অনুমতি।
  • UPDATE: টেবিল বা ভিউতে ডেটা পরিবর্তন করার অনুমতি।
  • DELETE: টেবিল বা ভিউ থেকে ডেটা মুছে ফেলার অনুমতি।
  • EXECUTE: স্টোরড প্রোসিজার বা ফাংশন চালানোর অনুমতি।
  • ALTER: টেবিল বা ভিউ-এর কাঠামো পরিবর্তন করার অনুমতি।
  • CONTROL: পুরো অবজেক্টে সম্পূর্ণ নিয়ন্ত্রণ, যা অন্তর্ভুক্ত করে CREATE, ALTER, এবং DROP অনুমতি।

2.2. Object Level Security এর উদাহরণ

আপনি যদি একটি নির্দিষ্ট টেবিলের উপর শুধুমাত্র একটি ব্যবহারকারীকে ডেটা পড়ার অনুমতি দিতে চান, তবে এটি করা যেতে পারে নিচের কোডের মাধ্যমে:

GRANT SELECT ON dbo.Employees TO UserName;

এটি dbo.Employees টেবিলের উপর শুধুমাত্র UserName ব্যবহারকারীকে SELECT করার অনুমতি দেবে।

এছাড়া, একটি ব্যবহারকারীকে একটি টেবিলের INSERT এবং UPDATE অনুমতি না দিয়ে শুধু SELECT করার অনুমতি দিতে:

GRANT SELECT ON dbo.Employees TO UserName;
DENY INSERT, UPDATE ON dbo.Employees TO UserName;

2.3. Permissions Denial and Revocation

Object Level Security তে আপনি permissions কে সরাসরি DENY বা REVOKE করতে পারেন। DENY অর্থাৎ কোনো নির্দিষ্ট permission এর বিরুদ্ধে নিষেধাজ্ঞা আরোপ করা, এবং REVOKE মানে পূর্বে দেওয়া অনুমতি প্রত্যাহার করা।

  • DENY:

    DENY SELECT ON dbo.Employees TO UserName;
    
  • REVOKE:

    REVOKE SELECT ON dbo.Employees FROM UserName;
    

3. Schema এবং Object Level Security এর মধ্যে পার্থক্য

  • Scope: Schema Level Security একটি স্কিমার মধ্যে সব অবজেক্টের জন্য একযোগে অনুমতি প্রদান ও নিয়ন্ত্রণ করার উপায়, যেখানে Object Level Security নির্দিষ্ট অবজেক্টের জন্য কাস্টম অনুমতি কন্ট্রোল দেয়।
  • Granularity: Schema level permission বড় পরিসরে ব্যবহৃত হয়, যা পুরো schema কে কাভার করে। Object level permission খুবই সুনির্দিষ্ট এবং একক অবজেক্টের জন্য।

4. Conclusion

Schema Level Security এবং Object Level Security SQL Server এর নিরাপত্তা কন্ট্রোলের দুটি গুরুত্বপূর্ণ অংশ। Schema Level Security আপনাকে একটি পুরো স্কিমা বা সেট অব অবজেক্টের ওপর নিরাপত্তা কন্ট্রোল করতে সাহায্য করে, যেখানে Object Level Security আপনাকে প্রতিটি অবজেক্টের জন্য নির্দিষ্ট নিরাপত্তা সেট করতে সক্ষম করে। আপনার ডেটাবেসে নিরাপত্তা ব্যবস্থাপনা কার্যকরী করতে উভয় স্তরের নিরাপত্তার সঠিক ব্যবহার অত্যন্ত গুরুত্বপূর্ণ।

Content added By

Data Encryption এবং Transparent Data Encryption (TDE)

290

Data Encryption এবং Transparent Data Encryption (TDE) হলো ডেটাবেস সুরক্ষা ব্যবস্থার গুরুত্বপূর্ণ অংশ, যা ডেটা প্রাইভেসি নিশ্চিত করে এবং অবৈধ অ্যাক্সেস থেকে রক্ষা করে। Encryption হল একটি প্রক্রিয়া যার মাধ্যমে ডেটাকে একটি নিরাপদ ফরম্যাটে রূপান্তরিত করা হয়, যাতে এটি শুধুমাত্র সঠিক কীগুলির মাধ্যমে পাঠযোগ্য হয়। TDE হল SQL Server এর একটি বিশেষ ধরনের Encryption প্রযুক্তি যা ডেটাবেস ফাইল এবং ডেটা ফাইলের ফিজিক্যাল সুরক্ষা নিশ্চিত করে।


1. Data Encryption (ডেটা এনক্রিপশন)

Data Encryption হল একটি প্রক্রিয়া যা ডেটাকে একটি নির্দিষ্ট অ্যালগরিদমের মাধ্যমে এনক্রিপ্ট (গোপন) করে, যাতে শুধুমাত্র অনুমোদিত ব্যক্তিরা (যাদের কাছে ডিক্রিপশন কীগুলি থাকে) সেই ডেটা দেখতে পারে। এটি ডেটার নিরাপত্তা এবং গোপনীয়তা বজায় রাখে, বিশেষত যখন ডেটা ট্রান্সমিট করা হয় বা স্টোর করা হয়।

1.1. Data Encryption এর প্রকার

  • At-Rest Encryption: ডেটা যখন স্টোর (যেমন ডেটাবেস, ফাইল সিস্টেমে) করা হয়, তখন তাকে এনক্রিপ্ট করা হয়। এটি স্টোর করা ডেটার সুরক্ষা নিশ্চিত করে। SQL Server তে TDE (Transparent Data Encryption) এই ধরনের এনক্রিপশনের উদাহরণ।
  • In-Transit Encryption: যখন ডেটা এক জায়গা থেকে অন্য জায়গায় ট্রান্সমিট হয়, তখন তাকে এনক্রিপ্ট করা হয়। SQL Server-এ SSL/TLS ব্যবহার করে ডেটার ট্রান্সমিশন এনক্রিপ্ট করা যায়।

1.2. Encryption Key Management

এনক্রিপশনের ক্ষেত্রে কী ম্যানেজমেন্ট অত্যন্ত গুরুত্বপূর্ণ। ডেটা এনক্রিপ্ট করতে একটি encryption key ব্যবহৃত হয় এবং এই কীগুলি সঠিকভাবে ম্যানেজ করা না হলে ডেটার নিরাপত্তা ঝুঁকির মধ্যে পড়তে পারে। SQL Server এ Always Encrypted এবং Column-Level Encryption এর মাধ্যমে ডেটা এনক্রিপ্ট করা যায়।


2. Transparent Data Encryption (TDE)

Transparent Data Encryption (TDE) হল SQL Server এর একটি প্রযুক্তি যা ডেটাবেসের data at rest এনক্রিপ্ট করে। এটি ডেটাবেস ফাইল (যেমন .mdf, .ldf) এবং ডেটাবেসের সিস্টেম ফাইল গুলোর এনক্রিপশন নিশ্চিত করে। TDE এর মাধ্যমে ডেটা এনক্রিপশন এবং ডিক্রিপশন স্বয়ংক্রিয়ভাবে SQL Server এর মধ্যে সম্পাদিত হয়, অর্থাৎ ব্যবহারকারীদের কোন কোড পরিবর্তন করতে হয় না।

TDE এর মাধ্যমে ডেটাবেসের ফাইলগুলিকে এনক্রিপ্ট করা যায়, যা সার্ভার-স্তরের সুরক্ষা প্রদান করে এবং ফিজিক্যালি ডেটাবেস ফাইলগুলি চুরি বা অননুমোদিত অ্যাক্সেস থেকে রক্ষা পায়।

2.1. TDE এর বৈশিষ্ট্য

  • End-to-End Data Protection: TDE ডেটাবেস ফাইল এবং অন্যান্য ডেটা ফাইলগুলো এনক্রিপ্ট করে এবং ডেটাবেসে লেখা, আপডেট বা ডিলিট করা ডেটা এনক্রিপ্ট এবং ডিক্রিপ্ট হয়।
  • Transparent Operation: TDE এনক্রিপশনটি স্বচ্ছ (transparent), অর্থাৎ ব্যবহারকারীদের বা অ্যাপ্লিকেশনগুলিকে কোনো কোড পরিবর্তন করতে হয় না। সব এনক্রিপশন এবং ডিক্রিপশন SQL Server দ্বারা স্বয়ংক্রিয়ভাবে পরিচালিত হয়।
  • Key Management: TDE ব্যবহারে, SQL Server একটি Database Encryption Key (DEK) তৈরি করে, যা ডেটাবেসের সমস্ত ডেটা এনক্রিপ্ট করতে ব্যবহৃত হয়। DEK টি একটি Certificate বা Asymmetric Key দ্বারা সুরক্ষিত থাকে।

2.2. TDE এর উপকারিতা

  • Data Breach Prevention: TDE ডেটাবেস ফাইলগুলিকে এনক্রিপ্ট করে, তাই ডেটাবেস ফাইল যদি চুরি হয়ে যায়, তবে ডেটা অ্যাক্সেস করা সম্ভব হবে না।
  • Compliance: অনেক প্রতিষ্ঠান এবং ইন্ডাস্ট্রি স্ট্যান্ডার্ড যেমন HIPAA, PCI-DSS ইত্যাদির জন্য ডেটা এনক্রিপশন একটি প্রয়োজনীয় শর্ত। TDE এর মাধ্যমে এই ধরনের কমপ্লায়েন্স বজায় রাখা সহজ হয়।
  • No Impact on Performance: TDE স্বচ্ছভাবে কাজ করে এবং সাধারণত এর ব্যবহার পারফরম্যান্সে কোনো উল্লেখযোগ্য প্রভাব ফেলে না।

2.3. TDE কনফিগারেশন

TDE কনফিগারেশন করতে, আপনি নিম্নলিখিত পদক্ষেপগুলো অনুসরণ করতে পারেন:

  1. Create a Database Master Key (DMK):

    CREATE DATABASE MASTER KEY ENCRYPTION BY PASSWORD = 'yourStrongPassword';
    
  2. Create a Certificate for the Database Encryption Key:

    CREATE CERTIFICATE TDECertificate
    WITH SUBJECT = 'TDE Encryption Certificate';
    
  3. Create the Database Encryption Key:

    CREATE DATABASE ENCRYPTION KEY;
    
  4. Enable TDE Encryption:

    ALTER DATABASE YourDatabaseName SET ENCRYPTION ON;
    
  5. Backup the Certificate: Always back up the certificate and the private key to ensure that you can restore the encryption in case of a disaster.

    BACKUP CERTIFICATE TDECertificate TO FILE = 'path_to_backup_file';
    
  6. Monitor Encryption Status: To verify if the database encryption is enabled:

    SELECT encryption_state 
    FROM sys.dm_database_encryption_keys;
    

3. Key Differences between Data Encryption and Transparent Data Encryption (TDE)

FeatureData EncryptionTransparent Data Encryption (TDE)
ScopeCan be applied at the column or file levelApplies to entire database files and logs
Encryption MethodColumn-level or file-level encryptionTransparent encryption at the database level
Performance ImpactCan have performance impact based on encryption methodMinimal impact due to transparent encryption
Use CaseUsed for specific data security (e.g., credit card numbers)Used for securing entire database files at rest
TransparencyMay require application changes (e.g., for column encryption)Transparent to applications and users
Key ManagementEncryption keys are user-definedManaged by SQL Server automatically (via certificates)

4. Conclusion

Data Encryption এবং Transparent Data Encryption (TDE) উভয়ই SQL Server এর মধ্যে ডেটার নিরাপত্তা এবং গোপনীয়তা নিশ্চিত করতে অত্যন্ত গুরুত্বপূর্ণ। যেখানে Data Encryption সাধারণত একটি নির্দিষ্ট কলাম বা ফাইলকে এনক্রিপ্ট করার জন্য ব্যবহৃত হয়, সেখানে TDE ডেটাবেসের সমগ্র ডেটা ফাইলগুলো এনক্রিপ্ট করে। TDE সহজে প্রয়োগযোগ্য এবং ব্যবহারকারীকে কোনো কোড পরিবর্তন করতে হয় না, যা এটি একটি অত্যন্ত জনপ্রিয় সুরক্ষা পদ্ধতি বানায়।

Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...