Nginx基于域名的虚拟主机
[root@localhost ~]# cat /etc/nginx/nginx.conf
worker_processes 4;#error_log logs/error.log;
worker_rlimit_nofile 102400;events {worker_connections 1024;
}http {include mime.types;default_type application/octet-stream;server {listen 80;server_name web.testpm.com;location / {root /var/www/nginx/;index index.html index.htm;limit_rate 2k;}}server {listen 80;server_name web.1000phone.com;location / {root /1000phone/html;index index.html index.htm;}}
}
[root@localhost ~]# mkdir -p /1000phone/html
[root@localhost ~]# vim /1000phone/html/index.html
<html>
<p>
this is my 1000phone
</p>
</html>
# 如果编译安装的执行
[root@nginx]# /usr/local/nginx/sbin/nginx -s reload
# 如果 yum 安装的执行
[root@nginx]# nginx -s reload
Nginx基于ip的虚拟主机
[root@localhost ~]# ip a
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN qlen 1link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00inet 127.0.0.1/8 scope host lovalid_lft forever preferred_lft foreverinet6 ::1/128 scope host valid_lft forever preferred_lft forever
2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000link/ether 00:0c:29:17:f1:af brd ff:ff:ff:ff:ff:ffinet 10.0.105.199/24 brd 10.0.105.255 scope global dynamic ens33valid_lft 81438sec preferred_lft 81438secinet6 fe80::9d26:f3f0:db9c:c9be/64 scope link valid_lft forever preferred_lft forever
[root@localhost ~]# ifconfig ens33:1 10.0.105.201/24
[root@localhost ~]# ifconfig
ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500inet 10.0.105.199 netmask 255.255.255.0 broadcast 10.0.105.255inet6 fe80::9d26:f3f0:db9c:c9be prefixlen 64 scopeid 0x20<link>ether 00:0c:29:17:f1:af txqueuelen 1000 (Ethernet)RX packets 9844 bytes 1052722 (1.0 MiB)RX errors 0 dropped 0 overruns 0 frame 0TX packets 5567 bytes 886269 (865.4 KiB)TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0ens33:1: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500inet 10.0.105.201 netmask 255.255.255.0 broadcast 10.0.105.255ether 00:0c:29:17:f1:af txqueuelen 1000 (Ethernet)2、配置通过ip区分的虚拟机
[root@localhost ~]# cat /etc/nginx/nginx.conf
user root;
worker_processes 4;#error_log logs/error.log;
worker_rlimit_nofile 102400;events {worker_connections 1024;
}http {include mime.types;default_type application/octet-stream;log_format main '$remote_addr - $remote_user [$time_local] "$request" ''$status $body_bytes_sent "$http_referer" ''"$http_user_agent" "$http_x_forwarded_for"';server {listen 10.0.105.199:80;server_name web.testpm.com;location / {root /var/www/nginx/;index index.html index.htm;limit_rate 2k;}server {listen 10.0.105.201:80;server_name web.testpm.com;location / {root /1000phone/html/;index index.html index.htm;}}
}
3、重新加载配置文件
[root@localhost ~]# /usr/local/nginx/sbin/nginx -s reload
4、 测试访问
浏览器输入:http://10.0.105.199
浏览器输入:http://10.0.105.201
5、补充
-- 删除绑定的vip
[root@localhost ~]# ifconfig ens33:1 10.0.105.201/24 down
重启一下nginx
[root@localhost ~]# systemctl restart nginx
Nginx基于端口的虚拟主机
[root@localhost ~]# cat /etc/nginx/nginx.conf
user root;
worker_processes 4;worker_rlimit_nofile 102400;events {worker_connections 1024;
}http {include mime.types;default_type application/octet-stream;log_format main '$remote_addr - $remote_user [$time_local] "$request" ''$status $body_bytes_sent "$http_referer" ''"$http_user_agent" "$http_x_forwarded_for"';sendfile on;keepalive_timeout 65;server {listen 80;server_name web.testpm.com;location / {root /var/www/nginx/;index index.html index.htm;limit_rate 2k;}server {listen 8080;server_name web.1000phone.com;location / {root /1000phone/html/;index index.html index.htm;}}
}
重新加载配置文件:
[root@localhost ~]# /usr/local/nginx/sbin/nginx -s reload
测试访问:
浏览器输入:http://web.testpm.com/
浏览器输入:http://web.1000phone.com:8080