web基础之http

day46 http原理

之前的web.yaml 增加内容

[root@m01 ansible_playbook]# cat web.yaml
- hosts: web
  tasks:

    - name: Mount NFS Server Share Date
      mount: src=172.16.1.31:/data path=/data fstype=nfs opts=defaults state=mounted

    - name: Install Httpd Php
      yum: name=httpd,php state=installed

    - name: Configurl copy
      copy: src=./conf/httpd.conf dest=/etc/httpd/conf/httpd.conf
      notify: Restart Httpd

    - name: Unzip kaoshi.zip
      unarchive: src=./file/kaoshi.zip dest=/data/ creates=/data/index.html

    - name: Start Httpd
      service: name=httpd state=started enabled=yes
  handlers:
    - name: Restart Httpd
      service: name=httpd state=restarted

1.Http协议介绍

HTTP全称HyperText Transfer Protocol中文名为超文本传输协议

1.http(超文本传输协议)
包含有超链接(Link)和各种多媒体元素标记的文本。这些超文本文件彼此链接,形成网状(Web),因此又被称为网页(Web Page)。这些链接使用URL表示。最常见的超文本格式是超文本标记语言HTML。

2.什么是URL

http:// www.qq.com:80 /news/index.html

协议 域名: 端口 具体的文件名下面的某个页面

4.http协议总结

1.http是一个超文本传输协议
2.http建立在应用层协议基础之上
3.http默认端口80, https默认端口443
4.一次tcp的链接,可以包含多次http的请求

Http工作原理

1.发起dns请求
2.获取到域名对应的IP地址
3.浏览器发起tcp的连接
4.基于tcp的连接,传输http的请求(一次tcp的连接,可以建立多次的http请求)
5.浏览器请求/index.html
6.服务器响应/index.html至浏览器
7.浏览器翻译index.html中的内容为人类可读
8.断开TCP的四次挥手

1.本地redirect跳转
2.检查浏览器缓存
3.DNS解析
2.tcp的三次握手
3.http客户端的请求
4.http服务端的响应
5.tcp的四次挥手

http的请求方法

get     # 获得请求文件信息的数据内容(获取)
post    # 用户提交数据至服务器端存储(提交)

Request URL:http://10.0.0.7/index.html # 请求的URL
Request Method:GET                     # 请求的方法
Status Code:200 OK                     # 当前的状态
Remote Address:10.0.0.7:80             # 远程的主机
注意: 当发起`http`请求文件时, 没有指定请求的文件内容,默认请求的首页文件`index.html`

http请求报文采用的协议版本

1.0: http的短连接:建立一次tcp的连接,发起一次http的请求,结束,tcp断开。
1.1: http的长连接:建立一次tcp的连接,发起多次http的请求,结束,tcp端口。

http的响应响应状态码

状态码的类别

1xx Informational(信息性状态码) 请求成功接受, 正在处理中.
2xx Successful(成功状态码) 请求正常处理完毕.
3xx Redirection(重定向状态码) 需要附加的操作以完成请求.
4xx Client Error(客户端错误状态码) 请求的语法等不正确, 服务器端无法处理.
5xx Server Error(服务器内部错误) 请求语法应该正确, 但是服务器内部出现了某种错误.

常用HTTP状态码简要介绍

200 OK 请求被正常处理
204 No Content 请求被正常处理, 但不返回实体部分
206 Partial Content 返回指定范围的实体内容
301 Moved Permanently 永久性重定向(redirect)
302 Found 临时性重定向(redirect)
304 Not Modified 资源未修改, 直接使用缓存
307 Temporary Redirect 临时性重定向
308 Permanent Redirect 永久性重定向
400 Bad Request 请求报文中存在语法错误
403 Forbidden 请求被服务器拒绝
404 Not Found 服务器上找不到请求的资源
408 Request Timeout 请求超时
500 Internal Server Error 服务器内部错误
503 Service Unavailable 服务器暂时无法提供服务
502 Bad Gateway 找不到后端的资源

用户访问网站携带的参数,以及服务端返回的参数 (http请求报文 http响应报文)

1.概况
    Request URL: http://10.0.0.7/index.html         # 请求的URL地址
    Request Method: GET                             # 请求的方法(获取)
    Status Code: 304 Not Modified                   # 返回的状态
    Remote Address: 10.0.0.7:80                     # 请求的地址

2.客户端请求的头部信息
Accept: text/html,                                  # 请求的类型
Accept-Encoding: gzip, deflate                      # 是否进行压缩
Accept-Language: zh-CN,zh;q=0.9                     # 请求的语言
Cache-Control: max-age=0                            # 缓存
Connection: keep-alive                              # TCP长连接
Host: www.oldboyedu.com                             # 请求的域名
If-Modified-Since: Fri, 04 May 2018 08:13:44 GMT    # 修改的时间
If-None-Match: "a49-56b5ce607fe00"                  # 标记
Upgrade-Insecure-Requests:1                         # 在http和https之间起的一个过渡作用
User-Agent: Mozilla/5.0                             # 用户的浏览器
===========请求一个空行=========================


3.服务端响应的头部信息
HTTP/1.1 304 Not Modified                           # 返回服务器的http协议,状态码
Date: Fri, 14 Sep 2018 09:14:28 GMT                 # 返回服务器的时间
Server: Apache/2.4.6 (CentOS) PHP/5.4.16            # 返回服务器使用的软件(Apache php)
Connection: Keep-Alive                              # TCP长连接
Keep-Alive: timeout=5, max=100                      # 长连接的超时时间
ETag: "a49-56b5ce607fe00"                           # 验证客户端标记
===========返回一个空行=========================
===========返回内容页面=========================

http相关术语

pv、ip、uv
PV:页面浏览量
uv:独立的客户
ip:独立IP

我们公司有一座大厦,大厦有100人,每个人有一台电脑一个手机,上网都是通过nat转换出口,每个人点击网站2次。
    PV:400
    UV:200
    IP:1个

用户访问网站的流程

1.客户端输入域名以及请求的页面
2.本地会进行一次redirect跳转
3.解析域名对应的dns
4.最终客户端浏览器获取到dns的IP地址
5.客户端会与服务端发起TCP的三次握手(长连接)
6.客户端发起http请求,请求会先抵达前端的防火墙
7.防火墙识别用户身份,正常的请求通过内部交换机通过tcp连接后端的负载均衡,然后传递用户的http请求
8.负载接收到请求,会根据请求的内容进行下发任务,通过tcp连接后端的web,然后下发用户的http请求
9.web接收到用户的http请求后,会根据用户请求的内容进行解析,解析分为如下两步:
    静态请求:由web服务器向nfs建立tcp连接,获取对应的图片,最后返回给负载均衡(负载均衡->防火墙->用户)
    动态请求:有web向后端的动态程序建立TCP连接,将用户的动态http请求传递给动态程序->由动态程序进行解析 
10.动态程序在解析的过程中,如果碰到查询数据库的请求,则优先和缓存建立tcp的连接,然后缓存服务发起http的查询
11.如果缓存没有对应的数据,动态程序再次向数据库建立tcp的连接,然后发起查询操作。
12.由数据库返回->动态程序->缓存->web服务->负载均衡->防火墙->用户。
博主QQ 343264992 QQ群交流:100411237 添加时候请备注博客园
原文地址:https://www.cnblogs.com/chengkanghua/p/9649901.html