HTTP:Hypertext Transfer Protocol;

HTML:Hypertext Markup Language;

URL:Uniform Resource Locator,在Internet的WWW服务程序上用于指定信息位置的表示方法;

  Scheme://Server:Port/path/to/resource;

  http://www.mageedu.com/images/logo.jpg;

一次完整的http请求过程:

  建立或处理连接 --> 接受请求 --> 处理请求 --> 访问资源 --> 构建响应报文 --> 发送响应报文 --> 记录日志;

http服务器程序:

  httpd(apache);nginx;lighttpd;

http监听端口:80/tcp,https监听端口:443/tcp;

centos6支持安装httpd-2.2,centos7支持安装httpd-2.4;

特别配置:

  1、持久连接

    连接建立,每个资源获取完成后不会断开连接,而是等待其他请求,访问量较大的服务器,持久连接功能会使有些请求得不到响应;

    折中方法,使用较短的毫秒级持久时间:

      KeepAlive On|Off

      MaxKeepAliveRequests #

      KeepAliveTimeout #

  2、站点访问控制

    可基于两种类型的路径指明对哪些资源进行访问控制:

      文件系统路径:

        <Directory " ">

        </Directory>

      URL路径:

        <Location " ">

        </Location>

  3、日志设定

    错误日志:

      ErrorLog logs/error_log

      LogLevel warn(记录warn以上级别的日志)

    访问日志:

      CustomLog logs/access_log combined

      LogFormat ...

  4、基于用户访问控制

    基于用户认证:

      <Directory "/var/www/html/SOME"> //要登录进入的目录

        Options None

        AllowOverride None

        Auth Type Basic

        AuthName "STRING"  //认证提示符

        AuthUserFile "/PATH/TO/HTTPD_USER"  //账号密码存放的目录

        Require user username1 username2...

        Require voild-user  //允许文件中所有用户

      </Directory>

      设置账号密码存储:htpasswd命令

        htpasswd -bm /etc/httpd/conf.d/.htuser username userpasswd

    基于组认证:

      <Directory "/var/www/html/admin"> 

        Options None

        AllowOverride None

        AuthType Basic

        AuthName "administrator private"

        AuthUserFile "/etc/httpd/conf.d/.htpasswd"

        AuthGroupFile "/etc/httpd/conf.d/.htgroup"

        Require group webadmin

      </Directory>

      组文件中:每行定义一个组

        webadmin:user1 user2 ...

  5、虚拟主机

    基于IP:

      为每个虚拟主机准备至少一个ip地址;

    基于port:

      为每个虚拟主机准备至少一个专用port,实践中很少使用;

    基于hostname:

      注意:一般虚拟主机莫与中心主机混用,所以要是用虚拟主机,先禁用中心主机,注释DocumentRoot;

    每个虚拟主机都专用配置:

    <VirtualHost *:80>

      ServerAdmin webmaster@dummy-host.example.com

      DocumentRoot /www/docs/dummy-host.example.com

      ServerName dummy-host.example.com

      ErrorLog logs/dummy-host.example.com-error_log

      CustomLog logs/dummy-host.example.com-access_log common

    </VirtualHost>

  status:状态码,标记请求过程中发生的情况;

    100-101:信息提示;

    200-206:成功;

    300-305:重定向;

    400-415:客户端错误;

    500-505:服务器端错误;

      200:成功;OK

      301:请求的URL指向的资源已经被删除,但响应报文中通过首部Location指明了资源现在所处的新位置,Moved Permanently;

      302:与301相似,但在响应报文中指明临时新位置;Found

      304:客户端发出条件式请求,但服务器上的资源未曾发生改变;Not Modified

      401:需要输入账号密码认证;Unauthorized

      403:请求被禁止;Forbidden

      404:服务器无法找到客户端请求的资源;Not Found

      500:服务器内部错误;Internal Server Error

      502:代理服务器从后端服务器收到一条伪响应;Bad Getway

httpd配置的更多相关文章

  1. centos7 httpd配置

    centos7 httpd配置 标签(空格分隔): 未分类 隐藏server信息 修改httpd.conf 设置,添加如下两行 ServerSignature Off ServerTokens Pro ...

  2. httpd配置.md

    httpd-2.2 配置 监听端口和IP 配置文件: Listen [IP:]PORT 省略IP表示为0.0.0.0 Listen指令可重复出现多次 修改监听socket,重启服务进程方可生效 可以监 ...

  3. 负载均衡之Haproxy配置详解(及httpd配置)

    下图描述了使用keepalived+Haproxy主从配置来达到能够针对前段流量进行负载均衡到多台后端web1.web2.web3.img1.img2.但是由于haproxy会存在单点故障问题,因此使 ...

  4. httpd配置Gzip压缩

    以下设置在 /etc/httpd/conf/httpd.conf 文件末尾加入即可.(不同方式安装的httpd可能主配置文件位置不同,请自行查找) 一.mod_deflate模块:文件压缩 官方文档: ...

  5. httpd配置ResponseHeader

    今天遇到一个问题:我把项目编译后的静态文件发布到开发机上,开发机使用httpd启的静态文件服务,页面的访问是在特制的壳浏览器里面,我更新了代码后,发现页面被缓存了,找到壳的RD联调了一下,发现我的主页 ...

  6. 利用httpd配置虚拟目录创建下载站点

    应用环境:通常放置一些文件来提供下载. 配置环境:centos7 //已经关闭Selinux和Firewall 需求假设:在网页输入主机IP并进入,会显示主机目录/home/share/的文件以提供下 ...

  7. Centos6.8上httpd配置腾讯云SSL证书

    (1)先按装mod_ssl yum -y install mod_ssl /etc/httpd/conf.d/下会有一个ssl.conf的文件,打开 a)检测本地证书配置是否正确 主要是看下证书及密钥 ...

  8. CentOS 使用httpd 配置局域网 yum源

    1.上传centos iso而且挂载 mkdir /mnt/cdr/iso mount -o /xxx.iso /mnt/cdr 2.使用createrepo来创建repo文件 cd /mnt/cdr ...

  9. Linux使用httpd配置反代理

    Linux安装httpd请看上一篇:https://www.cnblogs.com/tuituji27/p/11189095.html 首先,httpd默认监听端口号是80,增加或修改代理的端口号的文 ...

随机推荐

  1. 开发工程中遇到的BUG

    Xcode7自带Git创建的项目"Couldn’t communicate with a helper application" git xcode7 zhunjiee 2015年 ...

  2. E: 无法打开锁文件 /var/lib/dpkg/lock-frontend - open (13: 权限不够)E: 无法获取 dpkg 前端锁 (/var/lib/dpkg/lock-frontend),请查看您是否正以 root 用户运行?

    一.解决方案 修改root密码,以root身份安装 sudo pwdroot root  # 输入新密码即可

  3. linux下编译upx ucl

    昨天,UPX发布了3.93版本. UPX(the Ultimate Packer for eXecutables)是一个非常全面的可执行文件压缩软件,支持dos/exe.dos/com.dos/sys ...

  4. ubuntu使用squid搭建代理

    安装squid //检查是否安装squid which squid // apt update sudo apt install squid 配置squid的配置文件squid.conf //备份sq ...

  5. Oracle如何扩展表空间

    一: --查看表空间的名字及文件所在位置 select tablespace_name, file_id, file_name, ), ) total_space from sys.dba_data_ ...

  6. 【翻译】asp.net core2.1认证和授权解密

    asp.net core2.1认证和授权解密 本篇文章翻译自:https://digitalmccullough.com/posts/aspnetcore-auth-system-demystifie ...

  7. scp复制文件到远程服务器上

    scp -P 22 -r 2028792_www  root@120.79.172.45:/usr/local/src Linux scp命令用于Linux之间复制文件和目录. scp是 secure ...

  8. [转帖]批处理-For详解

    批处理-For详解 https://www.cnblogs.com/DswCnblog/p/5435300.html for 循环的写法 感觉非常好. 今天下午的时候简单测试了下. 多学习提高 非常重 ...

  9. Oracle创建'数据库'三步走

    --创建表空间 create tablespace waterboss datafile 'd:\waterboss.dbf' size 100m autoextend on next 10m; -- ...

  10. 剑指offer(7)

    今天的几道题目都是关于斐波那契数列的. 题目1: 大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项(从0开始,第0项为0). n<=39 传统的方法采用递归函数,这种 ...