লারাভেল কনফিগারেশন Laravel ফ্রেমওয়ার্কের মূল উপাদানগুলির মধ্যে একটি এবং এটি অ্যাপ্লিকেশন সেটিংস এবং চাহিদা অনুযায়ী কাস্টমাইজ করার সুযোগ দেয়। নিচে Laravel কনফিগারেশনের বিভিন্ন দিক নিয়ে বিস্তারিত আলোচনা করা হলো:
Laravel-এর সমস্ত কনফিগারেশন ফাইলগুলি config/ ডিরেক্টরিতে অবস্থিত। প্রতিটি কনফিগারেশন ফাইল নির্দিষ্ট সিস্টেম বা ফিচারের জন্য ব্যবহার করা হয়। উদাহরণস্বরূপ:
Laravel-এর প্রধান কনফিগারেশন ফাইল হলো .env। এই ফাইলটি পরিবেশ(env )-নির্ভর কনফিগারেশন রাখতে ব্যবহার করা হয়। অ্যাপ্লিকেশন লোকাল, স্টেজিং বা প্রোডাকশন পরিবেশে চলে তার উপর ভিত্তি করে বিভিন্ন মান সেট করা যায়।
.env ফাইলে আপনি বিভিন্ন গুরুত্বপূর্ণ কনফিগারেশন রাখবেন, যেমন:
APP_NAME=Laravel
APP_ENV=local
APP_KEY=base64:.....
APP_DEBUG=true
APP_URL=http://localhost
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=laravel
DB_USERNAME=root
DB_PASSWORD=
MAIL_MAILER=smtp
MAIL_HOST=smtp.mailtrap.io
MAIL_PORT=2525
MAIL_USERNAME=null
MAIL_PASSWORD=null
MAIL_ENCRYPTION=null
Environment Configuration Laravel 11-এর একটি গুরুত্বপূর্ণ অংশ, যা অ্যাপ্লিকেশনের পরিবেশভিত্তিক সেটিংস নির্ধারণ করে। Laravel বিভিন্ন পরিবেশ যেমন ডেভেলপমেন্ট, স্টেজিং এবং প্রোডাকশনের জন্য ভিন্ন কনফিগারেশন সমর্থন করে। পরিবেশভিত্তিক এই কনফিগারেশন Laravel-এর .env ফাইল এবং config/ ডিরেক্টরির মাধ্যমে নিয়ন্ত্রণ করা হয়।
Laravel বিভিন্ন পরিবেশের জন্য আলাদা আলাদা কনফিগারেশন ব্যবহার করে অ্যাপ্লিকেশন ডেপ্লয়মেন্ট ও ডেভেলপমেন্ট প্রক্রিয়াকে সহজ করে। উদাহরণস্বরূপ, লোকাল ডেভেলপমেন্টের সময় অ্যাপ্লিকেশন ডিবাগ মোডে থাকতে পারে, যেখানে প্রোডাকশনে এটি নিরাপত্তার জন্য বন্ধ রাখা হতে পারে।
Laravel 11 পরিবেশভিত্তিক কনফিগারেশন পরিচালনার জন্য .env ফাইল ব্যবহার করে। এই ফাইলটি অ্যাপ্লিকেশনের রুট ডিরেক্টরিতে অবস্থিত এবং এতে অ্যাপ্লিকেশনের গোপনীয় এবং পরিবেশের ওপর নির্ভরশীল সেটিংস থাকে।
.env ফাইলের উদাহরণ উপরে দেখানো হয়েছে।
Laravel-এর কনফিগারেশন ফাইলগুলি, যেমন config/app.php, config/database.php, ইত্যাদি, .env ফাইল থেকে মান নিয়ে কাজ করে। উদাহরণস্বরূপ:
// config/app.php
return [
'name' => env('APP_NAME', 'Laravel'),
'env' => env('APP_ENV', 'production'),
'debug' => env('APP_DEBUG', false),
'url' => env('APP_URL', 'http://localhost'),
];
উপরের কোডে env() ফাংশন ব্যবহার করে .env ফাইল থেকে মান নেওয়া হচ্ছে। যদি .env ফাইলে কোনো মান পাওয়া না যায়, তাহলে ডিফল্ট মান সেট করা হয় (যেমন 'Laravel', 'production')।
আপনি প্রতিটি পরিবেশের জন্য আলাদা .env ফাইল তৈরি করতে পারেন। উদাহরণস্বরূপ, ডেভেলপমেন্টের জন্য একটি .env.local ফাইল এবং প্রোডাকশনের জন্য .env.production ফাইল থাকতে পারে।
APP_ENV=production
APP_DEBUG=false
APP_URL=https://your-production-url.com
DB_CONNECTION=mysql
DB_HOST=your-production-host
DB_PORT=3306
DB_DATABASE=production_db
DB_USERNAME=production_user
DB_PASSWORD=production_password
APP_ENV=local
APP_DEBUG=true
APP_URL=http://localhost
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=local_db
DB_USERNAME=root
DB_PASSWORD=root
Laravel-এ Environment Variable হলো কনফিগারেশন তথ্য যা অ্যাপ্লিকেশনের বিভিন্ন পরিবেশ (local, production, staging) অনুযায়ী পরিবর্তন করা যায়। Laravel 11-এ পরিবেশভিত্তিক কনফিগারেশন ব্যবহারের জন্য .env ফাইল ব্যবহৃত হয়, যেখানে বিভিন্ন ধরনের environment variable রাখা হয়। নিচে environment variable এর ধরন এবং তাদের ভূমিকা নিয়ে বিস্তারিত আলোচনা করা হলো:
Laravel অ্যাপ্লিকেশন সম্পর্কিত কনফিগারেশন নির্দেশ করার জন্য environment variable ব্যবহৃত হয়। এগুলি অ্যাপ্লিকেশনের সাধারণ সেটিংস যেমন environment টাইপ, ডিবাগ মোড, এবং অ্যাপ্লিকেশনের URL নিয়ন্ত্রণ করে।
APP_ENV: অ্যাপ্লিকেশনের environment। এটি হতে পারে local, production, staging ইত্যাদি।
APP_ENV=local
APP_DEBUG: ডিবাগ মোড চালু বা বন্ধ করতে ব্যবহৃত হয়। ডেভেলপমেন্টের সময় true এবং প্রোডাকশনে false রাখা উচিত।
APP_DEBUG=true
APP_URL: অ্যাপ্লিকেশনের মূল URL। এটি API, asset লোডিং, এবং অন্যান্য URL ভিত্তিক কাজের জন্য ব্যবহৃত হয়।
APP_URL=http://localhost
ডাটাবেসের সাথে কানেক্ট করার জন্য environment variable ব্যবহৃত হয়। Laravel 11 ডিফল্টভাবে MySQL, PostgreSQL, SQLite, এবং SQL Server এর জন্য সাপোর্ট দেয়।
DB_CONNECTION: ডাটাবেস ড্রাইভার নির্দেশ করতে ব্যবহৃত হয়। যেমন mysql, pgsql, sqlite, ইত্যাদি।
DB_CONNECTION=mysql
DB_HOST: ডাটাবেস সার্ভারের হোস্টনেম বা IP ঠিকানা।
DB_HOST=127.0.0.1
DB_PORT: ডাটাবেস সার্ভারের পোর্ট নাম্বার।
DB_PORT=3306
DB_DATABASE: ডাটাবেসের নাম যেখানে ডেটা সংরক্ষিত হয়।
DB_DATABASE=laravel_app
DB_USERNAME এবং DB_PASSWORD: ডাটাবেসে কানেক্ট করার জন্য ইউজারনেম এবং পাসওয়ার্ড।
DB_USERNAME=root
DB_PASSWORD=
Laravel অ্যাপ্লিকেশন ক্যাশিংয়ের জন্য environment variable ব্যবহার করে।
CACHE_DRIVER: Laravel যে ক্যাশ ড্রাইভার ব্যবহার করবে তা নির্ধারণ করে। এটি file, redis, memcached, ইত্যাদি হতে পারে।
CACHE_DRIVER=file
সেশন স্টোরেজ এবং কনফিগারেশন environment variable এর মাধ্যমে নিয়ন্ত্রণ করা যায়।
SESSION_DRIVER: Laravel এর সেশন ম্যানেজমেন্টের ড্রাইভার নির্ধারণ করে। এটি file, cookie, database, redis, ইত্যাদি হতে পারে।
SESSION_DRIVER=file
SESSION_LIFETIME: সেশন কতক্ষণ থাকবে তা নির্দেশ করে (মিনিটে)।
SESSION_LIFETIME=120
Laravel অ্যাপ্লিকেশন থেকে মেইল পাঠানোর জন্য environment variable ব্যবহৃত হয়।
MAIL_MAILER: মেইল পাঠানোর ড্রাইভার নির্দেশ করে। যেমন smtp, sendmail, mailgun, ইত্যাদি।
MAIL_MAILER=smtp
MAIL_HOST: SMTP সার্ভারের হোস্টনেম।
MAIL_HOST=smtp.mailtrap.io
MAIL_PORT: SMTP সার্ভারের পোর্ট নাম্বার।
MAIL_PORT=2525
MAIL_USERNAME এবং MAIL_PASSWORD: SMTP সার্ভারের সাথে অ্যাক্সেস পাওয়ার জন্য ইউজারনেম এবং পাসওয়ার্ড।
MAIL_USERNAME=null
MAIL_PASSWORD=null
Laravel Queue এর কনফিগারেশন environment variable এর মাধ্যমে পরিচালনা করা হয়।
QUEUE_CONNECTION: Queue এর জন্য ব্যবহৃত ড্রাইভার নির্দেশ করে। এটি sync, database, redis, ইত্যাদি হতে পারে।
QUEUE_CONNECTION=sync
Broadcasting সিস্টেমের জন্য environment variable ব্যবহার করা হয়।
BROADCAST_DRIVER: Broadcasting এর জন্য ড্রাইভার নির্দেশ করে। যেমন pusher, redis, log ইত্যাদি।
BROADCAST_DRIVER=log
Laravel ফাইল সিস্টেম কনফিগারেশন environment variable দ্বারা পরিচালিত হয়।
FILESYSTEM_DISK: ডিফল্ট ফাইল সিস্টেম ড্রাইভার নির্দেশ করতে ব্যবহৃত হয়। এটি local, public, বা s3 হতে পারে।
FILESYSTEM_DISK=local
Laravel অ্যাপ্লিকেশনের লগিং ব্যবস্থা environment variable দ্বারা নিয়ন্ত্রিত হয়।
LOG_CHANNEL: লগিংয়ের ডিফল্ট চ্যানেল নির্দেশ করে। এটি stack, single, daily, syslog, ইত্যাদি হতে পারে।
LOG_CHANNEL=stack
Laravel অ্যাপ্লিকেশনগুলো এনক্রিপশন এবং নিরাপত্তার জন্য environment variable ব্যবহার করে।
APP_KEY: অ্যাপ্লিকেশনের জন্য একটি সিক্রেট কীগুলো নিরাপদ করার জন্য ব্যবহৃত হয়। এটি অ্যাপ্লিকেশনের সুরক্ষার জন্য অত্যন্ত গুরুত্বপূর্ণ।
APP_KEY=base64:...
Laravel 11-এর Environment Variables অ্যাপ্লিকেশনের বিভিন্ন দিক নিয়ন্ত্রণ এবং কনফিগারেশনের জন্য অত্যন্ত গুরুত্বপূর্ণ। .env ফাইলের মাধ্যমে পরিবেশভিত্তিক কনফিগারেশন সহজে নির্ধারণ করা যায়, যা ডেভেলপমেন্ট, প্রোডাকশন, এবং অন্যান্য পরিবেশে অ্যাপ্লিকেশনটির কার্যক্ষমতা ও নিরাপত্তা নিশ্চিত করে।
Laravel-এ চলমান environment (পরিবেশ) চেক করার জন্য আপনি Laravel এর বিভিন্ন ফাংশন এবং config ও app হেল্পার ব্যবহার করতে পারেন। Laravel অ্যাপ্লিকেশনটির environment নির্ধারণ করা থাকে .env ফাইলের APP_ENV ভ্যারিয়েবলের মাধ্যমে। এটি local, production, staging, বা অন্য কোনো কাস্টম environment হতে পারে।
Laravel এর App::environment() ফাংশন ব্যবহার করে environment চেক করা যায়। এটি আপনাকে জানাবে অ্যাপ্লিকেশনটি কোন environment এ চলছে।
উদাহরণ:
if (App::environment('local')) {
// যদি অ্যাপ্লিকেশনটি লোকাল environment এ থাকে
echo 'Running in the local environment!';
}
মাল্টিপল environment চেক করা:
if (App::environment(['staging', 'production'])) {
// যদি অ্যাপ্লিকেশনটি স্টেজিং বা প্রোডাকশনে থাকে
echo 'Running in either staging or production!';
}
app() হেল্পারের মাধ্যমে environment চেক করা যায়। environment() মেথডটি ব্যবহার করে সরাসরি অ্যাপ্লিকেশনের চলমান environment পেতে পারেন।
উদাহরণ:
if (app()->environment('production')) {
// যদি অ্যাপ্লিকেশনটি প্রোডাকশন environment এ থাকে
echo 'Running in the production environment!';
}
Laravel এর config() হেল্পার ব্যবহার করে environment চেক করতে পারেন। এটি সরাসরি app.env কনফিগারেশন থেকে environment এর মান বের করে দেয়।
$env = config('app.env');
if ($env === 'local') {
echo 'This is the local environment!';
}
Laravel 11-এ Request অবজেক্টের মাধ্যমেও environment চেক করতে পারেন।
use Illuminate\Http\Request;
$request->is('production') ? 'Production' : 'Not Production';
Laravel এ .env ফাইলে environment নির্ধারণ করতে নিচের মতো কোড ব্যবহার করা হয়:
APP_ENV=local
এই ভ্যালুটি App::environment() বা config('app.env') এর মাধ্যমে চেক করা যায়।
namespace App\Http\Controllers;
use Illuminate\Support\Facades\App;
class EnvironmentController extends Controller
{
public function index()
{
if (App::environment('local')) {
return 'This is local environment';
}
return 'This is not local environment';
}
}
Laravel 11-এ চলমান environment চেক করা খুবই সহজ। App::environment(), app()->environment(), এবং config('app.env') এর মাধ্যমে environment চেক করা যায় এবং সেই অনুযায়ী অ্যাপ্লিকেশনটি কনফিগার করা যেতে পারে।
প্রোডাকশন পরিবেশে Laravel-এর কনফিগারেশন ক্যাশ করার সুবিধা রয়েছে, যা অ্যাপ্লিকেশনের লোডিং টাইম উন্নত করতে পারে। কনফিগারেশন ক্যাশ করলে .env ফাইলের পরিবর্তন সরাসরি প্রতিফলিত হবে না, তাই ক্যাশ ক্লিয়ার করা প্রয়োজন হতে পারে।
কনফিগারেশন ক্যাশ করার জন্য কমান্ড:
php artisan config:cache
কনফিগারেশন ক্যাশ ক্লিয়ার করার জন্য:
php artisan config:clear
Laravel 11-এর Environment Configuration খুবই ফ্লেক্সিবল এবং পরিবেশভিত্তিক কনফিগারেশন পরিচালনা করা সহজ। .env ফাইল অ্যাপ্লিকেশনের গোপনীয় তথ্য এবং পরিবেশ নির্দিষ্ট সেটিংস ধারণ করে, এবং Laravel স্বয়ংক্রিয়ভাবে এই ফাইলের মানগুলি কনফিগারেশন ফাইলে প্রয়োগ করে।
Laravel আপনাকে আপনার নিজস্ব কনফিগারেশন ফাইল তৈরি করার সুযোগ দেয়। যদি আপনি কোনও নির্দিষ্ট কনফিগারেশন তৈরি করতে চান, তাহলে config/ ডিরেক্টরিতে একটি নতুন ফাইল তৈরি করে সেই ফাইলে আপনার কনফিগারেশন যুক্ত করতে পারেন।
// config/custom.php
return [
'setting1' => 'value1',
'setting2' => 'value2',
];
এরপর এই কনফিগারেশন অ্যাক্সেস করার জন্য:
$value = config('custom.setting1');
Laravel আপনাকে পরিবেশভিত্তিক কনফিগারেশন ব্যবহারের সুযোগ দেয়। উদাহরণস্বরূপ, আপনি .env ফাইলে বিভিন্ন পরিবেশে ভিন্ন ভিন্ন ডেটা সেট করতে পারবেন।
Laravel স্বয়ংক্রিয়ভাবে .env ফাইলের ভিত্তিতে সঠিক পরিবেশে চালিত হয়।
Laravel-এর কনফিগারেশনগুলো সহজে পরিবর্তন ও মাইগ্রেট করার সুবিধা দেয়। উদাহরণস্বরূপ, যদি আপনি প্রোডাকশনে নতুন ডাটাবেস বা সার্ভিস যোগ করেন, তবে .env ফাইলে পরিবর্তন করলেই কাজ হয়ে যায়।
Laravel Herd ইনস্টল ও কনফিগার করার জন্য কিছু বিশেষ সেটিংস প্রয়োজন হতে পারে, বিশেষ করে ম্যাক এবং উইন্ডোজ অপারেটিং সিস্টেমের ক্ষেত্রে। Laravel Herd সম্পর্কে বিস্তারিত কনফিগারেশন ধাপগুলো নিচের মতো হতে পারে:
ম্যাকে Laravel Herd ব্যবহারের জন্য PHP এবং অন্যান্য ডিপেন্ডেন্সি ইনস্টল করতে হয়। Laravel Herd সাধারণত স্বয়ংক্রিয়ভাবে এই ডিপেন্ডেন্সিগুলো ইনস্টল করে।
উইন্ডোজে Herd সেটআপ করার জন্য Windows Subsystem for Linux (WSL) প্রয়োজন হতে পারে।
Laravel কনফিগারেশন এত সহজ এবং কাস্টমাইজযোগ্য যে আপনি সহজেই আপনার অ্যাপ্লিকেশন অনুযায়ী সেটআপ এবং পরিচালনা করতে পারবেন।
Laravel-এ Environment File (যেমন .env) অত্যন্ত গুরুত্বপূর্ণ, কারণ এতে অ্যাপ্লিকেশনের জন্য সংবেদনশীল তথ্য (API keys, ডাটাবেস credentials, তৃতীয় পক্ষের সার্ভিস credentials) থাকে। এই তথ্যগুলোকে নিরাপদ রাখতে Laravel নিজে .env ফাইল এনক্রিপ্ট বা ডিক্রিপ্ট করার কোনো বিল্ট-ইন ফিচার সরাসরি সরবরাহ করে না। তবে .env ফাইল সুরক্ষিত রাখা খুবই গুরুত্বপূর্ণ, বিশেষ করে production সার্ভারে।
Laravel-এর .env ফাইলটি ডিফল্টভাবে এনক্রিপ্ট করা থাকে না। .env ফাইলটি সাধারণত শুধু সার্ভারে সংরক্ষণ করা হয় এবং এটি আপনার ভার্সন কন্ট্রোল সিস্টেমে অন্তর্ভুক্ত করা উচিত নয়। Laravel নিজে থেকে .env ফাইল পড়ে এবং তার মাধ্যমে কনফিগারেশন লোড করে।
যদি আপনি চান .env ফাইল এনক্রিপ্ট এবং ডিক্রিপ্ট করতে, তবে একটি কাস্টম সমাধান তৈরি করতে হবে। এটি Laravel এর বিল্ট-ইন কমান্ড বা প্যাকেজ ব্যবহারের মাধ্যমে করা যেতে পারে, যেমন:
Encryption Command: .env ফাইল এনক্রিপ্ট করতে openssl অথবা অন্য এনক্রিপশন লাইব্রেরি ব্যবহার করা যেতে পারে।
Decryption Command: ফাইলটি ডিক্রিপ্ট করার জন্য Laravel এর কোনো কাস্টম স্ক্রিপ্ট বা Artisan কমান্ড তৈরি করতে হবে।
উদাহরণস্বরূপ, Laravel Passport এবং Horizon এর মত প্যাকেজগুলো এনক্রিপশন ব্যবহার করে, যেগুলো Laravel এর APP_KEY ব্যবহার করে এনক্রিপ্টেড ডাটা তৈরি করে। এভাবে আপনি .env ফাইলের স্পর্শকাতর ডাটা এনক্রিপ্ট করতে পারেন।
প্রথমে Artisan কমান্ড তৈরি করুন:
php artisan make:command EncryptEnv
এখন app/Console/Commands/EncryptEnv.php ফাইলটি খুলে নিচের মত করে এনক্রিপশন লজিক যোগ করুন:
namespace App\Console\Commands;
use Illuminate\Console\Command;
use Illuminate\Support\Facades\Crypt;
use Illuminate\Support\Facades\File;
class EncryptEnv extends Command
{
protected $signature = 'env:encrypt';
protected $description = 'Encrypt the .env file';
public function handle()
{
$envPath = base_path('.env');
if (!File::exists($envPath)) {
$this->error('.env file not found!');
return;
}
$envContents = File::get($envPath);
$encryptedContents = Crypt::encryptString($envContents);
File::put($envPath . '.encrypted', $encryptedContents);
$this->info('.env file has been encrypted and saved as .env.encrypted');
}
}
.env ফাইল ডিক্রিপ্ট করার জন্য আরেকটি Artisan Command তৈরি করুন:
php artisan make:command DecryptEnv
এখন app/Console/Commands/DecryptEnv.php ফাইলটি এডিট করুন:
namespace App\Console\Commands;
use Illuminate\Console\Command;
use Illuminate\Support\Facades\Crypt;
use Illuminate\Support\Facades\File;
class DecryptEnv extends Command
{
protected $signature = 'env:decrypt';
protected $description = 'Decrypt the .env file';
public function handle()
{
$envPath = base_path('.env.encrypted');
if (!File::exists($envPath)) {
$this->error('.env.encrypted file not found!');
return;
}
$encryptedContents = File::get($envPath);
$decryptedContents = Crypt::decryptString($encryptedContents);
File::put(base_path('.env'), $decryptedContents);
$this->info('.env file has been decrypted.');
}
}
এখন আপনি env:encrypt এবং env:decrypt কমান্ড রান করতে পারেন:
php artisan env:encrypt php artisan env:decrypt
যদিও .env ফাইল এনক্রিপ্ট করা যায়, Laravel অ্যাপ্লিকেশনটির নিরাপত্তা রক্ষার জন্য কিছু মূল বিষয় অনুসরণ করা উচিত:
.env ফাইল কখনোই গিট রিপোজিটরিতে আপলোড করবেন না। .gitignore ফাইলে .env ফাইল যোগ করা উচিত।
প্রোডাকশন সার্ভারে .env ফাইলের জন্য ফাইল পারমিশন সঠিকভাবে কনফিগার করুন। শুধু নির্দিষ্ট ব্যবহারকারী (যেমন: www-data) .env ফাইল অ্যাক্সেস করতে পারবে তা নিশ্চিত করুন।
Environment Caching ব্যবহার করুন। প্রোডাকশন পরিবেশে .env ফাইলের ডেটা ক্যাশ করে রাখুন:
এটি .env ফাইলের ডেটা ক্যাশ করে রাখে, ফলে .env ফাইলে কোনো পরিবর্তন করলে ক্যাশ ক্লিয়ার করা লাগবে:
php artisan config:clear
php artisan config:cache
Laravel-এ ডিফল্টভাবে .env ফাইল এনক্রিপ্ট করা হয় না, কিন্তু আপনি চাইলে কাস্টম কমান্ডের মাধ্যমে .env ফাইল এনক্রিপ্ট এবং ডিক্রিপ্ট করতে পারেন। তবে .env ফাইল সুরক্ষিত রাখার জন্য সাধারণত গিট রিপোজিটরি থেকে বাদ দেওয়া এবং সার্ভারে সঠিক ফাইল পারমিশন ব্যবহার করাই বেশি কার্যকর এবং নিরাপদ পদ্ধতি।
Laravel-এ Configuration Value অ্যাপ্লিকেশনের বিভিন্ন সেটিংস এবং কনফিগারেশন মানকে পরিচালনা করার জন্য ব্যবহৃত হয়। এই মানগুলো অ্যাপ্লিকেশনের config ডিরেক্টরিতে থাকা PHP ফাইলগুলোর মাধ্যমে সংরক্ষিত হয়। Laravel-এর config হেল্পার ফাংশন ব্যবহার করে আপনি সহজেই এই মানগুলো অ্যাক্সেস করতে পারেন।
আপনি config() হেল্পার ফাংশন ব্যবহার করে সহজেই কনফিগারেশন ভ্যালু এক্সেস করতে পারেন। নিচে কিছু উদাহরণ দেওয়া হলো:
// app.php ফাইল থেকে APP_NAME মান এক্সেস করা
$appName = config('app.name');
// database.php ফাইল থেকে ডাটাবেসের নাম এক্সেস করা
$dbName = config('database.connections.mysql.database');
আপনি config() মেথডের দ্বিতীয় আর্গুমেন্ট হিসাবে একটি ডিফল্ট মান দিতে পারেন, যা কনফিগারেশন মানটি যদি না পাওয়া যায় তবে ব্যবহৃত হবে:
$cacheDriver = config('cache.default', 'file');
Laravel এ কিছু প্যাকেজ বা লাইব্রেরি ইনস্টল করার পর তাদের কনফিগারেশন ভ্যালু পাব্লিশ করার প্রয়োজন হতে পারে। এই প্রক্রিয়া সাধারণত প্যাকেজের কনফিগারেশন ফাইলকে আপনার অ্যাপ্লিকেশনের কনফিগারেশন ডিরেক্টরিতে কপি করে।
যদি একটি প্যাকেজে পাবলিশ করার জন্য কনফিগারেশন ফাইল থাকে, তাহলে আপনি নিচের কমান্ডটি ব্যবহার করতে পারেন:
php artisan vendor:publish --provider="Vendor\Package\ServiceProvider"
এটি config ডিরেক্টরিতে প্যাকেজের কনফিগারেশন ফাইল কপি করবে, এবং সেখানে আপনি প্রয়োজন অনুযায়ী কনফিগারেশন ভ্যালুগুলো পরিবর্তন করতে পারবেন।
কিছু প্যাকেজে একাধিক পাবলিশযোগ্য ফাইল থাকতে পারে। সেক্ষেত্রে আপনি একটি নির্দিষ্ট ট্যাগ ব্যবহার করে শুধুমাত্র প্রয়োজনীয় ফাইল পাব্লিশ করতে পারেন:
php artisan vendor:publish --tag="config"
Laravel অ্যাপ্লিকেশনের পারফরম্যান্স বাড়ানোর জন্য কনফিগারেশন ভ্যালুগুলোকে ক্যাশে করা যেতে পারে। এটি কনফিগারেশন ফাইলগুলোর সব মানকে একটি ফাইলে ক্যাশে করে রাখে, ফলে সেগুলোকে প্রতি রিকোয়েস্টে পুনরায় লোড করার প্রয়োজন হয় না।
php artisan config:cache
এই কমান্ডটি কনফিগারেশন ফাইলগুলোকে ক্যাশে করবে। আপনি যদি .env ফাইল বা কনফিগারেশন ফাইলে কিছু পরিবর্তন করেন, তাহলে ক্যাশ ক্লিয়ার করতে হবে:
php artisan config:clear
Laravel-এ কনফিগারেশন ভ্যালু এক্সেস করা এবং পাবলিশ করা খুবই সহজ। config() হেল্পার ব্যবহার করে আপনি সহজেই কনফিগারেশন মানগুলি ব্যবহার করতে পারেন এবং প্যাকেজের কনফিগারেশন ফাইলগুলো পাবলিশ করতে vendor:publish কমান্ড ব্যবহার করতে পারেন। এই সব ফিচারগুলি Laravel অ্যাপ্লিকেশনটির কনফিগারেশন ব্যবস্থাকে আরও কার্যকর এবং সুসংহত করে।
Laravel-এর Maintenance Mode একটি গুরুত্বপূর্ণ ফিচার, যা অ্যাপ্লিকেশন আপডেট বা মেইনটেন্যান্সের সময় ব্যবহার করা হয়। এটি ব্যবহার করলে অ্যাপ্লিকেশনের ভিজিটররা একটি কাস্টম "maintenance" পেজ দেখতে পায়, আর ডেভেলপাররা অ্যাপ্লিকেশনটি আপডেট বা অন্যান্য কাজ করতে পারেন।
Laravel 11-এ এই ফিচারটি আরো সহজে এবং শক্তিশালীভাবে ব্যবহার করা যায়।
আপনার অ্যাপ্লিকেশনকে মেইনটেন্যান্স মোডে নেওয়ার জন্য নিচের কমান্ডটি ব্যবহার করুন:
php artisan down
এটি চালানোর পর, অ্যাপ্লিকেশনটি সকল ভিজিটরের জন্য একটি 503 Service Unavailable পেজ প্রদর্শন করবে, যেখানে সাধারণত একটি ডিফল্ট মেসেজ থাকবে।
আপনার অ্যাপ্লিকেশনকে পুনরায় সক্রিয় করতে নিম্নোক্ত কমান্ডটি ব্যবহার করুন:
php artisan up
এই কমান্ডটি চালানোর পর অ্যাপ্লিকেশন স্বাভাবিকভাবে আবার কাজ করবে।
মেইনটেন্যান্স মোডে কাস্টম মেসেজ এবং পুনরায় চেষ্টা করার সময় নির্ধারণ করতে পারেন:
php artisan down --message="Upgrading the system" --retry=60
কখনও কখনও ডেভেলপাররা মেইনটেন্যান্স মোডে অ্যাপ্লিকেশন অ্যাক্সেস করতে চান। এর জন্য আপনি একটি গোপন URL সেট করতে পারেন, যা দিয়ে শুধু ডেভেলপাররাই অ্যাপ্লিকেশন অ্যাক্সেস করতে পারবেন:
php artisan down --secret="your-secret-key"
এটি চালানোর পরে, অ্যাপ্লিকেশনটি সাধারণ ভিজিটরদের জন্য বন্ধ থাকবে, কিন্তু আপনি https://your-app.com/your-secret-key URL ব্যবহার করে অ্যাপ্লিকেশনে প্রবেশ করতে পারবেন।
কিছু নির্দিষ্ট IP অ্যাড্রেসকে মেইনটেন্যান্স মোড বাইপাস করার অনুমতি দেওয়া যায়। এর জন্য আপনি .env ফাইলে EXCEPT_IPS অপশন ব্যবহার করতে পারেন:
EXCEPT_IPS=192.168.1.1,192.168.1.2
এই IP অ্যাড্রেসগুলো থেকে অ্যাপ্লিকেশন সরাসরি অ্যাক্সেসযোগ্য থাকবে।
Laravel 11 এ আপনি মেইনটেন্যান্স মোডের জন্য কাস্টম পেজ তৈরি করতে পারেন। এটি করার জন্য, আপনি resources/views/errors/503.blade.php নামে একটি ফাইল তৈরি করতে পারেন এবং সেখানে আপনার কাস্টম মেসেজ বা ডিজাইন যোগ করতে পারেন। Laravel এই ফাইলটি 503 এরর কোডের জন্য স্বয়ংক্রিয়ভাবে রেন্ডার করবে।
Deployment বা Continuous Integration (CI)/Continuous Delivery (CD) এর সময় স্বয়ংক্রিয়ভাবে মেইনটেন্যান্স মোড চালু এবং বন্ধ করা হয়। সাধারণত আপনি ডিপ্লয়মেন্ট স্ক্রিপ্টের মধ্যে এই কমান্ডগুলো ব্যবহার করতে পারেন:
# Maintenance mode on
php artisan down
# Deployment steps (pull latest code, run migrations, etc.)
# Bring the application back up
php artisan up
Laravel যখন মেইনটেন্যান্স মোডে প্রবেশ করে, তখন এটি storage/framework/down ফোল্ডারে একটি লক ফাইল তৈরি করে। এই ফাইলটি থেকে Laravel বুঝতে পারে অ্যাপ্লিকেশনটি মেইনটেন্যান্স মোডে আছে কিনা। php artisan up চালানোর পরে এই লক ফাইলটি মুছে ফেলা হয়।
Laravel-এর Maintenance Mode একটি অত্যন্ত কার্যকরী ফিচার যা অ্যাপ্লিকেশনের আপডেট, আপগ্রেড, বা সমস্যার সমাধানের সময় খুব সহজে ব্যবহার করা যায়। আপনি কাস্টম পেজ, সিক্রেট URL, নির্দিষ্ট IP-এর মাধ্যমে বাইপাস, এবং অন্যান্য অপশন দিয়ে এই মোডকে কাস্টমাইজ করতে পারেন, যা আপনার অ্যাপ্লিকেশন মেইনটেন্যান্সকে আরও স্মার্ট এবং সুরক্ষিত করে।
Laravel 11-এর কনফিগারেশন Laravel-এর আগের সংস্করণগুলির মতোই শক্তিশালী এবং কাস্টমাইজেবল, তবে এটি কিছু উন্নত নতুন ফিচার এবং বেটার পারফরম্যান্সের জন্য অপ্টিমাইজেশন নিয়ে আসে। Laravel 11-এর কনফিগারেশন সম্পর্কে বিস্তারিত আলোচনা করছি।
Laravel 11 কনফিগারেশন হল এমন একটি সিস্টেম যা আপনাকে অ্যাপ্লিকেশন কাস্টমাইজেশন, বিভিন্ন সেটিংস নির্ধারণ, এবং সার্ভার পরিবেশ(env ) এর উপর ভিত্তি করে অ্যাপ্লিকেশন পরিচালনা করার সুবিধা দেয়। এটি বেশিরভাগ সময় .env ফাইলের মাধ্যমে কনফিগার করা হয় এবং config/ ডিরেক্টরিতে থাকা কনফিগারেশন ফাইলের মাধ্যমে প্রতিটি ফিচার নিয়ন্ত্রণ করা হয়।
Laravel-এর সমস্ত কনফিগারেশন ফাইলগুলি config/ ডিরেক্টরিতে অবস্থিত। Laravel 11-এও এই কনফিগারেশন স্ট্রাকচারটি অব্যাহত রয়েছে। এই ডিরেক্টরির প্রতিটি ফাইল অ্যাপ্লিকেশনের একটি নির্দিষ্ট ফিচার বা ফাংশন কনফিগার করতে সাহায্য করে।
Laravel 11-এর গুরুত্বপূর্ণ কিছু কনফিগারেশন ফাইলগুলো হল:
Laravel 11-এও .env ফাইল অত্যন্ত গুরুত্বপূর্ণ, কারণ এটি অ্যাপ্লিকেশনের পরিবেশভিত্তিক সেটিংস ধারণ করে। এখানে অ্যাপ্লিকেশনের সমস্ত গোপনীয় তথ্য যেমন ডাটাবেস কানেকশন, API কী, এবং অন্যান্য সংবেদনশীল তথ্য সেট করা হয়।
APP_NAME=Laravel
APP_ENV=local
APP_KEY=base64:....
APP_DEBUG=true
APP_URL=http://localhost
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=laravel
DB_USERNAME=root
DB_PASSWORD=
MAIL_MAILER=smtp
MAIL_HOST=smtp.mailtrap.io
MAIL_PORT=2525
MAIL_USERNAME=null
MAIL_PASSWORD=null
MAIL_ENCRYPTION=null
.env ফাইলের মাধ্যমে Laravel 11-এর কনফিগারেশন পরিবেশভেদে পরিবর্তিত হতে পারে। যেমন লোকাল ডেভেলপমেন্ট, স্টেজিং বা প্রোডাকশন পরিবেশের জন্য আলাদা আলাদা .env ফাইল ব্যবহার করা যেতে পারে।
Laravel 11-এও কনফিগারেশন ক্যাশিং একটি গুরুত্বপূর্ণ ফিচার হিসেবে অব্যাহত রয়েছে। যখন আপনার অ্যাপ্লিকেশন প্রোডাকশনে থাকে, তখন কনফিগারেশন ক্যাশ করা অ্যাপ্লিকেশনের পারফরম্যান্স উন্নত করতে পারে।
কনফিগারেশন ক্যাশ করার জন্য কমান্ড:
php artisan config:cache
কনফিগারেশন ক্যাশ ক্লিয়ার করার জন্য:
php artisan config:clear
Laravel 11 আপনাকে কাস্টম কনফিগারেশন ফাইল তৈরি করার সুযোগ দেয়। যদি আপনার প্রজেক্টের নির্দিষ্ট কোনো কাস্টম সেটিংস থাকে, তাহলে আপনি config/ ডিরেক্টরির মধ্যে একটি নতুন কনফিগারেশন ফাইল তৈরি করে নিতে পারেন। উদাহরণস্বরূপ:
// config/custom.php
return [
'setting1' => 'value1',
'setting2' => 'value2',
];
এরপর এই কনফিগারেশন অ্যাক্সেস করার জন্য:
$value = config('custom.setting1');
Laravel 11-এর কিছু নতুন এবং উন্নত কনফিগারেশন ফিচার থাকতে পারে যা পূর্ববর্তী ভার্সনগুলির থেকে আলাদা। সাধারণত, Laravel-এর নতুন ভার্সনে পারফরম্যান্স উন্নতি, নিরাপত্তা ফিচার এবং ডেভেলপমেন্ট টুলিং নিয়ে কাজ করা হয়। Laravel 11-এর নির্দিষ্ট নতুন ফিচারগুলো সম্পর্কে জেনে নিতে হবে অফিসিয়াল ডকুমেন্টেশন থেকে।
Laravel 11-এর একটি শক্তিশালী বৈশিষ্ট্য হলো এটি পরিবেশভিত্তিক কনফিগারেশন সহজে সমর্থন করে। আপনি .env ফাইলে বিভিন্ন পরিবেশের জন্য ভিন্ন মান সেট করতে পারবেন। যেমন:
Laravel আপনার অ্যাপ্লিকেশনের চলমান পরিবেশের উপর ভিত্তি করে সঠিক কনফিগারেশন স্বয়ংক্রিয়ভাবে লোড করে।
Laravel 11-এর কনফিগারেশন একটি ফ্লেক্সিবল এবং সহজে কাস্টমাইজযোগ্য সিস্টেম যা আপনাকে অ্যাপ্লিকেশনের বিভিন্ন সেটিংস নির্ধারণ করতে সাহায্য করে। .env ফাইলের মাধ্যমে পরিবেশভিত্তিক কনফিগারেশন করা যায়, এবং config/ ডিরেক্টরির ফাইলগুলো অ্যাপ্লিকেশনের প্রতিটি ফিচার পরিচালনা করতে সাহায্য করে। Laravel 11 পূর্ববর্তী সংস্করণের মতোই শক্তিশালী কনফিগারেশন সাপোর্ট নিয়ে এসেছে, তবে এতে নতুন কিছু পারফরম্যান্স অপ্টিমাইজেশন এবং নিরাপত্তা ফিচার যুক্ত হতে পারে।