Docker运行WordPress通过Nginx反向代理开启HTTPS绑定域名

末蓝、 2022-09-15 12:43 255阅读 0赞

src=http\_\_\_blog.orx.me\_wpcontent\_uploads\_2013\_12\_wordpresslogo.jpgrefer=http\_\_\_blog.orx.jpg

后续更新地址:https://www.aiprose.com/blog/147

本文使用docker-compose运行wordpress,使用已有的mysql数据库,外部的nginx开启https反向代理到wordpress。如果你的域名还没有备案请先去备案。

编写启动文件

编写wordpress.yml,然后执行 docker-compose -f wordpress.yml up -d 启动容器

172.18.0.1:3308是我自己的mysql地址

  1. version: "3"
  2. services:
  3. wordpress:
  4. image: wordpress:latest
  5. ports:
  6. - "8000:80"
  7. restart: always
  8. volumes:
  9. - /opt/wordpress:/var/www/html
  10. environment:
  11. - WORDPRESS_DB_HOST=172.18.0.1:3308
  12. - WORDPRESS_DB_USER=wordpress
  13. - WORDPRESS_DB_PASSWORD=wordpress

如果你之前没有现成的mysql数据库,可以按照官网的教程编写配置文件

  1. version: '3.1'
  2. services:
  3. wordpress:
  4. image: wordpress
  5. restart: always
  6. ports:
  7. - 8080:80
  8. environment:
  9. WORDPRESS_DB_HOST: db
  10. WORDPRESS_DB_USER: wordpress
  11. WORDPRESS_DB_PASSWORD: wordpress
  12. WORDPRESS_DB_NAME: wordpress
  13. volumes:
  14. - /opt/wordpress:/var/www/html
  15. db:
  16. image: mysql:5.7
  17. restart: always
  18. environment:
  19. MYSQL_DATABASE: wordpress
  20. MYSQL_USER: wordpress
  21. MYSQL_PASSWORD: wordpress
  22. MYSQL_RANDOM_ROOT_PASSWORD: '1'
  23. volumes:
  24. - /opt/mysql:/var/lib/mysql

这里需要去wordpress后台配置地址,修改为我们最后带域名的地址。
访问 ip:8000/wp-admin
image.png

配置Nginx

这里使用nginx开启https并反向代理到worpress,如果没有安装nginx,请先安装nginx。HTTPS证书可以去阿里云申请免费的SSL证书,这里的坑比较多,请注意仔细看配置文件。
我们的案例域名是aispider.cc,我们把域名全部重定向到 https://www.aispider.cc
vi /etc/nginx/nginx.conf

  1. server {
  2. listen 80;
  3. server_name aispider.cc;
  4. location / {
  5. if ($host !~* ^www) {
  6. set $name_www www.$host;
  7. rewrite ^(.*) https://$name_www$1 permanent;
  8. }
  9. rewrite ^(.*) https://$host$1 permanent;
  10. }
  11. }
  12. server {
  13. listen 80;
  14. server_name www.aispider.cc;
  15. rewrite ^(.*) https://$host$1 permanent;
  16. }
  17. server {
  18. listen 443 ssl http2 default_server;
  19. server_name www.aispider.cc;
  20. ssl_certificate "/opt/cer/aispider.cc.pem";
  21. ssl_certificate_key "/opt/cer/aispider.cc.key";
  22. ssl_session_cache shared:SSL:1m;
  23. ssl_session_timeout 10m;
  24. ssl_ciphers PROFILE=SYSTEM;
  25. ssl_prefer_server_ciphers on;
  26. location / {
  27. if ($host !~* ^www) {
  28. set $name_www www.$host;
  29. rewrite ^(.*) https://$name_www$1 permanent;
  30. }
  31. proxy_pass http://localhost:8000;
  32. proxy_redirect off;
  33. proxy_set_header Host $host;
  34. proxy_set_header X-Real-IP $remote_addr;
  35. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  36. proxy_set_header X-Forwarded-Host $server_name;
  37. proxy_set_header X-Forwarded-Proto https;
  38. proxy_set_header Upgrade $http_upgrade;
  39. proxy_set_header Connection "upgrade";
  40. proxy_read_timeout 86400;
  41. }
  42. }

修改wordpress配置文件

如果直接代理过去,会有很多问题,比如循环重定向转发,js、css等资源走的是http请求,地址重定向为localhost,我也是踩了很多坑才配置好。

修改/opt/wordpress/wp-config.php,这个是docker容器挂载的卷,增加如下内容
vi /opt/wordpress/wp-config.php

  1. define('FORCE_SSL_ADMIN', true);
  2. if (strpos($_SERVER['HTTP_X_FORWARDED_PROTO'], 'https') !== false){
  3. $_SERVER['HTTPS'] = 'on';
  4. $_SERVER['SERVER_PORT'] = 443;
  5. }
  6. if (isset($_SERVER['HTTP_X_FORWARDED_HOST'])) {
  7. $_SERVER['HTTP_HOST'] = $_SERVER['HTTP_X_FORWARDED_HOST'];
  8. }
  9. define('WP_HOME','https://www.aispider.cc/');
  10. define('WP_SITEURL','https://www.aispider.cc/');

修改后最好重启一下容器,docker-compose -f wordpress.yml restart

最后访问配置好的地址 https://www.aispider.cc/

我这里用的主题是 RK blogger ,如果喜欢,自行百度去下载安装。一定要记得修改主题配置底部备案信息的展示。

image.png

发表评论

表情:
评论列表 (有 0 条评论,255人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Docker Nginx 反向代理

    最近在系统性梳理网关的知识,其中网关的的功能有一个是代理,正好咱们常用的Nginx也具备次功能,今天正好使用Nginx实现一下反向代理,与后面网关的代理做一个对比,因为我使用的

    相关 Nginx反向代理多个域名

    简介 由于公司内网有多台服务器的http服务要映射到公司外网静态IP,如果用路由的端口映射来做,就只能一台内网服务器的80端口映射到外网80端口,其他服务器的80端口只能