先创建一个共有的网络
docker network create -d bridge my-net
创建php-fpm容器
docker run -d -it --rm --name my-php --network my-net -v/root/docker/app/test:/usr/share/nginx/html php:7.1-fpm
要注意的是PHP的容器也要挂在文件目录-html,不然访问不到php文件的
接着在阿里云配置好SSL证书,下载秘钥下来做准备。
创建nginx容器
docker run -d --rm -it --name my-nginx -v /root/docker/conf/default.conf:/etc/nginx/conf.d/default.conf -v /root/docker/app/test:/usr/share/nginx/html -v /root/docker/cert/:/etc/nginx/cert/ -p 8089:443 -p 8090:80 --network my-net nginx
-v 挂载目录
-p 端口映射,注意要映射两个,其中一个是https的443端口,一个http的80端口(这样https和http都可以访问)
-network 容器加入网络
--rm stop容器时自动删除
cert/是证书文件的目录
接着配置Nginx的default.conf,配置ssl和连接php-cgi的代码都在里面
server {
listen 443;
root /usr/share/nginx/html;
server_name www.wrsndm.online;
ssl on;
ssl_certificate cert/2055101_www.wrsndm.online.pem;
ssl_certificate_key cert/2055101_www.wrsndm.online.key;
ssl_session_timeout 5m;
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_prefer_server_ciphers on;
location / {
index index.html index.htm;
}
location ~ \.php$ {
root /usr/share/nginx/html;
fastcgi_pass my-php:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /usr/share/nginx/html/$fastcgi_script_name;
fastcgi_param SCRIPT_NAME $fastcgi_script_name;
include fastcgi_params;
}
}
接着访问https://www.wrsndm.online:8089(注意这里访问的是443端口的映射,即8089端口,这个坑了我3个小时。。。)
访问成功就是OK了