关于vhost

  个人理解为vhost是一种可以在一个ip下同时部署多个不同域名站点的的概念。

  其好处就是对一些小型的网站不必每个网站都占用一个ip,或者说一个服务,举个例子,vhost的概念就相当于打开一个浏览器,里面有多个窗口,每个窗口就是一个站点,而不是说打开多个浏览器,一个浏览器只开一个窗口。

  之所以可以这么做,主要因为以下2方面:

    1、访问一个域名时,客户端不仅通过dns找到对应的ip,还会把域名也发送过去。

    2、中间件的存在,使得每个请求可以被预处理,从而可以通过域名获取客户端访问的站点。

关于中间件

  在这里可以这么理解,中间件就是一系列的过滤器,当服务器接收每一个到请求时,会先通过中间价做一些处理,再到真正的请求响应程序,在预处理的过程中的改动都会存在request中。

基于nodejs的代码实现

需要安装2个模块

npm install express -g
npm install vhost -g

简单代码,文件名为Evhost.js

var ex = require('express')
var vhost = require('vhost') var app = ex() function handler(req, res, next) {
console.log(req.vhost);
res.send('your request site: ' + req.vhost.hostname)
} var domain_sn = vhost('sn.cn', handler) var domain_vra = vhost('vra.cn', handler) app.use(domain_sn)//使用中间件
app.use(domain_vra) app.listen(80,function(err){
if (err)
throw err
console.log('服务启动,监听端口:80');
})

运行该程序

node Evhost.js

关于express:www.expressjs.com.cn/

关于vhost:https://github.com/expressjs/vhost

vhost关键代码解析,整个vhost的模块代码其实很简单

/**
* Create a vhost middleware.
*
* @param {string|RegExp} hostname
* @param {function} handle
* @return {Function}
* @api public
*/ module.exports = function vhost(hostname, handle) {
if (!hostname) {
throw new TypeError('argument hostname is required')
} if (!handle) {
throw new TypeError('argument handle is required')
} if (typeof handle !== 'function') {
throw new TypeError('argument handle must be a function')
} // create regular expression for hostname
var regexp = hostregexp(hostname) return function vhost(req, res, next) {//返回一个函数,作为中间件
var vhostdata = vhostof(req, regexp)//通过正则表达式判断域名是否是这个host处理
if (!vhostdata) {//不是则调到下一个中间件
return next()
} // populate
req.vhost = vhostdata//将域名信息存到request的vhost变量汇中 // handle
handle(req, res, next)//执行这个host绑定的处理程序
};
};

通过输入域名进行访问

因为需要获取域名信息,所以不可以通过输入ip直接进行访问,由于80端口是默认的http端口,所有不需要在后面再加上端口号。

如果该端口被占用则必须先关闭占用该端口的程序:http://jingyan.baidu.com/article/37bce2be10a5c21002f3a2cf.html

在访问之前还需要配置系统的vhost:http://www.cnblogs.com/sesna/p/host_troubleshot.html

  

最新文章

  1. zabbix3.x web设置手册(2)
  2. PHP 函数(2)
  3. Android Studio导入Eclipse项目和一些常见的问题
  4. ES6-Symbol
  5. hdu 2680 Choose the best route
  6. OpenGl从零开始之坐标变换(下)
  7. WPF多语言化的实现
  8. Palindrome Partitioning II
  9. Understanding GC pauses in JVM, HotSpot's minor GC.
  10. hdu 1402 A * B Problem Plus FFT
  11. PHP - 子类使用父类的构造函数
  12. 10分钟学会ES7+ES8
  13. Java-单例模式详解(图文并茂,简单易懂)
  14. 新概念英语(1-25)Mrs. Smith's Kitchen
  15. mysql 千万级数据查询效率实践,分析 mysql查询优化实践--本文只做了一部分,仅供参考
  16. IIS做反向代理重定向到NodeJS服务器
  17. BZOJ4377 Kurs szybkiego czytania \ Luogu 3589[POI2015]KUR - 数学思维题
  18. 全排列问题(c语言实现)
  19. 怎么在jquery里清空文本框的内容
  20. jboos下载地址记录

热门文章

  1. NDK下vfork+execl启动程序
  2. 爪哇国新游记之二----用于计算三角形面积的Point类和TAngle类
  3. GET RESTful With Python
  4. 七个你无法忽视的Git使用技巧
  5. eslint for...in 报错处理
  6. 从cocos2dx到cocos2dhtml5的不同之处
  7. oracle将一个表中字段的值赋值到另一个表中字段(批量)
  8. 转:maven3常用POM属性及Settings属性介绍
  9. c#封装DBHelper类 c# 图片加水印 (摘)C#生成随机数的三种方法 使用LINQ、Lambda 表达式 、委托快速比较两个集合,找出需要新增、修改、删除的对象 c# 制作正方形图片 JavaScript 事件循环及异步原理(完全指北)
  10. $("#SpecialAptitude").on("change",function(){CheckType($(this))})$("#SpecialAptitude").on("change",CheckType($(this)))