متن خبر

نحوه استقرار پروژه جنگو بر روی ماشین EC2 با استفاده از GitHub Actions

نحوه استقرار پروژه جنگو بر روی ماشین EC2 با استفاده از GitHub Actions

شناسهٔ خبر: 446827 -




استقرار یک برنامه جنگو را می توان با استفاده از GitHub Actions ساده و خودکار کرد.

این مقاله راهنمای جامعی در مورد چگونگی راه اندازی خط لوله استقرار پیوسته برای پروژه جنگو که بر روی نمونه AWS EC2 میزبانی می شود، ارائه می دهد.

با استفاده از GitHub Actions، توسعه‌دهندگان می‌توانند فرآیند استقرار خود را خودکار کرده و کارآمدتر و بدون خطا را افزایش دهند.

پیش نیازها

یک پروژه جنگو که در یک مخزن GitHub میزبانی شده است.

یک نمونه AWS EC2 برای میزبانی برنامه جنگو راه اندازی شده است.

آشنایی اولیه با گردش کار YAML و GitHub.

نحوه تنظیم نمونه EC2

قبل از غواصی در GitHub Actions، مطمئن شوید که نمونه EC2 شما برای میزبانی برنامه جنگو شما آماده است.

از دستور زیر برای اتصال به نمونه EC2 خود استفاده کنید:

 ssh -i /path/to/your-key.pem ec2-user@your-ec2-instance-public-dns

با استفاده از این موارد می توانید بسته های سیستم خود را به روز کنید:

 sudo apt-get update sudo apt-get upgrade

بعد، اگر قبلاً این کار را نکرده‌اید، پایتون و پیپ را نصب کنید:

 sudo apt-get install python3 sudo apt-get install python3-pip

سپس جنگو را با استفاده از این دستور نصب کنید:

 pip3 install django

نحوه پیکربندی وب سرور

در این بخش نحوه پیکربندی وب سرور خود را خواهید دید.

ابتدا Nginx را نصب کنید:

 sudo apt-get install nginx

سپس Nginx را برای جنگو پیکربندی کنید. با ایجاد یک فایل پیکربندی جدید برای پروژه جنگو شروع کنید.

 sudo nano /etc/nginx/sites-available/mydjangoapp

سپس بلوک سرور زیر را اضافه کنید:

 server { listen 80; server_name your-domain.com; location = /favicon.ico { access_log off; log_not_found off; } location /static/ { root /path/to/your/django/project; } location / { include proxy_params; proxy_pass http://unix:/path/to/your/gunicorn.sock; } }

در نهایت، پیکربندی Nginx را فعال کنید:

 sudo ln -s /etc/nginx/sites-available/mydjangoapp /etc/nginx/sites-enabled sudo nginx -t sudo systemctl restart nginx

نحوه راه اندازی پایگاه داده

با استفاده از این می توانید PostgreSQL را نصب کنید:

 sudo apt-get install postgresql postgresql-contrib

پس از نصب، با استفاده از این دستور یک پایگاه داده و کاربر ایجاد کنید:

 sudo -u postgres psql

برای ایجاد یک پایگاه داده جدید و اضافه کردن یک کاربر جدید، این کوئری SQL را اجرا کنید:

 CREATE DATABASE mydjangodb; CREATE USER mydjangouser WITH PASSWORD 'password'; ALTER ROLE mydjangouser SET client_encoding TO 'utf8'; ALTER ROLE mydjangouser SET default_transaction_isolation TO 'read committed'; ALTER ROLE mydjangouser SET timezone TO 'UTC'; GRANT ALL PRIVILEGES ON DATABASE mydjangodb TO mydjangouser; \q

سپس جنگو را برای استفاده از PostgreSQL پیکربندی کنید. در فایل settings.py جنگو، تنظیمات DATABASES را به‌روزرسانی کنید:

 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.postgresql', 'NAME': 'mydjangodb', 'USER': 'mydjangouser', 'PASSWORD': 'password', 'HOST': 'localhost', 'PORT': '', } }

گردش کار GitHub Actions برای استقرار یک پروژه جنگو شامل چندین مرحله کلیدی است:

مرحله شماره 1 - تسویه حساب و آماده سازی

اولین گام در گردش کار شما این است که آخرین کد را از مخزن GitHub خود تحلیل کنید و محیطی را برای استقرار تنظیم کنید.

 name: Deploy Django to EC2 on: push: branches: - main jobs: deploy: runs-on: ubuntu-latest steps: - name: Checkout repository uses: actions/checkout@v2

مرحله 2 - اسکریپت استقرار

اسکریپت استقرار شامل کشیدن آخرین کد، نصب وابستگی ها، اجرای مهاجرت و راه اندازی مجدد وب و سرورهای WSGI است.

یک فایل جدید deploy_script.sh در دستگاه EC2 خود ایجاد کنید و کد زیر را اضافه کنید:

 #!/bin/bash DRY_RUN=$1 echo "Pulling latest code from repository..." # Skip actual git pull in dry run [ "$DRY_RUN" != "true" ] && git pull origin main echo "Installing dependencies..." # Skip actual installation in dry run [ "$DRY_RUN" != "true" ] && pip install -r requirements.txt echo "Running migrations..." # Skip actual migrations in dry run [ "$DRY_RUN" != "true" ] && python manage.py migrate echo "Restarting the server..." # Skip actual restart in dry run [ "$DRY_RUN" != "true" ] && sudo systemctl restart myapp echo "Deployment complete."

مرحله 3 - یک مرحله برای اجرای اسکریپت استقرار ایجاد کنید

از GitHub Actions برای SSH در نمونه EC2 خود استفاده کنید. شما باید کلید SSH نمونه EC2 خود را به عنوان یک راز GitHub ذخیره کنید.

 - name: Run Deployment run: | ssh -i ${{ secrets.EC2_SSH_KEY }} ec2-user@your-ec2-instance 'bash -s' < deploy_script.sh env: ACTIONS_RUNNER_DEBUG: false

ملاحظات امنیتی

در اینجا برخی از ملاحظات امنیتی وجود دارد که باید در نظر داشته باشید:

کلیدهای SSH : کلیدهای خصوصی SSH خود را به صورت ایمن در GitHub Secrets ذخیره کنید.

حداقل مجوزها : مطمئن شوید که نقش IAM نمونه EC2 دارای حداقل مجوزهای لازم برای استقرار است.

تست و اعتبارسنجی

قبل از اجرای کامل این گردش کار، آن را با یک محیط توسعه یا مرحله بندی آزمایش کنید تا مطمئن شوید که فرآیند استقرار همانطور که پیش بینی می شود کار می کند.

اجرای Dry Run Deployment : مرحله ای را در گردش کار GitHub Actions خود پیاده کنید که یک «اجرای خشک» از فرآیند استقرار را انجام می دهد. این می‌تواند به اعتبارسنجی اسکریپت‌های استقرار بدون تأثیرگذاری بر نمونه زنده EC2 کمک کند. مرحله زیر را اضافه کنید تا dry_run = true در اسکریپت استقرار بگذرد.

 - name: Dry Run Deployment run: | ssh -i ${{ secrets.EC2_SSH_KEY }} ec2-user@your-ec2-instance 'bash -s' < deploy_script.sh true env: ACTIONS_RUNNER_DEBUG: true

ثبت و نظارت : می‌توانید گزارش‌های ثبت عملیات فعلی فرآیند استقرار را از deploy_script.sh مشاهده کنید، که در صورت بروز هر گونه مشکلی قابل تحلیل است.

نتیجه

خودکارسازی استقرار جنگو با استفاده از GitHub Actions یک راه کارآمد و قابل اعتماد برای مدیریت تحویل برنامه ارائه می دهد.

با دنبال کردن مراحل ذکر شده در بالا، توسعه‌دهندگان می‌توانند یک خط لوله استقرار قوی راه‌اندازی کنند که با هر بار فشار دادن به شاخه اصلی، آخرین کد جنگو خود را به یک نمونه EC2 منتقل می‌کند.

خبرکاو

ارسال نظر




تبليغات ايهنا تبليغات ايهنا

تمامی حقوق مادی و معنوی این سایت متعلق به خبرکاو است و استفاده از مطالب با ذکر منبع بلامانع است