Mac で Docker を使用して LNMP 開発環境を構成する方法: 1. Docker をインストールします; 2. インストール環境を構成します; 3. Mysql5.7 をインストールします; 4. php7.4.5 をインストールします; 5. nginx1.16.1 をインストールします; 5. nginx1.16.1 をインストールします。 6. docker-compose を構成します。
この記事の動作環境:macOS10.15システム、php7.4.5バージョン、MacBook Air 2019コンピュータ
Docker構成Mac 開発環境での LNMP
前書き:
1. Docker の標準的な使用法では、各 Docker コンテナーは 1 つのサービスのみを提供します。
したがって、mysql 用の別のコンテナ、php-fpm 用の別のコンテナ、nginx 用の別のコンテナにする必要があります。
2. Docker の設計コンセプトは、コンテナ内でバックグラウンド サービスを実行することではありません。コンテナ自体はホスト上の独立したメイン プロセスであり、コンテナ内でサービスを実行するアプリケーション プロセスとして間接的に理解することもできます。 。コンテナのライフサイクルはこのメインプロセスを中心に展開するため、コンテナの正しい使用方法は、コンテナ内のサービスをフォアグラウンドで実行することです。
1. Docker のインストール
ダウンロードしてインストールします
ダウンロード アドレス https://download.docker.com/mac/stable/Docker.dmg
構成イメージのアクセラレーション
環境設定 >> Docker エンジン
{ "registry-mirrors": [ "https://registry.docker-cn.com", "http://hub-mirror.c.163.com", "https://docker.mirrors.ustc.edu.cn" ] }
構成ステータスの表示docker info
2. インストール環境の構成
centos のインストール (スキップ可能)
イメージ バージョンの表示 https://hub.docker.com/_/centos?tab=tags
イメージのプル
docker pull centos:centos7.8.2003
ミラーの表示
docker images
コンテナの作成
docker run -v /data:/docker_data -p 80:80 -itd --privileged=true centos:v0.0.1 /usr/sbin/init // -v 挂载路径 本地/data挂载到容器的/docker_data路径 // -p 端口映射 // -i 允许你对容器内的标准输入 (STDIN) 进行交互 // -t 在新容器内指定一个伪终端或终端 // -d 在后台运行 // --privileged=true 以特权模式运行容器(可以运行后台服务)
コンテナの表示
docker ps // -l 查看历史容器
コンテナの入力
docker exec -it 46e9810a35e6 bash
画像の更新 (コンテナのコピーの送信)
docker commit -m "test update" 21e09cfcc692 centos:test
ミラーの削除
docker rmi centos:test
問題 1: リポジトリ参照「centos:test」を削除できません (強制する必要があります) - コンテナー 46e9810a35e6 はその参照イメージ 5b5eb956a405
解決策: ビューと過去のイメージを削除します
docker ps -l docker rm 46e9810a35e6
Mysql5.7 をインストールします
イメージをプルします
docker pull mysql:5.7
コンテナを作成します
docker run -p 3306:3306 --name mysql_test -v ~/Docker/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root -d --privileged=true mysql:5.7
コマンド手順
-p 3306:3306:将容器的3306端口映射到主机的3306端口 -v PWD/mysql/data:/var/lib/mysql:将主机当前目录下的mysql/data文件夹挂载到容器的/var/lib/mysql 下,在mysql容器中产生的数据就会保存在本机mysql/data目录下(路径会自动创建) -e MYSQL_ROOT_PASSWORD=passwd:初始化root用户的密码 -d 后台运行容器 --name 给容器指定别名 --privileged=true centos7 可能会碰到权限问题,需要加参数
コンテナ
docker exec -it mysql_test /bin/bash
Dockerにsudoを追加する方法
1.创建docker组:sudo groupadd docker 2.将当前用户加入docker组:sudo gpasswd -a ${USER} docker 3.重启服务:sudo service docker restart 4.刷新docker成员:newgrp - docker
Macの下に
#查看用户组: dscl . list /groups #添加用户组: sudo dscl . -create /Groups/docker 添加user到group: sudo dscl . -append /Groups/docker GroupMembership username
php7.4.5をインストール
イメージをPullします
docker pull php:7.4.5-fpm
Dockerfile の作成
vim Dockerfile FROM php:7.4.5-fpm RUN apt-get update && apt-get install -y \ libfreetype6-dev \ libjpeg62-turbo-dev \ libpng12*-dev \ && docker-php-ext-enable opcache \ && docker-php-ext-install pdo_mysql \ && docker-php-ext-install gd \
イメージの構築
docker build -t="php:7.4.5v2" .
開始
docker run -d -p 9000:9000 -v /var/www/html/:/var/www/html/ --name php-with-mysql --link mysql_test:mysql --volumes-from mysql_test --privileged=true php-fpm5.6/v2
コマンドの説明
-v 将本地磁盘上的php代码挂载到docker 环境中,对应docker的目录是 /var/www/html/ --name 新建的容器名称 php-with-mysql --link 链接的容器,链接的容器名称:在该容器中的别名,运行这个容器是,docker中会自动添加一个host识别被链接的容器ip --privileged=true 权限问题
備考
nproc内核参数,是系统上的最大进程数。 $(nproc)是获取安装系统的该内核参数。常用的还有获取文件路径的命令$(pwd)
拡張機能関連
# 查看已开启扩展 php -m # 查看现有可以启动的扩展 ls /usr/local/lib/php/extensions/no-debug-non-zts-20190902/ # 启动扩展 docker-php-ext-enable opcache # 安装并启动扩展
参考 Docker php 拡張機能のインストール手順の詳細説明
nginx1.16.1のインストール
イメージのプル
docker pull nginx:1.16.1
コンテナの作成
docker run -d --link php-with-mysql:phpfpm --volumes-from php-with-mysql -p 80:80 -v /var/www/nginx/conf/default.conf:/etc/nginx/conf.d/default.conf --name nginx-php --privileged=true nginx
コマンドの説明
--link php-with-mysql:phpfpm 将php容器链接到nginx容器里来,phpfpm是nginx容器里的别名。 --volumes-from php-with-mysql 将php-with-mysql 容器挂载的文件也同样挂载到nginx容器中 -v /var/www/nginx/conf/default.conf:/etc/nginx/conf.d/default.conf 将nginx 的配置文件替换,挂载本地编写的配置文件
デフォルト構成
vim default.conf server { listen 80; server_name localhost; location / { root /var/www/html; index index.html index.htm index.php; # 增加index.php } #error_page 404 /404.html; # redirect server error pages to the static page /50x.html # error_page 500 502 503 504 /50x.html; location = /50x.html { root /var/www/html; } location ~ \.php$ { root /var/www/html; # 代码目录 fastcgi_pass phpfpm:9000; # 修改为phpfpm容器 fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; # 修改为$document_root include fastcgi_params; } }
構成 docker-compose
ファイル構造ツリー
. ├── docker-compose.yml ├── mysql │ └── Dockerfile ├── nginx │ ├── Dockerfile │ └── conf │ └── default.conf ├── phpfpm │ └── Dockerfile └── res └── index.php
YAML構成
vim docker-compose.yml nginx: build: ./nginx ports: - "80:80" links: - "phpfpm" volumes: - /Users/majun/docker/res:/var/www/html - /Users/majun/docker/nginx/conf:/etc/nginx/conf.d phpfpm: build: ./phpfpm ports: - "9000:9000" volumes: - /Users/majun/docker/res:/var/www/html links: - "mysql" mysql: build: ./mysql ports: - "3306:3306" volumes: - /Users/majun/docker/mysql/data:/var/lib/mysql environment: MYSQL_ROOT_PASSWORD : root
Mysql Dockerfile
FROM mysql:5.7
Nginx Dockerfile
FROM nginx:1.16.1
PHPFPM Dockerfile (上で構築したイメージはここで直接使用されています)
FROM php:7.4.5v2
PHP 接続 Mysql テスト
vim index.php //PDO中的预处理1:sql语句中是: (别名的方式)的 header("Content-type:text/html;charset=utf-8"); //实例化PDO try{ $pdo = new PDO( "mysql:host=mysql;dbname=test", "root", "root" ); }catch(PDOException $pe){ die("PDO实例失败!原因:".$pe->getMessage()); } //定义sql语句 $sql = "select * from test"; //预处理sql $stmt = $pdo->prepare($sql); //执行 $stmt->execute(); // 获取多条数据 $res = $stmt->fetchAll(PDO::FETCH_ASSOC); var_dump($res);
備考ホストは mysql を記述する必要がありますコンテナ名
実行
docker-compose up -d
その他
redisのインストール
イメージのプル
docker pull redis
コンテナの作成
docker run -itd -p 6379:6379 redis
コンテナのデバッグに入る
# redis-cli 127.0.0.1:6379> set name 1 OK 127.0.0.1:6379> get name "1"
推奨される学習: 「PHP ビデオ チュートリアル 」
以上がMac 上で Docker を使用して LNMP 開発環境を構成する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、酸とベースのデータベースモデルを比較し、その特性と適切なユースケースを詳述しています。酸は、財務およびeコマースアプリケーションに適したデータの整合性と一貫性を優先し、ベースは可用性に焦点を当て、

この記事では、コードインジェクションのような脆弱性を防ぐために、PHPファイルのアップロードを確保することについて説明します。ファイルタイプの検証、セキュアストレージ、およびアプリケーションセキュリティを強化するエラー処理に焦点を当てています。

記事では、組み込み関数、ホワイトリストアプローチ、サーバー側の検証などの手法に焦点を当てたセキュリティを強化するためのPHP入力検証のベストプラクティスについて説明します。

この記事では、Token BucketやLeaky BucketなどのアルゴリズムやSymfony/Rate-Limiterなどのライブラリを使用するなど、PHPでAPIレート制限を実装するための戦略について説明します。また、監視、動的に調整されたレートの制限、および手をカバーします

この記事では、パスワードを保護するためにPHPでpassword_hashとpassword_verifyを使用することの利点について説明します。主な議論は、これらの関数が自動塩の生成、強力なハッシュアルゴリズム、およびSecurを通じてパスワード保護を強化するということです

この記事では、PHPおよび緩和戦略におけるOWASPトップ10の脆弱性について説明します。重要な問題には、PHPアプリケーションを監視および保護するための推奨ツールを備えたインジェクション、認証の壊れ、XSSが含まれます。

この記事では、PHPでのXSS攻撃を防ぐための戦略について説明し、入力の消毒、出力エンコード、セキュリティを向上させるライブラリとフレームワークの使用に焦点を当てています。

この記事では、PHPでのインターフェイスと抽象クラスの使用について説明し、それぞれをいつ使用するかに焦点を当てています。インターフェイスは、無関係なクラスや複数の継承に適した、実装なしで契約を定義します。抽象クラスは共通の機能を提供します


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

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

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

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません
