在Linux系统中更换域名涉及多个层面的配置调整,包括系统主机名、Web服务器配置、DNS解析以及相关服务重启等操作,以下是详细步骤及注意事项,确保域名更换后服务正常运行。

准备工作:备份关键配置文件
更换域名前,务必备份可能涉及的配置文件,避免误操作导致服务中断,需要备份的文件包括:
- 系统主机名配置文件:
/etc/hostname、/etc/hosts - Web服务器配置文件(如Apache的
/etc/apache2/sites-available/目录下文件、Nginx的/etc/nginx/sites-available/目录下文件) - 数据库中可能包含旧域名的表(如WordPress的
wp_options表) - SSL证书文件(若使用HTTPS,需确认证书是否与新域名匹配,否则需重新申请)
修改系统主机名(Hostname)
系统主机名是服务器自身的标识,需与新域名保持一致(可选,但推荐),根据Linux发行版不同,操作略有差异:
| 发行版 | 修改命令 | 涉及文件 |
|---|---|---|
| Ubuntu/Debian | sudo hostnamectl set-hostname new.domain.com |
/etc/hostname、/etc/hosts |
| CentOS/RHEL | sudo hostnamectl set-hostname new.domain.com |
/etc/hostname、/etc/hosts |
操作完成后,需同步更新/etc/hosts文件,确保本地解析正确:
sudo nano /etc/hosts
在文件中添加或修改以下内容(将0.0.1后的旧域名替换为新域名):

0.0.1 localhost 127.0.0.1 new.domain.com
修改Web服务器配置
Web服务器(Apache/Nginx)的域名配置是核心环节,需修改虚拟主机(VirtualHost)中的ServerName和ServerAlias,并设置旧域名重定向(可选)。
Apache配置
- 编辑虚拟主机配置文件(如
/etc/apache2/sites-available/000-default.conf):sudo nano /etc/apache2/sites-available/000-default.conf
- 修改
<VirtualHost *:80>块中的域名信息:<VirtualHost *:80> ServerName new.domain.com ServerAlias www.new.domain.com # 可选,添加带www的域名 DocumentRoot /var/www/html # 网站根目录 # 其他配置(如目录权限、日志路径等) </VirtualHost> - 若需旧域名301重定向到新域名,可添加以下配置:
<Virtual *:80> ServerName old.domain.com Redirect 301 / https://new.domain.com/ # 强制跳转到新域名 </VirtualHost> - 启用配置并重启Apache:
sudo a2ensite 000-default.conf # 启用配置(若未启用) sudo systemctl restart apache2
Nginx配置
- 编辑虚拟主机配置文件(如
/etc/nginx/sites-available/default):sudo nano /etc/nginx/sites-available/default
- 修改
server块中的域名信息:server { listen 80; server_name new.domain.com www.new.domain.com; # 新域名及www子域名 root /var/www/html; # 网站根目录 # 其他配置(如index、location规则等) } - 旧域名301重定向配置:
server { listen 80; server_name old.domain.com; return 301 https://new.domain.com$request_uri; # 跳转到新域名 } - 测试配置语法并重启Nginx:
sudo nginx -t # 测试语法 sudo systemctl restart nginx
配置DNS解析
登录域名注册商(如阿里云、Cloudflare)管理后台,将新域名的DNS记录指向服务器IP地址:
- A记录:将
new.domain.com和www.new.domain.com解析到服务器公网IP。 - CNAME记录(可选):若需子域名(如
blog.new.domain.com),可添加CNAME指向主域名。 - TTL值:建议设置为短时间(如5分钟),以便快速生效(通常生效时间为10分钟-24小时,具体以DNS缓存为准)。
更新数据库中的旧域名(若涉及)
若网站使用数据库(如MySQL、PostgreSQL),且数据库中存储了旧域名(如WordPress的站点URL),需执行以下操作:
- 以WordPress为例,通过phpMyAdmin或命令行登录数据库,执行SQL更新:
UPDATE wp_options SET option_value = 'https://new.domain.com' WHERE option_name IN ('home', 'siteurl'); UPDATE wp_posts SET post_content = REPLACE(post_content, 'old.domain.com', 'new.domain.com'); UPDATE wp_postmeta SET meta_value = REPLACE(meta_value, 'old.domain.com', 'new.domain.com');
验证与测试
- 本地测试:修改本地
hosts文件(Windows/Mac/Linux),将新域名指向服务器IP,通过浏览器访问验证页面是否正常。 - 远程测试:等待DNS生效后,使用
curl命令测试:curl -I https://new.domain.com # 检查HTTP状态码(应为200)
- 检查日志:查看Web服务器错误日志(如
/var/log/apache2/error.log或/var/log/nginx/error.log),确认无配置错误。
相关问答FAQs
Q1:更换域名后网站无法访问,可能的原因有哪些?
A:常见原因包括:

- DNS解析未生效(可通过
ping new.domain.com检查IP是否正确); - Web服务器配置错误(如
ServerName拼写错误,或未重启服务); - 防火墙阻止(如
ufw或iptables未开放80/443端口); - 数据库中仍存在旧域名(需检查并更新相关表数据)。
Q2:如何将旧域名的HTTPS流量重定向到新域名的HTTPS?
A:需在Web服务器配置中同时处理HTTP和HTTPS重定向,并确保新域名已配置SSL证书,以Nginx为例:
# 旧域名HTTP重定向到新域名HTTPS
server {
listen 80;
server_name old.domain.com;
return 301 https://new.domain.com$request_uri;
}
# 新域名HTTPS配置(需提前配置证书)
server {
listen 443 ssl;
server_name new.domain.com www.new.domain.com;
ssl_certificate /path/to/new.crt; # 新域名证书
ssl_certificate_key /path/to/new.key;
root /var/www/html;
# 其他配置
}
配置完成后重启Nginx即可实现旧域名HTTPS强制跳转到新域名HTTPS。
原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/38263.html