具有两个域的虚拟主机不起作用



我无法用VirtualHost配置两个域,因为,请始终向我展示一个域。我的意思是,如果我访问domainb.com,将我重定向到domaina.com和domaina.com的工作正常。我在Anothers主持人中进行了此过程:Digitalocean或我自己的Localhost,但是对于此情况,我找不到问题。如果我禁用一个站点,另一个毫无问题的工作。

我有一个带有Ubuntu 17.10的Google实例,而Apache2具有两个域(VirtualHost(。我禁用了默认的VirtualHost。我的文件夹结构是/var/www/domaina/and/var/www/domainb/p>

Cloud DNS配置了两个区域domaina.com和domainb.com,其中a和cname记录指向我的服务器IP。我也有NS记录指向googledomains.com,在我的雷吉塔尔(Registar(中,我添加了这些DNS。

如果我对两个域进行ping,它们可以正确地解决我的IP地址。

i有两个域在网站上配置了:

#in /etc/apache/sites-available/domainA.com.conf
<VirtualHost *:443>
        ServerAdmin webmaster@domainA.com
        ServerName domainA.com
        ServerAlias www.domainA.com
        DocumentRoot /var/www/domainA
        ErrorLog ${APACHE_LOG_DIR}/error-domainA.log
        CustomLog ${APACHE_LOG_DIR}/access-domainA.log combined
        SSLEngine on
        SSLCertificateFile /etc/apache2/sslcert/certified-number.crt
        SSLCertificateKeyFile /etc/apache2/sslcert/domainA.com.key
        SSLCertificateChainFile /etc/apache2/sslcert/gd_bundle-g2-g1.crt
        <FilesMatch ".(cgi|shtml|phtml|php)$">
            SSLOptions +StdEnvVars
        </FilesMatch>
        <Directory /var/www/domainA/>
            Options FollowSymLinks
            AllowOverride All
        </Directory>
        <Directory /usr/lib/cgi-bin>
            SSLOptions +StdEnvVars
        </Directory>
</VirtualHost>
#in /etc/apache/sites-available/domainB.com.conf
<VirtualHost *:80>
        ServerAdmin webmaster@domainB.com
        ServerName domainB.com
        ServerAlias www.domainB.com
        DocumentRoot /var/www/domainB
        ErrorLog ${APACHE_LOG_DIR}/error-domainB.log
        CustomLog ${APACHE_LOG_DIR}/access-domainB.log combined
        <Directory /var/www/domainB/>
                Options FollowSymLinks
                AllowOverride All
        </Directory>
</VirtualHost>

apachectl -s命令的结果:

sudo apache2ctl -s

VirtualHost configuration:
*:80                   domainB.com (/etc/apache2/sites-enabled/domainB.conf:1)
*:443                  domainA.com (/etc/apache2/sites-enabled/domainA.conf:1)
ServerRoot: "/etc/apache2"
Main DocumentRoot: "/var/www/html"
Main ErrorLog: "/var/log/apache2/error.log"
Mutex rewrite-map: using_defaults
Mutex ssl-stapling-refresh: using_defaults
Mutex ssl-stapling: using_defaults
Mutex ssl-cache: using_defaults
Mutex default: dir="/var/run/apache2/" mechanism=default 
Mutex mpm-accept: using_defaults
Mutex watchdog-callback: using_defaults
PidFile: "/var/run/apache2/apache2.pid"
Define: DUMP_VHOSTS
Define: DUMP_RUN_CFG
User: name="www-data" id=33
Group: name="www-data" id=33

我还必须检查哪些其他设置?

更新信息:如果我尝试使用www for domaina,则可以正常工作。

  • www.domaina.com-> works
  • domaina.com->不起作用,重定向到domainb.com
  • www.domainb.com-> works
  • domainb.com-> works

我在domaina.com的端口443中仅具有虚拟霍斯特配置。

我添加了一个配置 *:80,重定向到SSL并起作用。这样:

<VirtualHost *:80>
        ServerAdmin webmaster@domainA.com
        ServerName domainA.com
        ServerAlias www.domainA.com
        Redirect / https://www.domainA.com/
</VirtualHost>

感谢马特·雷恩斯的评论。

最新更新