mkdir docker
,然后在该docker目录下创建php、nginx、mysql等目录
1.创建网络
创建网络用于nginx和php之间的通信,也可以用link的方式
docker network create —driver bridge —subnet=192.138.0.0/16 mynginx
创建一个名为mynginx的网桥,ip段为192.138.0.0
2.php
1.安装php
// 1.拉取php镜像,这里以php7.4为例
docker pull php:7.4-fpm
// 2.启动php容器,并绑定上一步创建的网络
docker run -d --name php:7.4-fpm --network mynginx --ip=192.138.0.2 -v ~/docker/nginx/www:/www php:8.2.4-fpm-alpine3.17
启动php容器并绑定上一步创建的网络,这里取名为php:7.4-fpm。本地创建的docker/nginx/www
目录映射到docker容器中的/www
目录
2.安装php扩展
常规的扩展可以通过docker-php-ext-install命令安装,进入容器docker exec -it 容器ID bash
,运行以下命令即可快速安装扩展
// mysql_pdo
docker-php-ext-install pdo pdo_mysql
// pcntl
docker-php-ext-install pdo pdo_mysql
有些扩展没有的话需要手动安装,这里以redis为例:
// 1.下载redis扩展
wget https://pecl.php.net/get/redis-5.3.7.tgz
// 2.创建redis目录并解压到redis目录中
mkdir reids
tar -zxvf redis-5.3.7.tgz -C redis
// 3.编译安装
cd redis/redis-5.3.7
/usr/local/bin/phpize // 执行phpize
whereis php-config // 找到php-config位置
./configure --with-php-config=/usr/local/bin/php-config
make & make install
// 4.配置
cd /usr/local/etc/php/conf.d
vim docker-php-ext-sodium.ini
extension=/usr/local/lib/php/extensions/no-debug-non-zts-20210902/redis.so // 在php配置文件中加入第3步编译安装时的的redis扩展信息
操作完成后php -m
查看redis扩展信息,所有扩展安装后最好都重启一下容器参考
3.nginx
nginx采用最新版就行,这里选择体积较小的alpine版本
// 1.拉取nginx镜像
docker pull nginx:1.23.4-alpine
// 2.启动nginx容器并指定我们自己创建的网络
docker run --name nginx -p 80:80 -v ~/docker/nginx/www/:/usr/share/nginx/html -v ~/docker/nginx/conf.d:/etc/nginx/conf.d --network mynginx nginx:1.23.4-alpine
/usr/share/nginx/html
是nginx的默认工作目录,/etc/nginx/conf.d
是nginx的默认配置目录,这里在本地的docker/nginx目录下创建了www和conf.d目录,用于挂在docker容器中nginx的工作和配置目录,并绑定我们刚刚创建的网络mynginx(这样才能通过网络访问到php容器),然后绑定80端口
接下来在本地的docker/nginx/conf.d
目录下创建nginx.conf
文件,内容如下
server {
listen 80;
location / {
root /usr/share/nginx/html; // 这里是容器中nginx的访问目录
index index.html index.php;
}
// 配置PHP处理
location ~ \.php$ {
root /www; // 注意这里是php容器中的www目录,对应着宿主机的docker/nginx/www目录,这是在创建php容器时的目录映射
fastcgi_pass 192.138.0.10:9000; // 这里是通过网桥去访问php容器
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
}
这里需要注意root配置项的填写,不然访问php文件可能报错如file not found或者502之类的,如果是laravel或者yii等框架也只需要将两处root完整的指定到访问目录,如
// yii
root /usr/share/nginx/html/yii/web;
root /www/yii/web;
// laravel
root /usr/share/nginx/html/laravel/public;
root /www/laravel/public;
4.mysql
// 1.拉取镜像
docker pull:5.7.41
// 启动容器
docker run --name mysql -e MYSQL_ROOT_PASSWORD=123456 -v ~/docker/mysql/conf:/etc/mysql/conf.d/ -v ~/docker/mysql/data:/var/lib/mysql -p 3306:3306 -d mysql:5.7.41
这里创建mysql容器和上面步骤大致相同,指定了mysql的配置目录和数据存放目录的映射(预防数据丢失),并设置了数据库密码,由于mysql没有设置网络,在宿主机中可以以127.0.0.1:3306
访问,若在容器中可以以真实ip:3306
访问
5.其它
还有些其它常用的容器就简略写下
1.redis
docker run --name redis -p 6379:6379 -v ~/docker/redis/conf/redis.conf:/etc/redis/redis.conf -v ~/docker/redis/data/:/data --restart=always -d redis:7.0.10-alpine redis-server /etc/redis/redis.conf
2.mongo
docker run -d --name mongo -v ~/docker/mongo/data:/data/db -p 27017:27017 -e MONGO_INITDB_ROOT_USERNAME=admin -e MONGO_INITDB_ROOT_PASSWORD=123456 --restart=always mongo:6.0.5-jammy
3.elasticsearch
docker run -d --name es -v ~/docker/elastic/es7.10/elasticsearch:/usr/share/elasticsearch -p 9200:9200 blacktop/elasticsearch:7.10
docker run --init -d --name kibana -e elasticsearch.hosts="http://192.168.2.4:9200" -p 5601:5601 blacktop/kibana:7.10
4.rabbitmq
docker run -d --name rabbitmq -e RABBITMQ_DEFAULT_USER=root -e RABBITMQ_DEFAULT_PASS=123456 -p 8080:15672 -p 5672:5672
rabbitmq:3.11-management-alpine