首页
/ 使用nginx-proxy实现www域名重定向到主域名

使用nginx-proxy实现www域名重定向到主域名

2025-05-11 11:28:51作者:卓炯娓

在部署Web应用时,我们经常需要将带www的域名(如www.example.com)重定向到主域名(example.com),这不仅有利于SEO优化,也能统一访问入口。本文将介绍如何使用nginx-proxy这一Docker容器来实现这一功能。

为什么需要重定向www到主域名

  1. SEO优化:避免搜索引擎将www和非www版本视为两个不同网站
  2. 统一访问:确保用户无论输入哪种形式都能访问到同一内容
  3. 统计准确:避免流量分散统计

使用nginx-proxy的基本配置

nginx-proxy是一个流行的Docker容器,可以自动为其他容器配置Nginx反向代理。配合acme-companion容器,还能自动获取Let's Encrypt证书。

基本docker-compose配置如下:

services:
  nginx-proxy:
    image: nginxproxy/nginx-proxy
    # ...其他配置
  
  acme-companion:
    image: nginxproxy/acme-companion
    # ...其他配置
  
  your_web_app:
    image: your_web_app:latest
    environment:
      - VIRTUAL_HOST=example.com,www.example.com
      - LETSENCRYPT_HOST=example.com,www.example.com

实现www重定向的解决方案

虽然nginx-proxy默认不提供www重定向功能,但我们可以通过"location_override"文件来实现。

方法步骤

  1. 创建vhost目录:在主机上创建一个目录用于存放虚拟主机配置

  2. 挂载目录到容器:修改nginx-proxy的docker-compose配置,添加卷挂载

services:
  nginx-proxy:
    volumes:
      - ./vhost:/etc/nginx/vhost.d
  1. 创建重定向配置文件:在vhost目录中创建以www.你的域名_location_override命名的文件

  2. 配置重定向规则:在文件中添加以下Nginx配置

location / {
    return 301 https://example.com$request_uri;
}

工作原理

  1. nginx-proxy会自动加载/etc/nginx/vhost.d目录下的配置文件
  2. 通过_location_override后缀的文件可以覆盖特定域名的location配置
  3. 当访问www域名时,Nginx会返回301永久重定向到主域名

注意事项

  1. 确保主域名和www域名都正确配置了SSL证书
  2. 重定向规则应使用301而非302,以利于SEO
  3. 测试时可以使用curl命令检查重定向是否正确
  4. 清除浏览器缓存后再测试,避免缓存影响

通过以上配置,我们就能优雅地实现www域名到主域名的重定向,同时保持HTTPS的安全连接。这种方法不仅适用于单个网站,也可以轻松扩展到多个域名的管理。

登录后查看全文
热门项目推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
177
262
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
864
512
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
182
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
261
302
kernelkernel
deepin linux kernel
C
22
5
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
596
57
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
371
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
332
1.08 K