前言
关于Nginx虚拟主机的配置,可以分为以下三种方式:
- 基于域名的虚拟主机,通过域名来区分虚拟主机(主要应用外部网站)
- 基于端口的虚拟主机,通过端口来区分虚拟主机(主要应用于公司内部网站,外部网站的管理后台)
基于ip的虚拟主机,几乎不用
下面主要针对于前两种方式来讲解。
本文目录结构:
l____1.基于域名配置虚拟主主机
l_______1.1 环境准备
l_______1.2 html目录创建
l_______1.3 配置虚拟主机
l_______1.4 重启Nginx并测试
l____2.基于端口配置虚拟主机
l_______2.1 需求
l_______2.2 准备环境
l_______2.3 配置虚拟主机
l_______2.4 测试
l____总结
1.基于域名配置虚拟主机
现在有个需求: 两个域名指向同一台nginx服务器,用户访问不同的域名显示不同的网页内容,下面来讲解nginx如何基于域名配置虚拟主机的:
两个域名是:aaa.test.com 和 bbb.test.com
nginx服务器使用虚拟机192.168.25.128
1.1 环境准备
通过host文件指定aaa.test.com和bbb.test.com对应192.168.25.128
虚拟机,修改window的hosts文件(C:\Windows\System32\drivers\etc),在最后加上:
<span style="color:#000000"><code>192.168.25.128 aaa.test.com
192.168.25.128 bbb.test.com
</code></span>
1.2 html目录创建
1.在192.168.25.128
上创建/usr/local/aaa_html,此目录为 aaa.test.com 域名访问的目录
2.在192.168.25.128
上创建/usr/local/bbb_html,此目录为 bbb.test.com 域名访问的目录
3.目录中的内容使用nginx自带的html文件,将/usr/local/nginx/html
中的内容拷贝分别拷贝到上边两个目录中
<span style="color:#000000"><code>cp /usr/local/nginx/html/index.html /usr/local/aaa_html/
cp /usr/local/nginx/html/index.html /usr/local/bbb_html/
</code></span>
4.将aaa_html
目录中的index.html内容为:“Welcome to aaa nginx!”
<span style="color:#000000"><code> vi index.html
</code></span>
5.步骤同上,将bbb_html
目录中的index.html内容改为“Welcome to bbb nginx!”
1.3 配置虚拟主机
修改/usr/local/nginx/conf/nginx.conf
文件,添加两个虚拟主机,如下:
<span style="color:#000000"><code>#配置虚拟主机aaa.test.com
server {
#监听的ip和端口,配置本机ip和端口
listen 192.168.25.128:80;
#虚拟主机名称是aaa.test.com,请求域名aaa.test.com的url将由此server配置解析
server_name aaa.test.com;
#所有的请求都以/开始,所有的请求都可以匹配此location
location / {
#使用root指令指定虚拟主机目录即网页存放目录
#比如访问http://ip/test.html将找到/usr/local/aaa_html/test.html
#比如访问http://ip/item/test.html将找到/usr/local/aaa_html/item/test.html
root /usr/local/aaa_html;
#指定欢迎页面,按从左到右顺序查找
index index.html index.htm;
}
}
#配置虚拟主机bbb.test.com
server {
listen 192.168.25.128:80;
server_name bbb.test.com;
location / {
root /usr/local/bbb_html;
index index.html index.htm;
}
}
</code></span>
1.4 重启Nginx并测试
重启:
<span style="color:#000000"><code>./nginx -s quit
./nginx
</code></span>
访问 aaa.test.com、bbb.test.com
配置成功!!!
2.基于端口配置虚拟主机
2.1 需求
nginx对外提供80和8080两个端口监听服务。
请求80端口则请求html80目录下的html
请求8080端口则请求html8080目录下的html
2.2 准备环境
将原来nginx的html目录拷贝两个目录 “html80”和“html8080”,为了方便测试需要修改每个目录下的index.html内容使之个性化。
2.3 配置虚拟主机
修改/usr/local/nginx/conf/nginx.conf
文件,添加两个虚拟主机,如下:
<span style="color:#000000"><code>#user nobody;
worker_processes 1;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
#配置虚拟主机
server {
#监听的ip和端口,配置80
listen 80;
#虚拟主机名称这里配置ip地址
server_name 192.168.101.3;
#所有的请求都以/开始,所有的请求都可以匹配此location
location / {
#使用root指令指定虚拟主机目录即网页存放目录
#比如访问http://ip/test.html将找到/usr/local/html3/test.html
#比如访问http://ip/item/test.html将找到/usr/local/html3/item/test.html
root /usr/local/nginx/html80;
#指定欢迎页面,按从左到右顺序查找
index index.html index.htm;
}
}
#配置虚拟主机
server {
listen 8080;
server_name 192.168.101.3;
location / {
root /usr/local/nginx/html8080;
index index.html index.htm;
}
}
}
</code></span>
2.4 测试
启动 nginx,查看端口监听状态:
访问http://192.168.101.3
访问http://192.168.101.3:8080