প্রোডাকসান সার্ভার (Nginx) এবং জ্যাঙ্গো

প্রোডাকসান সার্ভার (Nginx) এবং জ্যাঙ্গো

জ্যাঙ্গো দিয়ে আমাদের কাজ করার সময় আমরা বিল্ট-ইন ডেভেলপমেন্ট সার্ভার ব্যবহার করতাম। এতে কাজ করতে সুবিধা হলেও এটা প্রডাকশন লেভেলে ব্যবহারের অনুপযোগী । তাই আমাদেরকে কোন প্রোদাকশান সার্ভার ব্যবহার করতে হয়। এই টিউটোরিয়ালে আমরা Nginx ব্যবহার করবো।
যেহেতু সার্ভারে লিনাক্স ব্যবহৃত হয়, তাই আমরা লিনাক্স এই টিউটোরিয়ালে লিনাক্স ব্যবহার করবো। আপনারা যারা windows ব্যবহার করেন কিংবা লিনাক্স ব্যবহারের পরও একটু সতর্ক থাকতে চান (যাতে আপনার working laptop এ ঝামেলা না হয় আরকি,... ) , তারা ভারচুয়াল বক্সে লিনাক্স ব্যবহার করতে পারেন। আমি নিজেও কিছুটা ঝামেলায় পরেছিলাম, তাই ভারচুয়াল বক্সে উবুন্টু সার্ভার ইন্সটল করে সেখানে জ্যাঙ্গো প্রোডাকশান করেছিলাম। সুতরাং ঝামেলা কমাতে এটি একটু ভাল উপায়।

ধাপসমুহ

আমাদের ১টা জ্যাঙ্গো প্রোজেক্ট দরকার। ছোটখাটো হেলো ওয়ার্ল্ড জাতিয় হলেই চলবে। ধরুন প্রোজেক্টের নাম webapp. এরপর settings ফাইলে অ্যাড করুন ঃ
1
DEBUG = False
Copied!
1
STATIC_ROOT = os.path.join(BASE_DIR, 'static/')
Copied!
, এরপর টার্মিনালে রান করুন
1
$ manage.py collectstatic
Copied!
এবার এই প্রোজেক্টকে ভারচুয়াল বক্সে আনতে হবে। আমি গিটহাব-এ কোড আপলোড করে ভারচুয়াল বক্সে ডাউনলোড করেছিলাম।
২। উবুন্টুতে nginx ইন্সটল করুন:
1
$ sudo apt-get install nginx
Copied!
আমই প্রোজেক্টটাকে এখানে রেখেছি ঃ /home/(user-name)/ তাই আমার প্রোজেক্টের রুট ডাইরেক্টরি হলোঃ /home/(user-name)/(project-name) এবং আমার এই ক্ষেত্রে তা ঃ /home/fahimfarhan/webapp আপনার ক্ষেত্রে প্রয়োজন মতো পরিবর্তন করে নিবেন, নাহলে ঠিক মতো কাজ করবে না।
৩। $ cd /etc/nginx/sites-available এই লোকেশানে যান, এখানে কিছু কাজ করতে হবে। এই লকেশানে পারমিশন-এর ব্যাপার আছে, তাই আমাদেরকে sudo sudo ব্যবহার করতে হবে।
1
$ sudo touch (project-name)
Copied!
আমার খেত্রেঃ
1
$ sudo touch webapp
Copied!
এবার webapp ফাইলটি ওপেন করুন (sudo ব্যবহার করতে হবে, যেমন টার্মিনাল থেকে sudo gedit webapp / sudo vim webapp ) এবং টাইপ করুনঃ
1
server {
2
listen 8000;
3
server_name 0.0.0.0;
4
5
location = /favicon.ico { access_log off; log_not_found off; }
6
7
location /static/ {
8
root /home/(user-name)/(project);
9
}
10
11
location / {
12
include proxy_params;
13
proxy_pass http://unix:/home/(user-name)/(project)/(project).sock;
14
}
15
}
Copied!
এখানে (user-name) ও (project) প্রয়োজন মতো পরিবর্তন করুন। অনেক সময় পোর্ট নম্বর পরিবর্তন করা লাগতে পারে। এবার টার্মিনাল এ এই কমান্ড রান করে একটি লিঙ্ক তইরি করুন ঃ
1
$ sudo ln -s /etc/nginx/sites-available/webapp /etc/nginx/sites-enabled
Copied!
এবার nginx রিস্টার্ট করুন ঃ
1
$ sudo service nginx restart
Copied!
আপনার প্রোজেক্ট রুট ডাইরেক্টরিতে যানঃ
1
$ cd ~/webapp/
Copied!
nginx দিয়ে সিএসএস , জাভাস্ক্রিপ্ট সারভ হয়, আর আমাদের মুল প্রোজেক্ট রান করতে gunicorn দরকার। তাই গুনিকরন না থাকলে ইন্সটল করুন
1
$ pip install gunicorn
2
# In my pc, python3 is default. so it works. If you have python 2 as default,
3
# use: pip3 install gunicorn
Copied!
এবং এই কমান্ড টাইপ করুন ঃ
1
$ gunicorn --daemon --workers 1 --bind unix:/home/(username)/(project)/(project).sock (project).wsgi
Copied!
এবং আমার ক্ষেত্রে কমান্ডটি দেখতে এরকম ঃ
1
$ gunicorn3 --daemon --workers 1 --bind unix:/home/fahimfarhan/webapp/webapp.sock webapp.wsgi
Copied!
এইভাবে আমরা nginx দিয়ে আমাদের প্রোজেক্টকে প্রোডাকশানে ব্যবহার করতে পারি।

রেফারেন্সঃ

Last modified 1yr ago