一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

云服務器|WEB服務器|FTP服務器|郵件服務器|虛擬主機|服務器安全|DNS服務器|服務器知識|Nginx|IIS|Tomcat|

服務器之家 - 服務器技術 - Nginx - 詳解Nginx 虛擬主機配置的三種方式(基于IP)

詳解Nginx 虛擬主機配置的三種方式(基于IP)

2019-12-30 14:23B8613A Nginx

Nginx配置虛擬主機支持3種方式主要有基于IP的虛擬主機配置,基于端口的虛擬主機配置,基于域名的虛擬主機配置。本文主要介紹了基于IP配置的實現,感興趣的小伙伴們可以參考一下

Nginx配置虛擬主機支持3種方式:基于IP的虛擬主機配置,基于端口的虛擬主機配置,基于域名的虛擬主機配置。

詳解Nginx 虛擬主機配置的三種方式(基于端口) http://www.ythuaji.com.cn/article/43829.html

詳解Nginx 虛擬主機配置的三種方式(基于域名) http://www.ythuaji.com.cn/article/43830.html

1、基于IP的虛擬主機配置

如果同一臺服務器有多個IP,可以使用基于IP的虛機主機配置,將不同的服務綁定在不同的IP上。

1.1 假設服務器有個IP地址為192.168.2.150,首先使用ifconfig在同一個網絡接口上綁定其他3個IP。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
[root@localhost ~]# ifconfig ens33:1 192.168.2.151/24 up
[root@localhost ~]# ifconfig ens33:2 192.168.2.152/24 up
[root@localhost ~]# ifconfig ens33:3 192.168.2.153/24 up
[root@localhost ~]# ifconfig
ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
 inet 192.168.2.106 netmask 255.255.255.0 broadcast 192.168.2.255
 inet6 fe80::2a8d:be6:a4a8:ea0 prefixlen 64 scopeid 0x20<link>
 ether 00:0c:29:16:90:ae txqueuelen 1000 (Ethernet)
 RX packets 1220 bytes 87955 (85.8 KiB)
 RX errors 0 dropped 0 overruns 0 frame 0
 TX packets 206 bytes 23755 (23.1 KiB)
 TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
 
ens33:1: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
 inet 192.168.2.151 netmask 255.255.255.0 broadcast 192.168.2.255
 ether 00:0c:29:16:90:ae txqueuelen 1000 (Ethernet)
 
ens33:2: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
 inet 192.168.2.152 netmask 255.255.255.0 broadcast 192.168.2.255
 ether 00:0c:29:16:90:ae txqueuelen 1000 (Ethernet)
 
ens33:3: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
 inet 192.168.2.153 netmask 255.255.255.0 broadcast 192.168.2.255
 ether 00:0c:29:16:90:ae txqueuelen 1000 (Ethernet)
 
lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536
 inet 127.0.0.1 netmask 255.0.0.0
 inet6 ::1 prefixlen 128 scopeid 0x10<host>
 loop txqueuelen 1 (Local Loopback)
 RX packets 72 bytes 6252 (6.1 KiB)
 RX errors 0 dropped 0 overruns 0 frame 0
 TX packets 72 bytes 6252 (6.1 KiB)
 TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0

1.2 3個IP對應的域名如下,配置主機的host文件便于測試

?
1
2
3
4
5
6
7
[root@localhost ~]# vim /etc/hosts
[root@localhost ~]# cat /etc/hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1  localhost localhost.localdomain localhost6 localhost6.localdomain6
192.168.2.151 www.test151.com
192.168.2.152 www.test152.com
192.168.2.153 www.test153.com

可以模擬實現DNS輪詢的情況。

附:設置完hosts文件后一定要記得執行以下命令使其生效

1、windows下cmd進入命令行

?
1
2
3
4
5
C:\Users\1234>ipconfig /flushdns
 
Windows IP 配置
 
已成功刷新 DNS 解析緩存。

1.3 建立虛擬主機存放網頁的根目錄,并創建首頁文件index.html

?
1
2
3
4
5
6
7
8
9
10
[root@localhost /]# mkdir -p /data/www
[root@localhost /]# cd /data/www
[root@localhost www]# mkdir 151
[root@localhost www]# mkdir 152
[root@localhost www]# mkdir 153
[root@localhost www]# echo "192.168.2.151" > 151/index.html
[root@localhost www]# echo "192.168.2.152" > 152/index.html
[root@localhost www]# echo "192.168.2.153" > 153/index.html
[root@localhost www]# ls
151 152 153

1.4 修改nginx.conf,將虛擬主機配置文件包含進主文件

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

在nginx.conf文件末尾加入以下配置

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

1.5 編輯每個IP的配置文件(每個虛擬主機的配置文件)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
[root@localhost conf]# mkdir -p vhost
[root@localhost conf]# cd vhost/
[root@localhost vhost]# cat www.test151.conf
 server {
 listen 192.168.2.151:80;
 # 配置成實際的域名,每個虛擬主機的配置文件域名都相同
 #server_name www.test.com;
 
 access_log /data/logs/www.test151.com.log main;
 error_log /data/logs/www.test151.com.error.log;
 
 location / {
  root /data/www/151;
  index index.html index.htm;
 }
 }
 
[root@localhost vhost]# cat www.test152.conf
 server {
 listen 192.168.2.152:80;
 # 配置成實際的域名,每個虛擬主機的配置文件域名都相同
 #server_name www.test.com;
 
 access_log /data/logs/www.test152.com.log main;
 error_log /data/logs/www.test152.com.error.log;
 
 location / {
  root /data/www/152;
  index index.html index.htm;
 }
 }
 
[root@localhost vhost]# cat www.test153.conf
 server {
 listen 192.168.2.153:80;
 # 配置成實際的域名,每個虛擬主機的配置文件域名都相同
 #server_name www.test.com;
 
 access_log /data/logs/www.test153.com.log main;
 error_log /data/logs/www.test153.com.error.log;
 
 location / {
  root /data/www/153;
  index index.html index.htm;
 }
 }

1.6 創建日志文件,否則無法啟動nginx

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

1.7 先測試配置文件然后再啟動nginx

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

1.8 測試文件

?
1
2
3
4
5
6
[root@localhost sbin]# curl www.test151.com
192.168.2.151
[root@localhost sbin]# curl www.test152.com
192.168.2.152
[root@localhost sbin]# curl www.test153.com
192.168.2.153

附:配置過程中出現的問題

1、測試配置文件時出現的問題

?
1
2
3
[root@localhost sbin]# ./nginx -t
nginx: [emerg] unexpected "}" in /usr/local/nginx/conf/nginx.conf:122
nginx: configuration file /usr/local/nginx/conf/nginx.conf test failed

解決方法:下面語句忘記加分號

?
1
include vhost/*.conf;

2、使用 curl www.test*.com 測試時總是訪問到相同的結果

解決方法:不要將IP地址寫在 server_name 后面, server_name 后面只能添加域名。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/liupeifeng3514/article/details/79006998

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 免费观看无遮挡www的小视频 | 91欧洲在线视精品在亚洲 | 亚洲色图影院 | 亚洲精品有码在线观看 | 欧美精品一区二区在线观看播放 | 成年美女黄网站色视频大全免费 | 亚洲性综合网 | 青春草在线观看视频 | 国产在线视频一区二区三区 | 9热在线精品视频观看 | 3d欧美人禽交 | 亚洲欧美日韩成人一区在线 | 美女岳肉太深了使劲 | 亚洲一区二区精品推荐 | 爱情岛论坛亚洲永久入口口 | 91精品啪在线观看国产91九色 | 91精品国产亚一区二区三区 | 香蕉免费一区二区三区 | 97自拍视频在线观看 | 女女同性做爰xxoo亲吻 | 精品视频在线播放 | 日韩一级在线观看 | 1313午夜精品理伦片 | 91传媒在线观看 | 涩涩屋在线观看 | 二区三区在线观看 | 亚洲波多野结衣日韩在线 | 欧美日韩久久中文字幕 | 艾秋麻豆果冻剧传媒在线播放 | 久久er国产免费精品 | 成人伊人亚洲人综合网站222 | 久久电影院久久国产 | 美女69xx | 亚洲精品国产成人 | 欧美视频一区二区三区四区 | 午夜在线观看视频 | 四虎b7s22c0m | 日韩无砖专区体验区 | 人人做人人爽人人爱 | 国产一区二区三区福利 | 欧美一区二区三区成人看不卡 |