Django

Settings และการตั้งค่า Production

การแยก settings (base/dev/prod), การจัดการ secret, ALLOWED_HOSTS, CSRF_TRUSTED_ORIGINS, settings SECURE_*, .env/vault, การตั้งค่า storage

22 คำถามสัมภาษณ์·
Senior
1

โครงสร้างที่แนะนำสำหรับการจัดระเบียบไฟล์ settings ของโปรเจกต์ Django ใน production คืออะไร?

คำตอบ

โครงสร้างที่แนะนำคือการสร้าง package settings ที่มีไฟล์ base.py ซึ่งบรรจุการตั้งค่าทั่วไป จากนั้นมีไฟล์แยก dev.py, staging.py และ prod.py ที่ import และขยาย base.py แนวทางนี้ช่วยให้แชร์การตั้งค่าทั่วไปได้พร้อมกับปรับแต่งสภาพแวดล้อมเฉพาะ ทำให้ดูแลรักษาง่ายขึ้นและลดการเขียนโค้ดซ้ำ

2

จะระบุว่าจะใช้ไฟล์ settings ใดเมื่อเริ่มโปรเจกต์ Django ได้อย่างไร?

คำตอบ

ตัวแปรสภาพแวดล้อม DJANGO_SETTINGS_MODULE ช่วยให้ระบุ path แบบ Python ไปยังโมดูล settings ที่จะใช้ได้ ตัวอย่างเช่น DJANGO_SETTINGS_MODULE=myproject.settings.prod บอกให้ Django ใช้ไฟล์ prod.py จาก package settings ตัวแปรนี้สามารถตั้งค่าได้ใน shell, ไฟล์การตั้งค่าเซิร์ฟเวอร์ หรือสคริปต์ deployment

3

setting ALLOWED_HOSTS ใน Django มีหน้าที่อะไร?

คำตอบ

ALLOWED_HOSTS คือรายการ domain/host ที่ได้รับอนุญาตให้ให้บริการแอปพลิเคชัน Django กลไกความปลอดภัยนี้ป้องกันการโจมตีแบบ HTTP Host header โดยการตรวจสอบ header Host ของแต่ละ request ใน production ที่ตั้ง DEBUG=False setting นี้เป็นสิ่งจำเป็นและต้องบรรจุ domain ที่ถูกต้องของแอปพลิเคชันเพื่อหลีกเลี่ยงข้อผิดพลาด 400 Bad Request

4

ค่า ALLOWED_HOSTS ใดที่ยอมรับ host ใดก็ได้ และเหตุใดจึงอันตรายใน production?

5

setting CSRF_TRUSTED_ORIGINS ที่เปิดตัวใน Django 4.0 มีไว้เพื่ออะไร?

+19 คำถามสัมภาษณ์

หัวข้อสัมภาษณ์ Django อื่นๆ

พื้นฐาน Python

Junior
25 คำถาม

Python เชิงวัตถุ

Junior
20 คำถาม

พื้นฐาน Django

Junior
20 คำถาม

Django Models - พื้นฐาน

Junior
22 คำถาม

Django Views

Junior
20 คำถาม

เทมเพลต Django

Junior
18 คำถาม

ฟอร์ม Django

Mid-Level
22 คำถาม

QuerySets ขั้นสูง

Mid-Level
25 คำถาม

การยืนยันตัวตนใน Django

Mid-Level
22 คำถาม

Django Middleware

Mid-Level
18 คำถาม

Django Admin

Mid-Level
20 คำถาม

Django REST Framework

Mid-Level
30 คำถาม

Django Signals

Mid-Level
18 คำถาม

การอัปโหลดไฟล์

Mid-Level
20 คำถาม

การแคชใน Django

Mid-Level
20 คำถาม

Django Sessions

Mid-Level
18 คำถาม

อีเมลใน Django

Mid-Level
18 คำถาม

การทดสอบ Django

Mid-Level
22 คำถาม

ความปลอดภัยของ Django

Mid-Level
22 คำถาม

การ Deploy Django

Mid-Level
24 คำถาม

Django ORM ขั้นสูง

Senior
28 คำถาม

ประสิทธิภาพของ Django

Senior
24 คำถาม

Django & Celery

Senior
22 คำถาม

Django Channels

Senior
24 คำถาม

Django & GraphQL

Senior
24 คำถาม

Django & Docker

Senior
20 คำถาม

Django ในระบบนิเวศ Microservices

Senior
24 คำถาม

คำสั่ง Django แบบกำหนดเอง

Senior
18 คำถาม

การทำให้รองรับหลายภาษาใน Django

Senior
20 คำถาม

Design Patterns ใน Django

Senior
24 คำถาม

Django Async และ ASGI

Senior
26 คำถาม

Observability และ Monitoring

Senior
24 คำถาม

เชี่ยวชาญ Django สำหรับการสัมภาษณ์ครั้งถัดไป

เข้าถึงคำถามทั้งหมด flashcards แบบทดสอบเทคนิค แบบฝึกหัด code review และตัวจำลองสัมภาษณ์

เริ่มใช้ฟรี