在服务器管理中,使用Apache搭建多个网站是一项常见需求,无论是托管个人博客、企业官网还是多个项目,合理配置多站点都能提升服务器资源利用率和管理效率,本文将详细介绍基于Apache的多个网站搭建方法,涵盖环境准备、虚拟主机配置、SSL证书部署及常见问题解决等关键环节。

环境准备与基础配置
在开始配置前,需确保服务器已安装Apache服务,以Ubuntu系统为例,可通过以下命令安装:
sudo apt update && sudo apt install apache2 -y
安装完成后,检查Apache服务状态:
sudo systemctl status apache2
确保服务处于“active(运行)”状态,需准备多个域名并解析至服务器IP地址,例如site1.com和site2.com,这里假设域名为示例,实际操作中需替换为真实域名。
理解Apache虚拟主机
Apache通过虚拟主机(Virtual Host)实现单服务器多站点部署,主要有两种类型:基于域名和基于IP,基于域名的虚拟主机最为常用,通过不同域名区分站点,即使共享同一IP地址也能独立运行,配置文件通常位于/etc/apache2/sites-available/目录下,默认包含000-default.conf(默认站点配置)和default-ssl.conf(HTTPS站点配置)。
创建虚拟主机配置文件
为每个网站创建独立的配置文件,确保结构清晰且易于管理,以site1.com为例,执行以下命令创建配置文件:
sudo nano /etc/apache2/sites-available/site1.com.conf
在文件中写入以下内容:

<VirtualHost *:80>
ServerName site1.com
ServerAlias www.site1.com
DocumentRoot /var/www/site1.com
<Directory /var/www/site1.com>
Options Indexes FollowSymLinks
AllowOverride All
Require all granted
</Directory>
ErrorLog ${APACHE_LOG_DIR}/site1.com_error.log
CustomLog ${APACHE_LOG_DIR}/site1.com_access.log combined
</VirtualHost>参数说明:
ServerName:主域名;ServerAlias:附加域名(如带www的子域名);DocumentRoot:网站根目录,需提前创建并设置权限:sudo mkdir -p /var/www/site1.com sudo chown -R $USER:$USER /var/www/site1.com sudo chmod -R 755 /var/www/site1.com
ErrorLog和CustomLog:分别定义错误日志和访问日志路径,便于排查问题。
按相同步骤为site2.com创建配置文件site2.com.conf,仅需修改ServerName、ServerAlias和DocumentRoot参数。
启用虚拟主机并测试配置
创建配置文件后,需使用a2ensite命令启用站点,并禁用默认站点(如无需保留):
sudo a2ensite site1.com.conf sudo a2ensite site2.com.conf sudo a2dissite 000-default.conf
随后检查Apache配置语法是否正确:
sudo apache2ctl configtest
若输出“Syntax OK”,则说明配置无语法错误,最后重启Apache服务使配置生效:
sudo systemctl restart apache2
在浏览器中访问site1.com和site2.com,应分别显示各自根目录下的内容(如默认的index.html)。

配置HTTPS(SSL证书)
现代网站需支持HTTPS以保障数据安全,可通过Let’s Encrypt免费获取SSL证书,使用certbot工具自动化部署:
- 安装Certbot:
sudo apt install certbot python3-certbot-apache -y
- 为站点申请证书:
sudo certbot --apache -d site1.com -d www.site1.com
按提示完成邮箱验证和协议选择后,Certbot会自动修改虚拟主机配置,添加443端口(HTTPS)和SSL相关指令。
site1.com.conf会新增如下内容:<VirtualHost *:443> ServerName site1.com DocumentRoot /var/www/site1.com SSLEngine on SSLCertificateFile /etc/letsencrypt/live/site1.com/fullchain.pem SSLCertificateKeyFile /etc/letsencrypt/live/site1.com/privkey.pem # 其他配置... </VirtualHost>
证书默认有效期为90天,可通过
sudo certbot renew --dry-run测试自动续期功能。
多站点管理常见问题
访问异常(显示默认页面或403错误)
- 检查DocumentRoot:确保路径正确且文件存在;
- 检查目录权限:
DocumentRoot及其子目录权限需为755,文件权限为644; - 检查SELinux(如启用):执行
sudo chcon -R -t httpd_sys_content_t /var/www/site1.com。
域名无法访问
- 检查DNS解析:使用
dig site1.com确认域名已解析至服务器IP; - 检查防火墙:确保允许80(HTTP)和443(HTTPS)端口,如UFW需执行:
sudo ufw allow 'Apache Full'
日志管理
每个站点的日志独立存储在/var/log/apache2/目录下,可通过tail -f /var/log/apache2/site1.com_access.log实时查看访问记录,为避免日志文件过大,可配置日志轮转(Logrotate),默认配置已包含Apache日志轮转规则。
通过Apache虚拟主机功能,可高效实现多站点部署,关键步骤包括创建独立配置文件、设置域名与目录映射、启用SSL加密及权限管理,合理规划目录结构和日志策略,不仅能提升服务器稳定性,还能简化后续运维工作,对于更复杂的需求(如子目录部署、反向代理),可进一步结合Apache的mod_rewrite和mod_proxy模块实现高级功能。
图片来源于AI模型,如侵权请联系管理员。作者:酷小编,如若转载,请注明出处:https://www.kufanyun.com/ask/28858.html
