zoukankan      html  css  js  c++  java
  • HTTP 04 web 服务器

    用单台虚拟主机实现多个域名

    HTTP/1.1 允许一台 HTTP 服务器搭建多个 web 站点, 例如提供 web 托管服务的供应商, 可以用一台服务器为多位客户服务, 也可以以每位客户持有的域名运行各自不同的网站. 这是利用了虚拟主机的功能.

    即使物理层面只有一台服务器, 但只要使用虚拟主机的功能, 则可以假想已具备多台服务器.

    客户端使用 HTTP 协议访问服务器时, 会经常采用类似 www.hackr.jp 这样的主机名和域名.

    在互联网上, 域名通过 DNS 服务映射到 IP地址(地址解析)之后访问目标网站, 可见, 当请求发送到服务器时, 已经是以 IP 地址形式访问了. 所以, 当一台服务器内托管了 www.tricoder.jp 和 www.hackr.jp 两个域名, 当收到请求时就需要弄清楚究竟要访问哪个域名.

    通信数据转发程序: 代理, 网关, 隧道

    HTTP通信时, 除客户端和服务器以外, 还有一些用户通信数据转发的应用程序, 例如 代理, 网关和隧道.

    这些应用程序和服务器可以将请求转发给通信线路上的下一站服务器, 并且能够接收从那台服务器发送的响应再转发给客户端.

    代理: 是一种有转发功能的应用程序, 它扮演了位于服务器和客户端之间的中间人的角色.

    使用代理服务器的理由: 利用缓存技术减少网络带宽的流量, 组织内部针对特定网站的访问控制, 获取访问日志 等.

    代理基本上分为两类: 缓存代理, 透明/非透明 代理

    缓存代理: 代理转发响应时, 会预先将资源的副本(缓存) 保存在代理服务器上. 当代理再次接收到对相同资源的请求时, 就可以不从源服务器那里获取资源, 而是将之前缓存的资源作为响应返回.

    透明代理: 转发请求或响应时, 不对报文做任何加工的代理类型被称为透明代理, 反之, 被称为 非透明代理

    网关:是转发其他服务器通信数据的服务器, 接收从客户端发送过来的请求时, 它就像自己拥有资源服务器一样对请求进行处理, 有时客户端可能都不会察觉, 自己的通信目标是一个网关.

    网关的工作和代理十分类似, 而网关能使通信线路上的服务器提供非 HTTP 协议服务.

    隧道: 中转.加密, 隧道的目的是确保客户端和服务器进行安全的通信.

    隧道本身不去解析 HTTP 请求, 隧道会在通信双方断开连接时结束.

    保存资源的缓存

    缓存是指代理服务器和客户端本地磁盘内保存的资源副本, 利用缓存可减少对源服务器的访问, 缓存服务器是代理服务器的一种, 并归类在缓存代理类型中. 

    缓存有效期, 即使存在缓存, 也会因为客户端的要求, 缓存的有效期等因素, 向源服务器确认资源的有效性. 若判断缓存失效, 缓存服务器将会再次从源服务器上获取"新"资源.

    注意 这里的缓存, 不是 Cookie, 不是一回事.

  • 相关阅读:
    Python+SparkStreaming+kafka+写入本地文件案例(可执行)
    Python安装pycurl失败,及解决办法
    Linux screen用法简介
    [算法]数组中求出下标不连续的任意个数,使得和最大
    消息队列小结
    [算法]计算全排列组合数
    [数据结构]A*寻路算法
    [数据结构]最大流之Ford-Fulkerson算法
    [数据结构]最小生成树算法Prim和Kruskal算法
    [数据结构]迪杰斯特拉(Dijkstra)算法
  • 原文地址:https://www.cnblogs.com/moveofgod/p/7667582.html
Copyright © 2011-2022 走看看