Comment créer un environnement de développement PHP avec Docker

小云云
Libérer: 2023-03-20 12:40:02
original
3172 Les gens l'ont consulté

1.1 Pourquoi utiliser Docker ?

Existe-t-il un tel scénario ? Vous avez un projet et vous devez mettre en place un environnement lorsque vous le développez localement. Vous devez également mettre en place un environnement lorsque vous le mettez en ligne. à l'entreprise et que vous voulez y jouer en secret, vous devez mettre en place un environnement, ce n'est pas suffisant si vous ne le faites pas correspondre, car vous avez beaucoup de dépendances environnementales. Si vous avez Docker à ce moment-là, il vous suffit d'installer Docker sur la machine et de mettre le fichier Docker écrit. Cela se fera automatiquement avec une seule ligne de commandes. Ne serait-ce pas génial ?

1.2 Préparation

Ensuite, cet article présente comment configurer un environnement de développement PHP, en utilisant zPhal-dockerfiles comme exemple. Il s'agit d'un ensemble de fichiers Docker que j'ai préparés pour mon système de blog.

Maintenant, qu'il s'agisse de Windows, Mac ou Linux, Docker peut très bien le prendre en charge, y compris les systèmes Windows sous Win 10, Docker pour Windows est en fait assez bon, mais il consomme plus de mémoire.

Grâce à la ligne de commande Docker, nous pouvons faire beaucoup de choses, extraire des images, exécuter des conteneurs, exécuter des commandes dans le conteneur, etc., mais maintenant, nous devons utiliser une manière plus simple et plus grossière d'écrire Dockerfiles, puis utilisez docker -compose gère ces fichiers et simplifie le processus de fonctionnement.

Qu'est-ce qu'un Dockerfile ?

Dockerfile est un script composé d'une série de commandes et de paramètres. Ces commandes sont appliquées à l'image de base extraite et créent enfin une nouvelle image grâce à Dockerfile, nous pouvons créer une image dont vous avez besoin, qui contient le logiciel dont vous avez besoin. vouloir installer équivaut à personnaliser à l'avance les extensions à installer, les commandes à exécuter, etc., puis à les exécuter en un seul clic, simplifiant grandement le processus de fonctionnement.

Pour créer un environnement selon cet article, vous avez besoin de :

Tout d'abord, comprendre Docker et certaines opérations de base de Docker, et ce qu'est docker-compose.
Docker et docker-compose doivent ensuite être installés, j'utiliserai docker-compose pour gérer mes Dockerfiles.
Notez que l'écriture d'un Dockerfile est une chose vivante, pas une chose morte. Le Dockerfile écrit par chacun sera différent, en fonction de vos besoins.

La documentation officielle de Docker est très claire, même si elle est en anglais, elle contient essentiellement tout. Si vous avez des questions, il est très judicieux de vous référer au document : Docker Documentation.

2. Commencez à écrire

Ce qui suit prendra les fichiers zPhal-docker comme exemple. Vous pouvez cliquer sur le lien pour voir le fichier complet. Ce qui suit n'est qu'un fragment.

Aperçu 2.1

Tout d'abord, jetons un coup d'œil au projet Dockerfile que j'ai créé. Je l'ai grossièrement divisé dans les répertoires suivants (bien sûr, cela est déterminé par moi-même, et c'est le cas). il n'est pas nécessaire d'être formaté de cette façon pour vous. fichier) :


zPhal-dockerfiles
app/
 index.php
 phpinfo.php
data/
 .gitignore
files/
 mysql/
 conf.d/
  mysql-file.cnf
 Dockerfile
 nginx/
 conf.d/
  default.conf
  zphal.conf
 Dockerfile
 nginx.conf
 php/
 pkg/
  .gitignore
 Dockerfile
 php.ini
 php-dev.ini
 php-fpm.conf
 redis/
 Dockerfile
 docker-compose.yml
logs/
.gitgnore
README.md
Copier après la connexion

Dans ce projet, j'ai utilisé les extensions PHP, MySQL, Nginx, Redis, Composer, Phalcon, etc.

En général, nous avons trois processus pour ce faire : écrire le Dockerfile de chaque logiciel ; écrire le fichier de configuration ; traiter tous les Dockerfiles via docker-compose, y compris le lancement du fichier de configuration dans le fichier Dockerfile dans l'image. qui sera construit.

2.2 Écriture d'un Dockerfile

2.2.1 PHP

Ce qui suit est le Dockerfile de PHP :

FROM php:7.2-fpm

MAINTAINER goozp "gzp@goozp.com"
Définir le fuseau horaire

ENV TZ=Asia/Shanghai

RUN ln -snf /usr/share/zoneinfo/$TZ /etc/ localtime && echo $TZ > /etc/timezone

Mettre à jour et installer les packages de dépendances et les extensions de base PHP


RUN apt-get update && apt-get install -y \
git \
libfreetype6-dev \
libjpeg62-turbo-dev \
libpng-dev \
&& docker-php-ext-configure gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/ \
&& docker-php-ext-install -j$(nproc) gd \
&& docker-php-ext-install zip \
&& docker-php-ext-install pdo_mysql \
&& docker-php-ext-install opcache \
&& docker-php-ext-install mysqli \
&& rm -r /var/lib/apt/lists/*
Copier après la connexion

Mettre l'extension pré-téléchargée package de l'hôte Copiez l'hôte dans


COPY ./pkg/redis.tgz /home/redis.tgz
COPY ./pkg/cphalcon.tar.gz /home/cphalcon.tar.gz
Copier après la connexion

pour installer l'extension PECL Ici, nous installons Redis

RUN pecl install /home/redis. tgz && echo "extension =redis.so" > /usr/local/etc/php/conf.d/redis.ini

Installez des extensions tierces, voici l'extension Phalcon


RUN cd /home \
&& tar -zxvf cphalcon.tar.gz \
&& mv cphalcon-* phalcon \
&& cd phalcon/build \
&& ./install \
&& echo "extension=phalcon.so" > /usr/local/etc/php/conf.d/phalcon.ini
Copier après la connexion

Install Composer


ENV COMPOSER_HOME /root/composer
RUN curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer
ENV PATH $COMPOSER_HOME/vendor/bin:$PATH
RUN rm -f /home/redis.tgz \
rm -f /home/cphalcon.tar.gz 
WORKDIR /data
Write Permission
RUN usermod -u 1000 www-data
Copier après la connexion

La première ligne définit l'image de base Nous utilisons ici la version fpm de PHP 7.2. . Ici, la deuxième ligne définit A mainteneur.

Ensuite, le fuseau horaire est défini. Cette phrase est définie dans chaque Dockerfile. Le but principal est de synchroniser l'heure de tous les conteneurs avec l'hôte. En fait, nous pouvons la définir dans le docker-composer. fichier yml :

services:

php-fpm:

volumes:

- /etc/localtime:/etc/localtime:ro
Mais dans Lors de l'exécution sur des systèmes non Linux, tels que Windows, nous ne pouvons pas obtenir /etc/localtime Afin d'être plus compatible avec toutes les plates-formes, j'ai écrit la synchronisation de l'heure dans le Dockerfile.

接下来安装一些拓展,其实安装拓展的过程类似于我们徒手在Linux中安装PHP拓展,值得一提的是Composer。我将Composer直接安装在了php-fpm的镜像中,其实官方也提供了Composer的镜像,拉取Composer镜像执行也可以达到目的,因为我们使用Composer只是为了执行Composer命令来管理我们的包,如果Composer单独是一个容器的话,我们在不用时,还可以将容器关掉;但是在这里,我直接将Composer装进php-fpm镜像中,主要是我的项目安装了一些PHP拓展,在编写composer.json文件时,我定义了extension的依赖,这样Composer执行时会检查环境是否安装了这些依赖,所有如果我直接用Composer镜像的话,还需要把我用的拓展安装到镜像里,就麻烦多了,所以我直接在PHP镜像中就把这个事做了,其实没什么区别,取决于你怎么用。

2.2.2 Nginx

下面是Nginx的Dockerfile:

FROM nginx:1.12
set timezome

ENV TZ=Asia/Shanghai

RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone

这个就简单多了,我只设置了一个时间。因为我不需要安装其它的东西,可以直接使用官方的镜像。

当然,我们需要修改配置文件,只要事先写好配置文件就行,最后在 docker-compose.yml 文件中,将配置文件扔进去,这个下面会讲,包括PHP的配置文件,MySQL的配置文件,都是一样的。

2.2.3 MySQL

下面是 MySQL 的 Dockerfile:

FROM mysql:5.7
set timezome

ENV TZ=Asia/Shanghai

RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone

MySQL也没有什么特别之处,直接使用官方的镜像。

2.2.4 Redis

下面是 Redis 的,也直接使用官方镜像:

FROM redis:3.2
set timezome

ENV TZ=Asia/Shanghai

RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone

2.3 编写配置文件

如何处理配置文件呢,我将配置文件进行归类,PHP的配置文件放在PHP目录下,Nginx的配置放在Nginx目录下,至于要不要再新建一个子文件夹就看情况了,比如conf.d文件夹。

下面以Nginx配置文件为例,首先Nginx目录是这样的:

nginx/

conf.d/

default.conf

zphal.conf

Dockerfile

nginx.conf

除了nginx.conf外,还有一个子文件夹conf.d用来存放所有的域名配置文件,在Linux下搭建过PHP环境的应该都比较熟悉。这些配置文件就是我们到时候要传进去容器中的文件,我们并不会在宿主机使用这些文件。

所以需要注意的最重要一点就是,配置文件中出现的路径是容器内环境的路径,而不是宿主机的路径,每一个容器内都有一个运行环境,都是一台微型小系统,这些路径都是容器内的路径。我们可以通过挂载与容器内通讯来同步文件,在命令行启动容器也需要挂载文件路径,而现在挂载这一步我们也用docker-compose来解决。

下面是一个配置文件示例:


server {
listen 80 default;
index index.html index.htm;
server_name localhost docker;

root /data/www;
index index.php index.html index.htm;
location / {
 try_files $uri $uri/ /index.html;
}

location ~ \.php {
 include fastcgi_params;
 fastcgi_pass php-fpm:9000;
 fastcgi_index index.php;
 fastcgi_param SCRIPT_FILENAME /data/www/$fastcgi_script_name;
}
}
Copier après la connexion

而root /data/www中,/data/www路径,是到时候Nginx容器的路径,而不是当前在操作的宿主机的路径,所以到时候我们要挂载Web程序放的位置到这个路径。

2.4 编写 docker-compose.yml

在PHP、Nginx等目录的同级,我们创建一个docker-compose.yml,我们在执行docker-compose相关命令时,会自动找到这个文件,并根据里面的内容来执行。

接上面Nginx的例子,我们先谈挂载,因为这是最重要的一步。在docker-compose.yml中,Nginx的部分:


build: ./nginx
depends_on:
 - php-fpm
links:
 - php-fpm:php-fpm
volumes:
 - ../app:/data/www:rw
 - ./nginx/conf.d:/etc/nginx/conf.d:ro
 - ./nginx/nginx.conf:/etc/nginx/nginx.conf:ro
 - ../logs/nginx:/var/log/nginx
ports:
 - "80:80"
 - "8080:8080"
 - "443:443"
restart: always
command: nginx -g 'daemon off;'
Copier après la connexion

有一个volumes参数,这里就是我们要挂载的目录的相关配置,第一条我们将../app挂载到/data/www之中,也是我们配置文件中定义的默认监听的root,而APP目录是我们宿主机中的一个目录,通过这样挂载我们可以直接将我们的项目文件放到APP中,Docker会帮你传输到容器内的/data/www目录下。

其它的参数:

build定义了你的Dockerfile在哪里,如果没有写Dockerfile可以不用build,可以用images参数定义官方镜像,比如image:mysql:5.7;
depends_on表示将依赖其它镜像,比如Nginx依赖php-fpm,没有它我Nginx没法玩;
links定义连接,比如要连接到php-fpm容器,就是php-fpm:php-fpm,后面是别名;
ports表示端口映射,80:80表示将80端口映射到宿主机的80端口;
restart重启,restart: always表示将自动重启;
command是自动执行的命令;
……
参数很多,更多的可以参考官方文档。

下面是一个完整的 docker-compose.yml 文件:


version: '3.2'
services:
php-fpm:
build: ./php/
ports:
 - "9000:9000"
links:
 - mysql-db:mysql-db
 - redis-db:redis-db
volumes:
 - ../app:/data/www:rw
 - ./php/php-dev.ini:/usr/local/etc/php/php.ini:ro
 - ./php/php-fpm.conf:/usr/local/etc/php-fpm.conf:ro
 - ../logs/php-fpm:/var/log/php-fpm:rw
restart: always
command: php-fpm

nginx:
build: ./nginx
depends_on:
 - php-fpm
links:
 - php-fpm:php-fpm
volumes:
 - ../app:/data/www:rw
 - ./nginx/conf.d:/etc/nginx/conf.d:ro
 - ./nginx/nginx.conf:/etc/nginx/nginx.conf:ro
 - ../logs/nginx:/var/log/nginx
ports:
 - "80:80"
 - "8080:8080"
 - "443:443"
restart: always
command: nginx -g 'daemon off;'

mysql-db:
 build: ./mysql
 ports:
 - "3306:3306"
 volumes:
 - ../data/mysql:/var/lib/mysql:rw
 - ../logs/mysql:/var/lib/mysql-logs:rw
 - ./mysql/conf.d:/etc/mysql/conf.d:ro
 environment:
 MYSQL_ROOT_PASSWORD: 123456
 MYSQL_DATABASE: zphaldb
 MYSQL_USER: zphal
 MYSQL_PASSWORD: zphal123
 restart: always
 command: "--character-set-server=utf8"
redis-db:
 build: ./redis
 ports:
 - "6379:6379"
 volumes:
 - ../data/redis:/data
 restart: always
Copier après la connexion

3. 使用

这一套编写下来,我们怎么用呢?

3.1 使用搭建好的环境

首先,进入项目Dockerfiles的目录下,这里是files目录:

cd zPhal-dockerfiles/files

wget https://pecl.php.net/get/redis-3.1.6.tgz -O php/pkg/redis.tgz

wget https://codeload.github.com/phalcon/cphalcon/tar.gz/v3.3.1 -O php/pkg/cphalcon.tar.gz
然后下载我们会用到的PHP拓展包。

执行命令:

docker-compose up
Docker会自动通过编写好的docker-compose.yml内容构建镜像,并且启动容器。

如果没问题,下次启动时可以以守护模式启用,所有容器将后台运行:

docker-compose up -d
关闭容器:

可以这样关闭容器并删除服务:

docker-compose down
使用 docker-compose 基本上就这么简单,用stop,start等这些命令来操纵容器服务。而更多的工作是在于编写Dockerfile和docker-compose.yml文件。

3.2 使用Composer

当我们要使用Composer时怎么做呢? 我们已经在php-fpm里安装了Composer。

用docker-compose进行操作:

docker-compose run --rm -w /data/www/zPhal php-fpm composer update
-w /data/www/zPhal为在php-fpm的工作区域,zPhal项目也是挂载在里面,所有我们可以直接在容器里运行Composer。

或者进入宿主机APP目录下用Docker命令:

cd zPhal-dockerfiles/app

docker run -it --rm -v `pwd`:/data/www/ -w /data/www/zPhal files_php-fpm composer update

4. 注意事项

注意挂载路径。
构建失败时,注意容器内是否报错。
加速镜像。如果过程下载镜像很慢,可以使用国内的加速镜像服务。

相关推荐:

php开发环境独立安装(二):PHP与Apache整合图文教程

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!