前言
在日常的網站發布中很多情況下都無法做到一個IP對應一個站點,在IP4的情況下IP的資源是相對有限的。然而作為最流行的Apache自然也考慮到這種情況,下面來一起看看詳細的介紹吧。
配置方法
首先apache的版本是2.4.7,然后系統是Ubuntu 14.04.1 LTS。(因為好像配置文件和目錄有差異)
首先進到apache2目錄下,
我們要探討的主要是sites-available和sites-enabled根據字面意思,前一個是網站可用的,后一個是網站可用的,然后我們還知道了,sites-enabled里面的文件是sites-available里面文件的軟鏈接,所以我們主要改site-available的文件,打開site-available有兩個文件,但我們只需要000-default.conf文件,打開cat文件
代碼如下:
<VirtualHost *:80> # The ServerName directive sets the request scheme, hostname and port that # the server uses to identify itself. This is used when creating # redirection URLs. In the context of virtual hosts, the ServerName # specifies what hostname must appear in the request's Host: header to # match this virtual host. For the default virtual host (this file) this # value is not decisive as it is used as a last resort host regardless. # However, you must seothert it for any further virtual host explicitly. #ServerName www.example.com ServerAdmin webmaster@localhost DocumentRoot /var/www/ # Available loglevels: trace8, ..., trace1, debug, info, notice, warn, # error, crit, alert, emerg. # It is also possible to configure the loglevel for particular # modules, e.g. #LogLevel info ssl:warn ErrorLog ${APACHE_LOG_DIR}/error.log CustomLog ${APACHE_LOG_DIR}/access.log combined # For most configuration files from conf-available/, which are # enabled or disabled at a global level, it is possible to # include a line for only one particular virtual host. For example the # following line enables the CGI configuration for this host only # after it has been globally disabled with "a2disconf". #Include conf-available/serve-cgi-bin.conf</VirtualHost>
這就是網址配置文件了,而我們要修改的只有被注釋掉的ServerName 域名,DocumentRoot 路徑這兩個部分,去掉注釋剩下。
<VirtualHost *:80> ServerName #這里是域名地址 ServerAdmin webmaster@localhost DocumentRoot /var/www/ #這里是路徑 ErrorLog ${APACHE_LOG_DIR}/error.log CustomLog ${APACHE_LOG_DIR}/access.log combined</VirtualHost>
可以直接添加在下面,重啟apache就成了。但是上面的優先級要更高,訪問自己的域名會跳轉到你設置的路徑,直接訪問ip還是會到第一個設置的路徑,你也可以選擇刪除。
還有另外一種改法就是新建一個文件,xxx.conf然后內容一樣,
<VirtualHost *:80> ServerName #這里是域名地址 ServerAdmin webmaster@localhost DocumentRoot /var/www/ #這里是路徑 ErrorLog ${APACHE_LOG_DIR}/error.log CustomLog ${APACHE_LOG_DIR}/access.log combined</VirtualHost>
在創建軟鏈接 ln -s ../sites-avaiable/xxx.conf ../sites-enable/xxx.conf
這樣子也可以實現,但是優先級還是000-default.conf高。
好了,就是這么簡單。
附:配置Apache2.4.7反向代理的方法
1.設置httpd.conf
打開Apache24/conf文件夾下的httpd.conf設置文件,找到一下幾行把前面的注釋‘#'刪除
LoadModule proxy_module modules/mod_proxy.soLoadModule proxy_connect_modulemodules/mod_proxy_connect.soLoadModule proxy_ftp_modulemodules/mod_proxy_ftp.soLoadModule proxy_http_modulemodules/mod_proxy_http.so
(Ps:很多人都會注釋LoadModuleproxy_balancer_modulemodules/mod_proxy_balancer.so
,然而這個是做負載均衡用的一個功能,單純做反向代理的話,不需要用這個,而且取消了這里的注釋不進行相應的設置的話,會導致apache服務無法開啟)
然后找到Include conf/extra/httpd-vhosts.conf
這一行前面的注釋‘#'也刪除,引入這個文件
2.設置httpd-vhosts.conf
打開Apache24/conf/extra文件夾下的httpd-vhosts.conf.conf找到
<VirtualHost _default_:80>#ServerName www.example.com:80DocumentRoot "${SRVROOT}/htdocs"</VirtualHost>
在后面添加
ProxyRequests OffProxyPass /***(你想要訪問的地址) http://*******(想要代理的地址)ProxyPassReverse /***(你想要訪問的地址) http://*******(想要代理的地址)
比如說我想在瀏覽器中輸入localhost,但實際獲取的內容是www.baidu.com的話就可以設置為ProxyPass /***(你想要訪問的地址) http://*******(想要代理的地址),第二個ProxyPassReverse是做域名重定向使用的,如果你代理的那個地址重定向的跳到另一個地方,有了ProxyPassReverse的設置就可以相應的跳轉過去 沒有的話可能就會報錯
如果想讓別的電腦訪問自己電腦的外網地址就可以訪問自己服務器可以設置一下httpd.conf中的<Directory "${SRVROOT}/htdocs">
把 Require all denied
改為Require all granted
允許所有的請求和訪問
然后就可以使用了~
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。
新聞熱點
疑難解答