apache實現(xiàn)部署多個網(wǎng)站(一個ip部署多域名)的方法詳解
前言
在日常的網(wǎng)站發(fā)布中很多情況下都無法做到一個IP對應(yīng)一個站點,在IP4的情況下IP的資源是相對有限的。然而作為最流行的Apache自然也考慮到這種情況,下面來一起看看詳細(xì)的介紹吧。
配置方法
首先apache的版本是2.4.7,然后系統(tǒng)是Ubuntu 14.04.1 LTS。(因為好像配置文件和目錄有差異)
首先進到apache2目錄下,
我們要探討的主要是sites-available和sites-enabled根據(jù)字面意思,前一個是網(wǎng)站可用的,后一個是網(wǎng)站可用的,然后我們還知道了,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>
這就是網(wǎng)址配置文件了,而我們要修改的只有被注釋掉的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就成了。但是上面的優(yōu)先級要更高,訪問自己的域名會跳轉(zhuǎn)到你設(shè)置的路徑,直接訪問ip還是會到第一個設(shè)置的路徑,你也可以選擇刪除。
還有另外一種改法就是新建一個文件,xxx.conf然后內(nèi)容一樣,
<VirtualHost *:80> ServerName #這里是域名地址 ServerAdmin webmaster@localhost DocumentRoot /var/www/ #這里是路徑 ErrorLog ${APACHE_LOG_DIR}/error.log CustomLog ${APACHE_LOG_DIR}/access.log combined </VirtualHost>
在創(chuàng)建軟鏈接 ln -s ../sites-avaiable/xxx.conf ../sites-enable/xxx.conf
這樣子也可以實現(xiàn),但是優(yōu)先級還是000-default.conf高。
好了,就是這么簡單。
附:配置Apache2.4.7反向代理的方法
1.設(shè)置httpd.conf
打開Apache24/conf文件夾下的httpd.conf設(shè)置文件,找到一下幾行把前面的注釋‘#'刪除
LoadModule proxy_module modules/mod_proxy.so LoadModule proxy_connect_modulemodules/mod_proxy_connect.so LoadModule proxy_ftp_modulemodules/mod_proxy_ftp.so LoadModule proxy_http_modulemodules/mod_proxy_http.so
(Ps:很多人都會注釋LoadModuleproxy_balancer_modulemodules/mod_proxy_balancer.so
,然而這個是做負(fù)載均衡用的一個功能,單純做反向代理的話,不需要用這個,而且取消了這里的注釋不進行相應(yīng)的設(shè)置的話,會導(dǎo)致apache服務(wù)無法開啟)
然后找到Include conf/extra/httpd-vhosts.conf
這一行前面的注釋‘#'也刪除,引入這個文件
2.設(shè)置httpd-vhosts.conf
打開Apache24/conf/extra文件夾下的httpd-vhosts.conf.conf找到
<VirtualHost _default_:80> #ServerName www.example.com:80 DocumentRoot "${SRVROOT}/htdocs" </VirtualHost>
在后面添加
ProxyRequests Off ProxyPass /***(你想要訪問的地址) http://*******(想要代理的地址) ProxyPassReverse /***(你想要訪問的地址) http://*******(想要代理的地址)
比如說我想在瀏覽器中輸入localhost,但實際獲取的內(nèi)容是www.baidu.com的話就可以設(shè)置為ProxyPass /***(你想要訪問的地址) http://*******(想要代理的地址),第二個ProxyPassReverse是做域名重定向使用的,如果你代理的那個地址重定向的跳到另一個地方,有了ProxyPassReverse的設(shè)置就可以相應(yīng)的跳轉(zhuǎn)過去 沒有的話可能就會報錯
如果想讓別的電腦訪問自己電腦的外網(wǎng)地址就可以訪問自己服務(wù)器可以設(shè)置一下httpd.conf中的<Directory "${SRVROOT}/htdocs">
把 Require all denied
改為Require all granted
允許所有的請求和訪問
然后就可以使用了~
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
Linux系統(tǒng)中sudo命令的十個技巧總結(jié)
Linux 下使用Sudo 命令,可以讓普通用戶也能執(zhí)行一些或者全部的root命令,下面這篇文章主要給大家介紹了關(guān)于Linux系統(tǒng)中sudo命令的十個技巧,需要的朋友可以參考借鑒,下面來一起看看吧。2018-04-04Centos7運用/dev/shm進行網(wǎng)站優(yōu)化
這篇文章主要介紹了LINUX中Centos7運用/dev/shm進行網(wǎng)站優(yōu)化相關(guān)知識點,對此有興趣的朋友參考學(xué)習(xí)下。2018-03-03