Docker を使用して Nginx+Flask+Mongo アプリケーションをデプロイする方法
nginx をサーバーとして、mongo をデータベースサポートとして、flask を Python 言語の Web フレームワークとして使用し、docker のコンテナ機能を使用して、Linux サーバーに簡単にデプロイできます
プロジェクトの準備
プロジェクトのメイン ディレクトリは次のとおりです
__ project-name |__ docker-file |__ ningx |__ dockerfile |__ conf |__ nginx.conf |__ flask |__ dockerfile |__ requirements.txt |__ mongo |__ dockerfile |__ setup.sh |__ docker-compose.yml |__ src |__ app |__ ... |__ run.py
簡単な説明
docker-file ディレクトリは docker デプロイメントの設定ファイルです
src ディレクトリは flask アプリケーションの Python コードです
#Docker の詳細な設定
version: '2.2' services: mongo: build: ./mongo volumes: - "./mongo/db:/data/db" restart: always ports: - "27017:27017" environment: mongo_initdb_root_username: root mongo_initdb_root_password: 123456 flask: build: ./flask links: - mongo ports: - "5000:5000" expose: - "5000" volumes: - ../src:/home/web nginx: build: ./nginx links: - flask volumes: - "./nginx/log:/var/log/nginx" - "../:/usr/share/nginx/html" ports: - "80:80" - "8080:8080" - "443:443" restart: always
mongodb 構成
/mongo/ の内容dockerfile は次のとおりです
from mongo:3.6 # 设置时区 env tz=asia/shanghai run ln -snf /usr/share/zoneinfo/$tz /etc/localtime && echo $tz > /etc/timezone # 设置工作目录 env workdir /usr/local/work env auto_run_dir /docker-entrypoint-initdb.d env install_mongo_shell setup.sh run mkdir -p $workdir # 复制数据库的初始化命令 copy ./$install_mongo_shell $auto_run_dir/ run chmod +x $auto_run_dir/$install_mongo_shell
/mongo/setup.sh 内容は次のとおりです
このファイルの目的は、mongodb の起動後に test というパスワードを持つユーザー テストを作成し、データベース test
#!/bin/bash mongo <<eof use admin; db.auth('root', '123456'); use dmx_aluminum; db.createuser({user:'test',pwd:'test',roles:[{role:'readwrite',db:'test'}]}); db.createcollection("user"); eof
flask アプリケーションの読み取りおよび書き込み操作です。構成
/flask/dockerfile の内容は次のとおりです
from python:3.6 # 设置时区 env tz=asia/shanghai run ln -snf /usr/share/zoneinfo/$tz /etc/localtime && echo $tz > /etc/timezone # 设置工作区 run mkdir -p /home/web workdir /home/web # 添加依赖 add requirements.txt /home/web/requirements.txt run pip3 install -i https://pypi.douban.com/simple/ -r requirements.txt # 使用gunicorn启动应用 cmd gunicorn -w 4 -b 0.0.0.0:5000 run:app
/src/app/run.py コード
app.run() のデバッグについてここにコメントしました。公開するときは gunicorn から始めます
from app import create_app app = create_app('default') app.debug=false # if __name__ == '__main__': # app.run()
nginx 構成
/nginx/dockerfile の内容は次のとおりです
from nginx:1.14 # 设置时区 env tz=asia/shanghai run ln -snf /usr/share/zoneinfo/$tz /etc/localtime && echo $tz > /etc/timezone # 复制配置 copy conf/nginx.conf /etc/nginx/nginx.conf
/nignx/conf/nginx.conf の内容は次のとおりです
user nginx; worker_processes 1; error_log /var/log/nginx/error.log warn; pid /var/run/nginx.pid; events { worker_connections 1024; } http { include /etc/nginx/mime.types; default_type application/octet-stream; log_format main '$remote_addr - $remote_user [$time_local] "$request" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" "$http_x_forwarded_for"'; access_log /var/log/nginx/access.log main; sendfile on; #tcp_nopush on; keepalive_timeout 65; # 开启gzip gzip on; gzip_min_length 1k; gzip_buffers 4 16k; #gzip_http_version 1.0; gzip_comp_level 1; gzip_types text/plain application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png; gzip_vary off; gzip_disable "msie [1-6]\."; server { listen 80; server_name localhost; keepalive_timeout 5; root /usr/share/nginx/html; location /static/ { alias /usr/share/nginx/html/src/app/static/; } location / { # checks for static file, if not found proxy to app try_files $uri @flask_app; } location @flask_app { proxy_pass http://192.168.0.2:5000; # 发布在阿里云上,应填写内网ip proxy_redirect off; proxy_set_header x-forwarded-for $proxy_add_x_forwarded_for; proxy_set_header host $http_host; proxy_set_header x-real-ip $remote_addr; #proxy_buffers 8 32k; #proxy_buffer_size 64k; } } }
#docker-flie ディレクトリに移動します。 cd docker-flie
#docker を開始します docker-compose up
コンテナ ステータスの表示ドッカー ps
ローカル デプロイメントブラウザに 127.0.0.1 と入力します
最後に、同様の 3 つのコンテナが表示されますdocker_file_nginx_1、docker_file_mongo_1、docker_file_flask_1 が表示され、成功したことを示します。 ! !
1 モンゴルコンテナ内の初期化ファイルは、docker-entrypoint-initdb.d ディレクトリに配置する必要があります
add setup.sh /data/setup.sh run chmod +x /data/setup.sh cmd ["/data/setup.sh"]
2 flask アプリケーションが mongo に接続できません。この記事ではリンク方式を使用しています。 データベース構成は次のように記述する必要があります:
mongodb_settings = { 'db': 'test', 'host': 'mongo', # 127.0.0.1 host地址一定要写你配置的--link的名字 'username': 'test', 'password': 'test', 'port': 27017 }
ローカル テスト中に 127.0.0.1 に戻す
3 nginx 構成で使用されるプロキシ モード。フラスコが実行されます。アプリケーション IP はイントラネット IP
である必要があります。
以上がDocker を使用して Nginx+Flask+Mongo アプリケーションをデプロイする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

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

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











ピン張りのノードの詳細な説明とインストールガイドこの記事では、ピネットワークのエコシステムを詳細に紹介します - PIノードは、ピン系生態系における重要な役割であり、設置と構成の完全な手順を提供します。 Pinetworkブロックチェーンテストネットワークの発売後、PIノードは多くの先駆者の重要な部分になり、テストに積極的に参加し、今後のメインネットワークリリースの準備をしています。まだピン張りのものがわからない場合は、ピコインとは何かを参照してください。リストの価格はいくらですか? PIの使用、マイニング、セキュリティ分析。パインワークとは何ですか?ピン競技プロジェクトは2019年に開始され、独占的な暗号通貨PIコインを所有しています。このプロジェクトは、誰もが参加できるものを作成することを目指しています

回答: PHP マイクロサービスは、アジャイル開発のために HelmCharts でデプロイされ、分離とスケーラビリティのために DockerContainer でコンテナ化されます。詳細説明: HelmCharts を使用して PHP マイクロサービスを自動的にデプロイし、アジャイル開発を実現します。 Docker イメージを使用すると、マイクロサービスの迅速な反復とバージョン管理が可能になります。 DockerContainer 標準はマイクロサービスを分離し、Kubernetes がコンテナの可用性とスケーラビリティを管理します。 Prometheus と Grafana を使用して、マイクロサービスのパフォーマンスと健全性を監視し、アラームと自動修復メカニズムを作成します。

DeepSeekをインストールするには、Dockerコンテナ(最も便利な場合は、互換性について心配する必要はありません)を使用して、事前コンパイルパッケージ(Windowsユーザー向け)を使用してソースからコンパイル(経験豊富な開発者向け)を含む多くの方法があります。公式文書は慎重に文書化され、不必要なトラブルを避けるために完全に準備します。

Docker コンテナを使用した Java EE アプリケーションのデプロイ: Dockerfile を作成してイメージを定義し、イメージを構築し、コンテナを実行してポートをマップし、ブラウザでアプリケーションにアクセスします。サンプル JavaEE アプリケーション: REST API はデータベースと対話し、Docker 経由でデプロイ後にローカルホストでアクセスできます。

回答: PHPCI/CD を使用して、CI/CD パイプラインの設定、自動化されたテストおよび展開プロセスなどの迅速な反復を実現します。 CI/CD パイプラインのセットアップ: CI/CD ツールを選択し、コード リポジトリを構成し、ビルド パイプラインを定義します。自動テスト: 単体テストと統合テストを作成し、テスト フレームワークを使用してテストを簡素化します。実際のケース: TravisCI の使用: TravisCI をインストールし、パイプラインを定義し、パイプラインを有効にして、結果を表示します。継続的デリバリーを実装します。展開ツールを選択し、展開パイプラインを定義し、展開を自動化します。利点: 開発効率が向上し、エラーが減少し、納期が短縮されます。

1. まず、インターフェイスを開いた後、左側の拡張機能アイコン ボタンをクリックします。 2. 次に、開いた拡張機能ページで検索バーの場所を見つけます。 3. 次に、マウスで「Docker」という単語を入力して拡張機能プラグインを見つけます。 4最後に、対象のプラグインを選択して右をクリックし、下隅にあるインストールボタンをクリックします。

PHP マイクロサービスのコンテナー化された監視とログ管理の監視: Prometheus と Grafana を使用して、リソースの使用状況、リクエストの数、待機時間を監視します。ログ管理: ELKStack (ElasticSearch、Logstash、Kibana) を使用してログを収集、解析、視覚化します。 Filebeat エージェントをデプロイして、ログを ElasticSearch に送信します。

マイクロサービス アーキテクチャは、PHP フレームワーク (Symfony や Laravel など) を使用してマイクロサービスを実装し、RESTful 原則と標準データ形式に従って API を設計します。マイクロサービスはメッセージ キュー、HTTP リクエスト、または gRPC を介して通信し、監視とトラブルシューティングに Prometheus や ELKStack などのツールを使用します。
