Nginx 虛擬主機配置的三種方式(基於域名)

佚名發表於2018-12-19
Nginx配置虛擬主機支援3種方式:基於IP的虛擬主機配置,基於埠的虛擬主機配置,基於域名的虛擬主機配置。本文主要介紹了基於域名的實現,感興趣的小夥伴們可以參考一下

3、Nginx基於域名的虛擬主機配置

使用基於域名的虛擬主機配置是比較流行的方式,可以在同一個IP上配置多個域名並且都透過80埠訪問。

3.1 假設伺服器有個IP地址為192.168.2.155

  1. [root@localhost ~]# ifconfig ens33:5 192.168.2.155/24 up
  2. [root@localhost ~]# ifconfig
  3. ens33:5: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
  4. inet 192.168.2.155 netmask 255.255.255.0 broadcast 192.168.2.255
  5. ether 00:0c:29:16:90:ae txqueuelen 1000 (Ethernet)

3.2 192.168.2.155對應的域名如下,配置主機的host檔案便於測試

  1. [root@localhost ~]# vim /etc/hosts
  2. [root@localhost ~]# cat /etc/hosts|grep 192.168.2.155
  3. 192.168.2.155 www.oa.com
  4. 192.168.2.155 www.bbs.com
  5. 192.168.2.155 www.test.com

3.3 建立虛擬主機存放網頁的根目錄,並建立首頁檔案index.html

  1. [root@localhost ~]# cd /data/www/
  2. [root@localhost www]# mkdir www.oa.com
  3. [root@localhost www]# mkdir www.bbs.com
  4. [root@localhost www]# mkdir www.test.com
  5. [root@localhost www]# echo www.oa.com > www.oa.com/index.html
  6. [root@localhost www]# echo www.bbs.com > www.bbs.com/index.html
  7. [root@localhost www]# echo www.test.com > www.test.com/index.html

3.4 修改nginx.conf,將虛擬主機配置檔案包含進主檔案

  1. [root@localhost /]# cd /usr/local/nginx/conf/
  2. [root@localhost conf]# ls
  3. fastcgi.conf fastcgi_params koi-utf mime.types nginx.conf scgi_params uwsgi_params win-utf
  4. fastcgi.conf.default fastcgi_params.default koi-win mime.types.default nginx.conf.default scgi_params.default uwsgi_params.default
  5. [root@localhost conf]# vim nginx.conf

在nginx.conf檔案末尾加入以下配置

  1. # 在http段中找到以下內容並刪除每行前面的“#”
  2. log_format main '$remote_addr - $remote_user [$time_local] "$request" '
  3. '$status $body_bytes_sent "$http_referer" '
  4. '"$http_user_agent" "$http_x_forwarded_for"';
  5. # 配置檔案結尾的最後一個“}”之前加入以下語句,如下所示
  6. include vhost/*.conf

3.5 編輯每個域名的配置檔案(每個虛擬主機的配置檔案)

  1. [root@localhost conf]# cd vhost/
  2. [root@localhost vhost]# cat www.oa.com.conf
  3. server {
  4. listen 192.168.2.155:80;
  5. server_name www.oa.com;
  6. Access_log /data/logs/www.oa.com.log main;
  7. error_log /data/logs/www.oa.com.error.log;
  8. location / {
  9. root /data/www/www.oa.com;
  10. index index.html index.htm;
  11. }
  12. }
  13. [root@localhost vhost]# cat www.bbs.com.conf
  14. server {
  15. listen 192.168.2.155:80;
  16. server_name www.bbs.com;
  17. access_log /data/logs/www.bbs.com.log main;
  18. error_log /data/logs/www.bbs.com.error.log;
  19. location / {
  20. root /data/www/www.bbs.com;
  21. index index.html index.htm;
  22. }
  23. }
  24. [root@localhost vhost]# cat www.test.com.conf
  25. server {
  26. listen 192.168.2.155:80;
  27. server_name www.test.com;
  28. access_log /data/logs/www.test.com.log main;
  29. error_log /data/logs/www.test.com.error.log;
  30. location / {
  31. root /data/www/www.test.com;
  32. index index.html index.htm;
  33. }
  34. }
  35. [root@localhost vhost]# cat /data/www/www.oa.com/index.html
  36. www.oa.com
  37. [root@localhost vhost]# cat /data/www/www.bbs.com/index.html
  38. www.bbs.com
  39. [root@localhost vhost]# cat /data/www/www.test.com/index.html
  40. www.test.com

3.6 建立日誌檔案,否則無法啟動nginx

  1. [root@localhost /]# mkdir -p /data/logs
  2. [root@localhost /]# touch /data/logs/www.oa.com.log
  3. [root@localhost /]# touch /data/logs/www.oa.com.error.log
  4. [root@localhost /]# touch /data/logs/www.bbs.com.log
  5. [root@localhost /]# touch /data/logs/www.bbs.com.error.log
  6. [root@localhost /]# touch /data/logs/www.test.com.log
  7. [root@localhost /]# touch /data/logs/www.test.com.error.log
  8. [root@localhost /]# ls /data/logs/
  9. www.oa.com.error.log www.bbs.com.error.log www.test.com.error.log
  10. www.oa.com.log www.bbs.com.log www.test.com.log

3.7 先測試配置檔案然後再啟動nginx

  1. [root@localhost /]# cd /usr/local/nginx/sbin/
  2. [root@localhost sbin]# ./nginx -t
  3. nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
  4. nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
  5. # 啟動nginx
  6. [root@localhost sbin]# ./nginx

3.8 測試檔案

  1. [root@localhost vhost]# curl http://www.oa.com
  2. www.oa.com
  3. [root@localhost vhost]# curl http://www.bbs.com
  4. www.bbs.com
  5. [root@localhost vhost]# curl http://www.test.com
  6. www.test.com

附:配置過程中的問題

1、最後測試時發生的問題

  1. [root@localhost ~]# curl http://www.oa.com
  2. curl: (7) Failed connect to www.oa.com:80; 拒絕連線

解決方法:

檢視Nginx是否在監聽相應的埠。

  1. [root@localhost ~]# netstat -lnt
  2. Active Internet connections (only servers)
  3. Proto Recv-Q Send-Q Local Address Foreign Address State
  4. tcp 0 0 0.0.0.0:111 0.0.0.0:* LISTEN
  5. tcp 0 0 192.168.2.155:80 0.0.0.0:* LISTEN
  6. tcp 0 0 0.0.0.0:8080 0.0.0.0:* LISTEN
  7. tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN
  8. tcp 0 0 127.0.0.1:25 0.0.0.0:* LISTEN
  9. tcp6 0 0 :::111 :::* LISTEN
  10. tcp6 0 0 :::22 :::* LISTEN
  11. tcp6 0 0 :::23 :::* LISTEN
  12. tcp6 0 0 ::1:25 :::* LISTEN

1、配置虛擬主機檔案時要加上監聽的IP地址,每個虛擬主機配置檔案都一樣。

  1. listen 192.168.2.155:80;

2、配置完成後要重啟伺服器

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援IT科技網。

相關文章