我的开发环境是Windows10,使用VirtualBox安装的CentOS-7作为Docker的宿主机。
本文从头开始讲解部署lnmp环境,最后创建一个Laravel项目为例。
安装仓库:
$ sudo yum install -y yum-utils \
device-mapper-persistent-data \
lvm2
设置仓库地址:
$ sudo yum-config-manager \
--add-repo \
https://download.docker.com/linux/centos/docker-ce.repo
安装最新版本的 Docker Engine-Community:
$ sudo yum install docker-ce docker-ce-cli containerd.io
启动Docker服务:
$ sudo service docker start
验证安装:
$ sudo docker version
为了避免每次命令都输入sudo(可选):
$ sudo usermod -aG docker $USER
使用国内镜像:(也可选阿里云等等)
$ vi /etc/docker/daemon.json
{"registry-mirrors": ["https://registry.docker-cn.com","http://hub-mirror.c.163.com"]}
$ systemctl restart docker.service
参考: 官方文档
可以根据需要的环境选择版本:
$ docker pull php:7.2.30-fpm
$ docker pull nginx
$ docker pull mysql:5.7.30
$ docker pull redis
查看镜像:
$ docker images
参考:Docker Hub镜像源
创建名为my-net的网络,指定子网段:
$ docker network create -d bridge --subnet 172.18.1.0/16 my-net
查看所有网络:
$ docker network ls
查看刚创建的网络:
$ docker network inspect my-net
创建redis容器,加入my-net,并指定IP(若不指定IP,停止容器后再启动,IP会变化。其他容器同理。):
$ docker run --name my-redis -d --network my-net --ip 172.18.1.13 -p 6379:6379 redis
创建mysql容器,密码123456:
$ docker run --name my-mysql -d --network my-net --ip 172.18.1.12 -p 3306:3306 \
-e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7.30
创建php容器,映射本地/data/wwwroot目录到容器中的/data目录:
(若想映射配置文件目录,可加上此参数: -v /data/config/php:/usr/local/etc/php/conf.d)
(-v参数,冒号左边是宿主机路径,冒号右边是容器路径)
(若用已装有nginx的宿主机,这里路径最好设置一样的,方便js、css等文件的获取。若设置不同路径,则nginx配置文件中需要手动写$document_root的值)
$ docker run --name my-php -d --network my-net --ip 172.18.1.11 \
-v /data/wwwroot:/data/wwwroot \
php:7.2.30-fpm
创建nginx容器,映射项目目录和配置目录(:ro表示readonly):
$ docker run --name my-nginx -p 80:80 -d --network my-net --ip 172.18.1.10 \
-v /data/wwwroot:/data/wwwroot:ro \
-v /data/config/nginx:/etc/nginx/conf.d:ro \
nginx
查看所有容器,检查STATUS是否为UP:
$ docker ps -a
创建nginx配置文件(文件名是.conf 结尾就会被自动加载):
$ vi /data/config/nginx/cls.com.conf
server {
listen 80;
server_name cls.com; # 主机名
root /data/cls.com/public; # 项目index.php所在目录
index index.php index.html index.htm;
location / {
# 本例使用laravel的rewrite,如果是其他框架,请使用相应配置。
try_files $uri $uri/ /index.php?$query_string;
}
location ~ [^/]\.php(/|$) {
fastcgi_pass 172.18.1.11:9000; # php容器的IP
fastcgi_index index.php;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
}
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|flv|mp4|ico)$ {
expires 30d;
access_log off;
}
location ~ .*\.(js|css)?$ {
expires 7d;
access_log off;
}
location ~ /\.ht {
deny all;
}
}
重启容器以加载配置文件:
$ docker restart my-nginx
多站点配置,就新建一个xxx.conf文件,复制以上配置,修改server_name,root参数即可。
进入php容器:
$ docker exec -it my-php bash
php镜像内自带默认的php.ini-development和php.ini-production两个配置文件,开发用dev生产用pro,本例使用开发配置:
$ cp "$PHP_INI_DIR/php.ini-development" "$PHP_INI_DIR/php.ini"
PHP配置文件目录在$PHP_INI_DIR/conf.d/,php容器将自动加载此目录中以.ini结尾的配置文件。
重启php容器:
$ exit
$ docker restart my-php
参考官方镜像文档
进入php容器:
$ docker exec -it my-php bash
安装mysql相关扩展(docker-php-ext-install是容器内置脚本)
$ docker-php-ext-install pdo_mysql
$ docker-php-ext-install mysqli
安装redis扩展(可以在github上找最新的版本):
$ docker-php-source extract # 创建并初始化 /usr/src/php目录(扩展源码在/usr/src/php/ext)
$ curl -L -o /tmp/redis.tar.gz https://github.com/phpredis/phpredis/archive/5.1.1.tar.gz
$ tar xfz /tmp/redis.tar.gz
$ rm -r /tmp/redis.tar.gz
$ mv phpredis-5.1.1 /usr/src/php/ext/redis
$ docker-php-ext-install redis
重启php容器:
$ exit
$ docker restart my-php
若不是laravel项目,以下内容可以忽略。
进入php容器:
$ docker exec -it my-php bash
安装git和zip(composer依赖):
$ apt-get update
$ apt-get install git
$ apt-get install zip
安装composer:
$ php -r "copy('https://install.phpcomposer.com/installer', 'composer-setup.php');"
$ php composer-setup.php
$ php -r "unlink('composer-setup.php');"
$ mv composer.phar /usr/local/bin/composer
$ composer config -g repo.packagist composer https://mirrors.aliyun.com/composer/
克隆php项目:
$ cd /data
$ git clone xxxxxxxxxxcls.com
$ cd /data/cls.com
$ composer install
重启容器:
$ exit
$ docker restart my-php
若没有权限,在宿主机更新相关目录权限:(可选)
$ chmod o+rwx -R /data/wwwroot/cls.com
最后在.env中配置好mysql和redis的IP和密码。
配置windows的hosts文件,尾部加上域名解析:
192.168.2.23 cls.com
打开浏览器访问cls.com。