http协议
--------------------------------------------------
实验:
Yum install httpd php php-mysql mariadb-server //安装相关文件
启动httpd以及mariadb服务,并关闭防火墙以及selinux;
Systemctl start httpd
Systemctl start mariadb
Iptables -F
Systemctl stop firewalld
Seteforce 0
测试是否安装成功
Vim /var/www/html/index.php
<?php
Phpinfo();
?>
访问,能够看到php的测试主页面即可
http://192.168.94.130
vim /var/www/html/index.php
<?php
$conn=mysql_connect(‘127.0.0.1’,’root’);
If ($conn)
Echo “ok”;
Else
Echo “false”;
Mysql_close();
?>
访问,能够看到php的测试数据显示ok则表示正确;
在数据库上创建用户;
Mysql
Grant all on wpdb.* to ‘wpuser’@’localhost’ identified by ‘wppasswd’;
Grant all on wpdb.* to ‘wpuser’@’127.0.0.1’ identified by ‘wppasswd’;
Create database wpdb;
Flush privileges;
Exit
查看用户是否添加成功
Mysql -uwpuser -pwppasswd
Show databases;
修改wordpress的配置文件
Unzip workpress-4.3.1-zh_CN.zip
Cp -a wordpress /var/www/html/
Cd /var/www/html/wardpress
Cp wp-config-sample.php wp-config.php
添加数据库,用户,以及密码
Vim wp-config.php
Define(‘DB_NAME’, ‘wpdb’);
Define(‘DB_USER’, ‘wpuser’);
Define(‘DB_PASSWORD’, ‘wppasswd’);
访问测试:
在流量器上访问:http://192.168.94.130/wdpress
---------------------------------------------------------------------------------------
1、套接字 (进程间通讯)
tcp/ip -- osi
应用层 --> 资源子网 (提供正真客户所需要的资源信息 -- 应用层!)
--------
传输层 --> tcp udp
网络层 --> 通讯子网 (内核提供)
主机到主机层
套接字概念:关联应用层资源与底层的网络;使得,不同主机之间能够实现应用数据的交互;
所有进程间通讯的机制,我们都叫做IPC机制(进程间通讯);套接字只是 IPC 机制中的一种而已;
常见的IPC通讯机制:
1、MQ -- 消息队列
2、socker 套接字
3、single 信号
4、共享内存
分类:
根据数据包封装的情况分类:
1、SOCK_STREAM tcp的套接字
2、SOCK_DGRAM udp的套接字
3、SOCK_RAM 裸套接字
地址簇来进行分类:
1、IPV6的套接字
2、IPV4的套接字
3、UNIX的套接字
我们也可以将套接字理解为内核的系统调用 -- system call(C语言开发相关的底层代码 -- 类似于函数):
编译型(面向过程的)的编译语言的调用 -- 函数
解释型(面向对象的)的编程语言的调用 -- 类
套接字相关的应用:
socket() 创建套接字
listen() 监听
accept() 接受请求
connect() 请求连接建立
write() 发送数据
read() 从缓存中接受数据
我们http协议,使用B/S架构(浏览器与服务器架构)就需要通过套接字的方式进行数据传输!!!
http://www.baidu.com/... -- URL
/... --> 指定资源 URI
http --> 协议
www --> 提供指定服务的主机的主机名
baidu.com --> 域名
2、http协议基础
超文本传输协议
默认情况下,http协议就是用来实现客户端与服务端的数据传输(文本);
【流浪器必须安装插件】
<html>
<head>
<title>Title</title>
</head>
<body>
<h1></h1>
<p> 内容 <a href="http://www.magedu.com/log.jpg"> 内容 </a> </p>
<h2></h2>
</body>
</html>
http默认只能传输文本文件 数据流
|
html css javascriptes //标签语言 -- 更好的规划文本格式! ,xml注入攻击
|
MIME
Multipurpose Internet Mail Extensions : 多用途互联网邮件扩展类型
用来展示图片以及视频数据;
默认情况下,在传输的过程中,依然文本流量;
MIME只用作将文本与视频及图片进行转换;
工作机制
首先会建立TCP连接,http tcp80端口;C -- > S:80
http请求
http响应
注意:请求是有很多的,(前端语言将很多的资源进行划分,而固定的服务器,只提供固定资源)
所以,有可能请求了一次,但是实际上生成了很多的进程;
http支持MPM (多处理模块)
因为http提供的访问进程数量有限,所以,我们需要启用一些访问机制,能够处理高并发流量;
MPM模块支持三种模式:
prefork -- 默认模式,队列模式
worker -- 多线程模式
event -- 多线程并发处理模式
每一个请求,我都叫一个IO;
修改MPM模式:
特性:http服务的MPM模式是在服务启动的那一刻加载进来的。
目录:/etc/sysconfig/httpd -- http -2.2
-- http -2.4
#HTTPD=/usr/sbin/httpd.worker
去掉 # 即可;
必须重新加载配置,这样才能生效;
ps aux | grep httpd //查看当前所起的进程
【注意:web服务是不能随便重启!!!】
相关的配置文件可以在 /etc/httpd/conf/httpd.conf 文件中去设置;
除了event模式没有--因为这种并不稳定,不建议使用;
请求资源
首先明白:如何识别这些资源 -- 文件后缀来识别;
静态资源 -- 图片 jpg png 、文字 .txt .doc 、视屏 avi mp4 rmvd flv
*动态资源 -- .php ... *
LAMP / LNMP / LAMMP / LNMMP -- memcache
php -- 加速器
httpd优化 -- 权限限制、MPM的访问模式、虚拟主机搭建。。。
http的版本 -- (不加密)
HTTP协议版本:
HTTP/0.9 最早的被广泛采用的版本 原型版本,不支持多媒体内容
HTTP/1.0 第一个广泛使用的版本,现在依然被使用,能支持多媒体,但是缓存机制不行
*HTTP/1.1 增强了缓存功能*当前使用的版本;
HTTP/2.0 2001年就出来了,现在基于web的应用多数使用HTTP/2.0版本(新版本),它参考了谷歌的spdy协议,所以我们有理由相信HTTP/2.0会被广泛使用
默认安装的都是2.0版本;
---------------------------------------------------------------
HTTP协议:
TCP 80 http://192.168.94.128 - URL
URL介绍
URL的完整格式:
协议类型://用户名,密码@hostname:port/URI;参数值?查询请求#标记
示例:https://www.baidu.com/s?ie=utf-8&f=8&rsv_bp=1
URL包含URI,由URI来定义所要访问资源的具体位置;
URN和URL是一个并列的东西(不做了解)
*cookie机制
cookie分类:
永久cookie -- 把cookie值存在硬盘上(这里需要指定cookie的保存时间)
临时cookie -- 把cookie值保存在内存上(重启流量器即失效)
cookie非常不安全
HTTP事务
请求 request 和相应 replay,一个请求和一个相应合起来,我们叫做一个HTTP事务;
(事务:一次完整的会话,或者工作,才能被称为一个事务;)
mysql
A ---------------------> B
1000 500
1000-300=700 ----------> 500+300=800
mysql -- 事务回滚
报文格式 -- http的请求报文 http的应答报文
http 请求报文:
首行信息: 模式 URI 版本信息
头部信息: 头部
请求主体: 实体信息
http 应答报文:
首行信息: 版本信息 状态码 原因短语
200 OK
头部信息:
应答主体:
method(模式):
GET 普通的请求
HEAD 之请求网站的头部信息
POST 推送用户名或密码的时候使用的
PUT 推送比较大的资源的时候使用的
DELETE 发起删除对应资源的命令
TARCE 容许客户端查看,被修改后的http请求报文(因为中间通过了代理服务器,而代理服务器会修改我们的请求表文)
OPTIONS 客户端去咨询服务器端所能支持模式;
还有其他很多的扩展模式 -- 例如:MOVE LOCK 等等。
version:http的版本
常见使用的版本为 1.1
status:相应状态码,例如200,301,302,404,502
100-199 表示服务器信息回应 100 101
200-299 表示成功的请求
常见的--200 ok 201 create
300-399 表示重定向
301 请求的URL指向的资源已经被删除:但在响应报文中通过首部Location指明了资源现在所处的新位置;这个是永久重定向:Moved Permently
302 与301相似,但是在响应报文中,通过Location指明了资源现在所处的临时新位置;Found
304 客户端发出了条件式请求,但是服务器发现客户端的缓存资源未曾发生改变,则通过响应状态码通知客户端:Not Modified
400-499 客户端错误状态码
401 需要输入账号和密码认证方能访问资源,Unauthorizad
403 请求被禁止:forbidden
404 服务器无法找到客户端请求的资源:Not Found
500-599 服务器端错误
500 服务器内部错误:Internal Server Error
502 代理服务器从后端服务器收到一条伪响应,Bad Gatway
reason-phrase(原因短语):状态码说明
如上