1.安装docker服务
yum -y install docker
2.启动mysql
下载镜像
docker pull mysql #不带版本号的话默认为最新版本
docker pull mysql:5.7 #指定拉取5.7版本的mysql
然后创建容器并启动服务
docker run \
--name mysql \
-d \
-p 3306:3306 \
--restart unless-stopped \
-v /mydata/mysql/log:/var/log/mysql \
-v /mydata/mysql/data:/var/lib/mysql \
-v /mydata/mysql/conf:/etc/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
mysql:5.7
3.启动redis(如果不需要此服务则跳过)
下载镜像
docker pull redis
然后创建容器并启动服务
docker run -itd -p 6379:6379 \
-v ~/Documents/docker/redis/data:/redis \ #redis数据存储的文件映射
-v ~/Documents/docker/redis/redis.conf:/etc/redis/redis.conf \ #配置文件的映射
--name redis redis --bind 0.0.0.0 --protected-mode no
4.启动php-fpm
下载镜像
docker pull php:7.4-fpm
然后创建容器并启动服务
docker run --name php-fpm74 --privileged=true -d \
-v ~/Documents/code:/home/wwwroot \ #映射自己的代码文件保存路径
--link mysql5.7:mysql \ #根据需要自行决定是否需要link链接
--link redis:redis \ #根据需要自行决定是否需要link链接
php:7.4-fpm
根据需求,选择性安装某些扩展文件
pecl install -o -f redis && docker-php-ext-enable redis
docker-php-ext-install pdo pdo_mysql
docker-php-ext-install gd
docker-php-ext-install -j$(nproc) bcmath
5.启动nginx
下载镜像
docker pull nginx
然后创建容器并启动服务
docker run --name myNginx -p 9100-9200:9100-9200 --privileged=true -d \
-v ~/Documents/code:/home/wwwroot \
-v ~/Documents/docker/nginx/conf.d:/etc/nginx/conf.d \
--link php-fpm74:php \
--link mysql5.7:mysql \
--link redis:redis \
nginx
特别注意,在配置nginx的conf站点文件时,fastcgi的路径一定要与php-fpm容器中的php脚本路径一致,可参考如下配置,nginx的端口可自行随意更改
server {
listen 9100;
server_name tools.92funs.com;
root /home/wwwroot/tools_git/public;
index index.php;
location / {
if ( !-e $request_filename) {
rewrite ^/(.*)$ /index.php/$1 last;
break;
}
}
location ~ \.php(.*)$ {
#fastcgi_pass php:9000;
fastcgi_pass php:9000;
fastcgi_index index.php;
#下面两句是给fastcgi权限,可以支持 ?s=/module/controller/action的url访问模式
fastcgi_split_path_info ^((?U).+\.php)(/?.+)$;
fastcgi_param SCRIPT_FILENAME /home/wwwroot/tools_git/public$fastcgi_script_name; #特别说明:这里的/www要与php56fpm容器里映射的php脚本路径一致,否则php-fpm将找不到php脚本,会报404错误
#下面两句才能真正支持 index.php/index/index/index的pathinfo模式
fastcgi_param PATH_INFO $fastcgi_path_info;
#fastcgi_param PATH_TRANSLATED $document_root$fastcgi_path_info;
fastcgi_param PATH_TRANSLATED /home/wwwroot/tools_git/public$fastcgi_path_info;
include fastcgi_params;
}
}
在跨容器使用时,需要特别注意每个容器的IP地址,如果配置没有对应会导致出现网站404或无法访问等现象
docker 其他命令参考
1.查看启动参数
1,在容器外部,物理机上,可以用下面命令
docker inspect <container_name> # 可以是container_name或者container_id
# 默认的输出信息很多,可以通过-f, --format格式化输出:
docker inspect --format='{{.NetworkSettings.Networks.bridge.IPAddress}}' <container_name> # format是go语言的template,还有其他的用法
2,如果在容器内部。可以用下面命令
ps -ef # 其中1号进程就是command启动命令
2.查看当前正在运行的容器列表
docker ps -a --no-trunc | grep container_name # 通过docker --no-trunc参数来详细展示容器运行命令
3.其他常用命令
docker ps -a #查看所有的容器
docker stop <容器id或者容器name> #停止指定容器运行
docker start <容器id或者容器name> #启动指定容器
docker rm <容器id或者容器name> #删除指定容器
docker rm -f <容器id或者容器name> #强制删除容器,包含正在运行中的,该命令慎重使用
docker exec -it <容器id或者容器name> /bin/bash #进入到指定容器中操作
docker rmi -f 镜像id #删除指定镜像,带-f表示强制删除