私は最近、独自の Django アプリケーションを運用環境にデプロイしました。この Web サイトは videiro.com と呼ばれ、django + HTML/CSS/JS + Tailwind で開発されました。
設定
私は debian 12 サーバーを使用しており、cloudflare トンネル経由でアプリケーションを公開します。すべての静的ファイルは nginx 経由で提供され、Django プロジェクトは gunicorn によって実行されます。
このガイドでは、これをどのように設定するかを説明します。
Django プロジェクトの準備
最初に行う必要があるのは、settings.py を開いて次の内容を変更することです
Debug = False ALLOWED_HOSTS = ['yourdomain.tld'] CSRF_COOKIE_SECURE = True CSRF_TRUSTED_ORIGINS = [ 'yourdomain.tld', ]
また、SECRET_KEY を長いランダムな文字列に変更する必要があります。これは誰とも共有しないでください。
その後、.gitignore という名前の新しいファイルを作成し、以下を貼り付けます:
db.sqlite3 *.pyc
これにより、データベースがサーバーにアップロードされず、pyc ファイルもアップロードされなくなります。
これで、プロジェクトを新しい github リポジトリ (または gitea リポジトリ) にアップロードできるようになりました。誰もがソース コードにアクセスできるようにしたくない場合は、必ずリポジトリを非公開として設定してください。
ソース コードを非公開にしたい場合は、セルフホスト型 gitea インスタンスをセットアップすることをお勧めします。その方法については、「独自の gitea インスタンスをセルフホストする - セルフホスト型で軽量な github の代替」を参照してください。
git init git branch -M main git add . git commit -m "initial commit" git remote add origin https://... git push -u origin main
これでサーバーにログインできるようになりました
サーバーのセットアップ
何かを設定する前に、パスワードを使用した SSH ログインを許可していないことを確認してください。このような種類の攻撃からサーバーを保護するには、「キーベースの認証による ssh の保護」に従ってください。
サーバーにログインします
ssh user@server.ip
パッケージがデータに準拠していることを確認してください
sudo apt update && sudo apt upgrade
次に、Python、pip、git、nginx をインストールします
sudo apt install python3 python3-pip git nginx
次に、プロジェクトのクローンをホーム ディレクトリに作成します。
git clone https://... cd my-project
開始したら、以下をインストールします:
pip install django django-crispy-forms whitenoise
次にプロジェクトを実行してみます:
python3 manage.py runserver
パッケージが見つからないというエラーが表示された場合は、パッケージをインストールして再実行します。
ガニコーンの構成
次に、ガニコーンをセットアップします
まずインストールしてください
pip install gunicorn
次に、お気に入りのテキスト エディターを使用して、gunicorn.service という名前の新しいファイルを作成します。
sudo vim /etc/systemd/system/gunicorn.service
以下を貼り付けます:
[Unit] Description=gunicorn daemon After=network.target [Service] User=YOURUSER Group=www-data WorkingDirectory=/home/YOURUSER/PROJECT ExecStart=/path/to/gunicorn --access-logfile - --workers 3 --bind 127.0.0.1:8000 PROJECTNAME.wsgi:application [Install] WantedBy=multi-user.target
YOURUSER を自分のユーザーに変更します。
gunicorn へのパスを見つけるには、以下を実行します:
which gunicorn
プロジェクト名は、settings.py ファイルが含まれるプロジェクト内のフォルダーの名前です。
次のコマンドを実行して、gunicorn を起動して有効にします (起動時に開始)
sudo systemctl daemon-reload sudo systemctl start gunicorn.service sudo systemctl enable gunicorn.service
ここで 127.0.0.1:8000 に移動すると、プロジェクトが実行されているのが確認できるはずです。
しかし、まだ終わっていません
nginxのセットアップ
次に、静的コンテンツを nginx 経由で提供する必要があります。
まず、お気に入りのテキスト エディターで新しいファイル nginx 構成ファイルを作成します。
sudo vim /etc/nginx/sites-available/PROJECT
PROJECT を任意のものに変更します
次のコンテンツを貼り付けます:
server { listen 80; server_name YOURDOMAIN; location /static/ { alias /var/www/staticfiles/; } location / { proxy_pass http://127.0.0.1:8000; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; } }
YOURDOMAIN を、これがホストされるドメインに変更するだけです。
Web サイトを有効にするシンボリック リンクを作成します:
sudo ln -s /etc/nginx/sites-available/PROJECT /etc/nginx/sites-enabled/
nginx を起動して有効にします:
sudo systemctl start nginx sudo systemctl enable nginx
静的ファイルのセットアップ
最初に行う必要があるのは、(django) プロジェクトに cd することです
cd project
次のコマンドを実行します:
python3 manage.py collectstatic
これにより、staticfiles という新しいフォルダーが作成されます
静的ファイルを設定するには、2 つのオプションがあります:
- /etc/nginx/nginx.conf のユーザーを自分のユーザーに変更します (安全性は低くなります)
- 静的ファイルを /var/www/ にコピーします (より安全です)
2 番目のオプションを実行します:
まず、/var/www に staticfiles という新しいファイルを作成します
sudo mkdir -p /var/www/staticfiles
次に、プロジェクトからすべての静的ファイルをそこにコピーします。
sudo cp staticfiles/* /var/www/staticfiles
次に /var/www に cd します
cd /var/www
すべてのファイルの所有権を変更します
sudo chown www-data:www-data staticfiles sudo chown www-data:www-data staticfiles/*
nginx サービスを再起動します:
sudo systemctl restart nginx
今、次の場所に向かうとします:
127.0.0.1
すべての静的ファイルが提供された状態で Web サイトが実行されていることがわかります。
クラウドフレアトンネル経由で公開する
次に、Web サイトを一般公開します。
これを行うには、cloudflare アカウントと、cloudflare を指すドメインが必要です。
まずゼロトラストダッシュボードに移動します
「ネットワーク」で「トンネル」をクリックし、トンネルを作成します
作成したら、コネクタをインストールして実行し、特定のセットアップのページの指示に従ってください。
コネクタが実行されたら、[パブリック ホスト名] タブをクリックし、パブリック ホスト名を追加する必要があります。
次のようなものが表示されるはずです:
私が持っている情報を入力してください。サービス タイプは HTTP、URL は 127.0.0.1:80 または localhost:80
である必要があります。指定したドメインに移動すると、アプリが起動して実行されていることが確認できます。
おめでとうございます!
この投稿を気に入っていただき、私の (ほとんど無給の) 仕事をサポートしたい場合は、ここから寄付していただけます。
無料のニュースレターに参加してください!
ここから参加してください
以上がDjango を本番環境にデプロイするの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

Pythonの柔軟性は、マルチパラダイムサポートと動的タイプシステムに反映されていますが、使いやすさはシンプルな構文とリッチ標準ライブラリに由来しています。 1。柔軟性:オブジェクト指向、機能的および手続き的プログラミングをサポートし、動的タイプシステムは開発効率を向上させます。 2。使いやすさ:文法は自然言語に近く、標準的なライブラリは幅広い機能をカバーし、開発プロセスを簡素化します。

Pythonは、初心者から上級開発者までのすべてのニーズに適した、そのシンプルさとパワーに非常に好まれています。その汎用性は、次のことに反映されています。1)学習と使用が簡単、シンプルな構文。 2)Numpy、Pandasなどの豊富なライブラリとフレームワーク。 3)さまざまなオペレーティングシステムで実行できるクロスプラットフォームサポート。 4)作業効率を向上させるためのスクリプトおよび自動化タスクに適しています。

はい、1日2時間でPythonを学びます。 1.合理的な学習計画を作成します。2。適切な学習リソースを選択します。3。実践を通じて学んだ知識を統合します。これらの手順は、短時間でPythonをマスターするのに役立ちます。

Pythonは迅速な開発とデータ処理に適していますが、Cは高性能および基礎となる制御に適しています。 1)Pythonは、簡潔な構文を備えた使いやすく、データサイエンスやWeb開発に適しています。 2)Cは高性能で正確な制御を持ち、ゲームやシステムのプログラミングでよく使用されます。

Pythonを学ぶのに必要な時間は、人によって異なり、主に以前のプログラミングの経験、学習の動機付け、学習リソースと方法、学習リズムの影響を受けます。現実的な学習目標を設定し、実用的なプロジェクトを通じて最善を尽くします。

Pythonは、自動化、スクリプト、およびタスク管理に優れています。 1)自動化:OSやShutilなどの標準ライブラリを介してファイルバックアップが実現されます。 2)スクリプトの書き込み:Psutilライブラリを使用してシステムリソースを監視します。 3)タスク管理:スケジュールライブラリを使用してタスクをスケジュールします。 Pythonの使いやすさと豊富なライブラリサポートにより、これらの分野で優先ツールになります。

限られた時間でPythonの学習効率を最大化するには、PythonのDateTime、時間、およびスケジュールモジュールを使用できます。 1. DateTimeモジュールは、学習時間を記録および計画するために使用されます。 2。時間モジュールは、勉強と休息の時間を設定するのに役立ちます。 3.スケジュールモジュールは、毎週の学習タスクを自動的に配置します。

PythonはゲームとGUI開発に優れています。 1)ゲーム開発は、2Dゲームの作成に適した図面、オーディオ、その他の機能を提供し、Pygameを使用します。 2)GUI開発は、TKINTERまたはPYQTを選択できます。 TKINTERはシンプルで使いやすく、PYQTは豊富な機能を備えており、専門能力開発に適しています。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

ドリームウィーバー CS6
ビジュアル Web 開発ツール

Dreamweaver Mac版
ビジュアル Web 開発ツール
