原文链接:https://www.cnblogs.com/Erick-L/p/7066564.html
有时候你想在一台服务器上为不同的域名运行不同的站点。比如www.siteA.com作为博客,www.siteB.com作为论坛。你可以把两个域名的IP都解析到你的服务器上,但是没法在Nginx的根目录里同时运行两个不同的网站。这时候,你就需要使用虚拟目录了。假设你把博客放在”/home/user/www/blog”下,论坛放在”/home/user/www/forum”下。下面我们就开始配置了:
$ sudo mkdir /etc/Nginx/vhost
- 创建siteA的配置文件
$ sudo vi /etc/Nginx/vhost/vhost_siteA.conf
- 输入以下配置信息
server { listen 80; # 监听端口 server_name www.siteA.com siteA.com; # 站点域名 root /home/user/www/blog; # 站点根目录 index index.html index.htm index.PHP; # 默认导航页 location / { # wordpress固定链接URL重写 if (!-e $request_filename) { rewrite (.*) /index.PHP; } } # PHP配置 location ~ \.PHP$ { fastcgi_pass unix:/var/run/PHP5-fpm.sock; fastcgi_index index.PHP; include fastcgi_params; } }
- 同siteA一样创建siteB的配置文件,两者仅有的不同是”server_name”和”root”目录
$ sudo vi /etc/Nginx/vhost/vhost_siteB.conf
server { ... server_name www.siteB.com siteB.com; # 站点域名 root /home/user/www/forum; # 站点根目录 ... }
sudo vi /etc/Nginx/Nginx.conf
- 将虚拟目录的配置文件加入到”http {}”部分的末尾
http { ... include /etc/Nginx/vhost/*.conf; }
- 重启Nginx服务
$ sudo service Nginx restart
- 现在访问www.siteA.com和www.siteB.com,你将发现浏览器会打开不同的站点
禁止访问小技巧
假如你的Nginx根目录设在”/home/user/www”,你想阻止别人通过”http://IP地址/blog”或”http://IP地址/forum”来访问你的站点,最简单的方法就是禁止IP地址访问。方法如下:
$ sudo cp /etc/Nginx/sites-available/default /etc/Nginx/sites-available/default_bak $ sudo vi /etc/Nginx/sites-available/default
server { listen 80 default_server; server_name _; return 404; }
- 重启Nginx后,别人将无法通过IP地址访问网站了
如果你不想禁止IP地址访问整个目录,只是要防止别人通过IP访问你的博客和论坛。那就需要禁止”/blog”和”/forum”的目录访问。
- 在”server { }”部分加上以下配置
location ^~ /blog/ { deny all; } location ^~ /forum/ { deny all; }
- 重启Nginx即可
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。