Apache搭建多个站点方法详解
Apache的虚拟主机是一种允许在同一台机器上配置多个不同站点的web服务器环境的,就是iis一样可以创建多站点了,但是apache需要在编辑状态操作,不能像windows iis直接点击几下就好了,下面我来给各位介绍配置方法。
最平常的大概有3种方法。
第一种:单IP不同端口
第二种:多IP同端口(独立IP的虚拟空间)
第三种:域名绑定根目录的方式(共享IP的虚拟空间)
Apache的核心配置文件名是”httpd.conf”,其所存放的路径在Apache目录下的conf文件夹下。修改它只需要使用记事本(建议使用其他编辑器,带行数的那种,方便修改),生效的话只需要保存httpd.conf,重启apache即可。
下面多站点支持的话,修改httpd.conf的第187~264行(不同的httpd.conf可能有差异),也就是在ServerAdmin和ServerName那里,大部分是注释。下面是主要修改的地方。
注意:如果是服务器请备份httpd.conf后再修改文件。
 
例子分别通过80和8080访问不同的根目录。
大概在50几行有个Listen 80,在下面添加8080端口。
网站访问网址:
网站1: http://www.yeniugo.com
网站2: http://yeniugo.com:8080
 
IP地址1:192.168.2.2
IP地址2:192.168.1.68
端口同是80端口。
网站访问网址:
网站1: http://www.yeniugo.com
网站2: http://yeniugo.com
 
网站访问网址:
网站1: http://www.yeniugo.com
网站2: http://yeniugo.com
备注:对于reviewboard中
修改最后一行为
以上是http配置方法,https配置方法类似,区别主要有两点,一个是配置文件不一样,ssl.conf,一个是VirtualHost的端口和内容会有少许差别。内容的话,仿照系统默认的那个写一个即可。
下面有一个demo,仅供参考
http
最平常的大概有3种方法。
第一种:单IP不同端口
第二种:多IP同端口(独立IP的虚拟空间)
第三种:域名绑定根目录的方式(共享IP的虚拟空间)
Apache的核心配置文件名是”httpd.conf”,其所存放的路径在Apache目录下的conf文件夹下。修改它只需要使用记事本(建议使用其他编辑器,带行数的那种,方便修改),生效的话只需要保存httpd.conf,重启apache即可。
下面多站点支持的话,修改httpd.conf的第187~264行(不同的httpd.conf可能有差异),也就是在ServerAdmin和ServerName那里,大部分是注释。下面是主要修改的地方。
注意:如果是服务器请备份httpd.conf后再修改文件。
第一种:单IP不同端口
例子分别通过80和8080访问不同的根目录。
大概在50几行有个Listen 80,在下面添加8080端口。
<VirtualHost *:80>
    ServerAdmin admin@yeniugo.com
    ServerName www.yeniugo.com:80
    DocumentRoot "/var/www/www1"
     <Directory "/var/www/www1">
     Options  Indexes FollowSymLinks
     AllowOverride All
     Require all granted
   </Directory>
</VirtualHost>
<VirtualHost *:8080>
    ServerAdmin admin@yeniugo.com
    ServerName yeniugo.com:8080
    DocumentRoot "/var/www/www2"
   <Directory "/var/www/www2">
     Options Indexes FollowSymLinks
     AllowOverride All
     Require all granted
   </Directory>
</VirtualHost>
网站访问网址:
网站1: http://www.yeniugo.com
网站2: http://yeniugo.com:8080
第二种多IP同端口。
IP地址1:192.168.2.2
IP地址2:192.168.1.68
端口同是80端口。
<VirtualHost 192.168.1.68:80>
    ServerAdmin admin@yeniugo.com
    ServerName www.yeniugo.com:80
    DocumentRoot "/var/www/www1"
     <Directory "/var/www/www1">
     Options  Indexes FollowSymLinks
     AllowOverride All
     Require all granted
   </Directory>
</VirtualHost>
<VirtualHost 192.168.2.2:80>
    ServerAdmin admin@yeniugo.com
    ServerName yeniugo.com:80
    DocumentRoot "/var/www/www2"
   <Directory "/var/www/www2">
     Options  Indexes FollowSymLinks
     AllowOverride All
     Require all granted
   </Directory>
</VirtualHost>
网站访问网址:
网站1: http://www.yeniugo.com
网站2: http://yeniugo.com
第三种同IP不同域名和根目录(域名的话修改本地host演示)。
<VirtualHost *:80>
    ServerAdmin admin@yeniugo.com
    ServerName www.yeniugo.com
    DocumentRoot "/var/www/www1"
     <Directory "/var/www/www1">
     Options  Indexes FollowSymLinks
     AllowOverride All
     Require all granted
   </Directory>
</VirtualHost>
<VirtualHost *:80>
    ServerAdmin admin@yeniugo.com
    ServerName yeniugo.com
    DocumentRoot "/var/www/www2"
   <Directory "/var/www/www2">
     Options  Indexes FollowSymLinks
     AllowOverride All
     Require all granted
   </Directory>
</VirtualHost>
网站访问网址:
网站1: http://www.yeniugo.com
网站2: http://yeniugo.com
备注:对于reviewboard中
/var/www/reviewboard/conf/settings_local.py修改最后一行为
ALLOWED_HOSTS = ['*']或者主机本身IP,修改成'*'以支持多个ip地址https,SSL配置
以上是http配置方法,https配置方法类似,区别主要有两点,一个是配置文件不一样,ssl.conf,一个是VirtualHost的端口和内容会有少许差别。内容的话,仿照系统默认的那个写一个即可。
下面有一个demo,仅供参考
<VirtualHost *:443>
    ServerName www.yeniugo.com:443
    DocumentRoot "/var/www/www"
    <Directory "/var/www/www"> 
     Options Indexes FollowSymLinks
     AllowOverride All 
     Require all granted 
    </Directory>
    ErrorLog logs/www_ssl_error_log
    TransferLog logs/www_ssl_access_log
    LogLevel warn
    SSLEngine on
    SSLProtocol all -SSLv2
    SSLCipherSuite HIGH:MEDIUM:!aNULL:!MD5:!SEED:!IDEA
    SSLCertificateFile /var/www/ssl/public.pem
    SSLCertificateKeyFile /var/www/ssl/private.key
   <Files ~ "\.(cgi|shtml|phtml|php3?)$">
    SSLOptions +StdEnvVars
   </Files>
   <Directory "/var/www/cgi-bin">
    SSLOptions +StdEnvVars
   </Directory>
   BrowserMatch "MSIE [2-5]" \
         nokeepalive ssl-unclean-shutdown \
         downgrade-1.0 force-response-1.0
   CustomLog logs/ssl_request_log \
          "%t %h %{SSL_PROTOCOL}x %{SSL_CIPHER}x \"%r\" %b"
</VirtualHost>
评论
发表评论