httpd协议配置进阶

目录

  • 虚拟主机配置

  • status状态页面

  • curl命令

  • mod_deflate模块

  • https配置

  • httpd自带应用程序

虚拟主机配置

有三种实现方案:
   基于IP
       为每个虚拟主机准备至少一个IP地址
   基于端口:
       为每个虚拟主机使用至少一个独立的port
   局域FQDN:
       为每个虚拟主机使用至少一个FQDN

注意:一般虚拟主机不要与中心主机混用; 因此,要使用虚拟主机,得先禁用’main’主机 
禁用方法:注释中心主机的DocumentRoot指令即可

虚拟主机配置方法
<VirtualHost IP:PORT>    # 指明IP和端口
   ServerName FQDN     # 指明主机名
   DocumentRoot ""     # 网页文档路径
</VirtualHost>

其它可用命令:
   ServerAlias:虚拟主机的别名;可多次使用;
   ErrorLog:错误日志
   CustomLog:访问日志
   ...
基于IP的虚拟主机示例

1.创建虚拟主机配置文件

]FXYA~)N(ZZ]1IF%{`QDG8U.png

2.为每个虚拟主机提供网页文档

{_5T7[W2)[}GI(_H`NQ_085.png

3.测试

@O2A@DMR$)UI$JMQ5[39I]P.png

CHNTLQRV@RIXQI1HB1BU[{C.png

F_D2)9FJ1CR4W7`I_E0WAIC.png

基于端口的虚拟主机

1.创建虚拟主机配置文件

@KKRI)T8PXHBP1@ROUZPEEL.png

2.确认三个端口都已经监听

N(4{H0)2OCSW3F}OWVFAJVY.png

3.测试

O3$0{{KET8%Q2~1I~(43NBR.png

P27~XCHW3R2M0EHKO6@15ML.png

XJVG}NGI@`~ENH5W1O(~9$9.png

基于主机名的虚拟主机

1.创建虚拟主机配置文件

(AH5Z@DK2@5({_%SIUU04V1.png

2.在客户端hosts文件中添加主机名解析

EF}MWZ1[OR8WV{Z8B0@)T1K.png

3.测试

_H]A$(F3M2$07UY8Q7[23{K.png

B@P4ABJ$@55N])ESC]H]H$B.png

H{)%V@XYNJXH3[V{MYG_QO0.png

配置status状态页

1.确保status_module模块已加载

]Y$86ZFN}9()M7X4V~M}AAT.png

2.在配置文件中添加此项

)V8F25AO8O]Y__IUH`1~62X.png

3.测试

9Q@EZUHJDM(X4S{@S00~`~A.png

curl命令

curl是基于URL语法在命令行方式下工作的文件传输工具,它支持FTP, FTPS, HTTP, HTTPS, GOPHER, TELNET, DICT, FILE及LDAP等协议。curl支持HTTPS认证,并且支持HTTP的POST、PUT等方法, FTP上传, kerberos认证,HTTP上传,代理服务器, cookies, 用户名/密码认证, 下载文件断点续传,上载文件断点续传, http代理服务器管道( proxy tunneling), 甚至它还支持IPv6, socks5代理服务器,,通过http代理服务器上传文件到FTP服务器等等,功能十分强大。           
curl  [options]  [URL...]

curl的常用选项:
   -A/--user-agent <string> 设置用户代理发送给服务器
   --basic 使用HTTP基本认证
   -e/--referer <URL> 来源网址
   --cacert <file> CA证书 (SSL)
   --compressed 要求返回是压缩的格式
   -H/--header <line>自定义首部信息传递给服务器
   -I/--head 只显示响应报文首部信息
   --limit-rate <rate> 设置传输速度
   -u/--user <user[:password]>设置服务器的用户和密码
   -0/--http1.0 使用HTTP 1.0
   -X, --request <command>:自定义请求方法

用法:curl [options] [URL...]

另一个工具:elinks
   elinks  [OPTION]... [URL]...
       -dump: 不进入交互式模式,而直接将URL的内容输出至标准输出;

mod_deflate模块

使用mod_deflate模块压缩页面优化传输速度

适用场景:
(1) 节约带宽,额外消耗CPU;同时,可能有些较老浏览器不支持;
(2) 压缩适于压缩的资源,例如文件文件;

   SetOutputFilter DEFLATE

   # mod_deflate configuration

   # Restrict compression to these MIME types
   AddOutputFilterByType DEFLATE text/plain
   AddOutputFilterByType DEFLATE text/html
   AddOutputFilterByType DEFLATE application/xhtml+xml
   AddOutputFilterByType DEFLATE text/xml
   AddOutputFilterByType DEFLATE application/xml
   AddOutputFilterByType DEFLATE application/x-javascript
   AddOutputFilterByType DEFLATE text/javascript
   AddOutputFilterByType DEFLATE text/css

   # Level of compression (Highest 9 - Lowest 1)
   DeflateCompressionLevel 9

   # Netscape 4.x has some problems.
   BrowserMatch ^Mozilla/4  gzip-only-text/html

   # Netscape 4.06-4.08 have some more problems
   BrowserMatch  ^Mozilla/4\.0[678]  no-gzip

   # MSIE masquerades as Netscape, but it is fine
   BrowserMatch \bMSI[E]  !no-gzip !gzip-only-text/html

https协议

HTTPS(全称:Hyper Text Transfer Protocol over Secure Socket Layer),是以安全为目标的HTTP通道,简单讲是HTTP的安全版。即HTTP下加入SSL层,HTTPS的安全基础是SSL,因此加密的详细内容就需要SSL。

HTTPS和HTTP的区别

超文本传输协议HTTP协议被用于在Web浏览器和网站服务器之间传递信息。HTTP协议以明文方式发送内容,不提供任何方式的数据加密,如果攻击者截取了Web浏览器和网站服务器之间的传输报文,就可以直接读懂其中的信息,因此HTTP协议不适合传输一些敏感信息,比如信用卡号、密码等。 
为了解决HTTP协议的这一缺陷,需要使用另一种协议:安全套接字层超文本传输协议HTTPS。为了数据传输的安全,HTTPS在HTTP的基础上加入了SSL协议,SSL依靠证书来验证服务器的身份,并为浏览器和服务器之间的通信加密。

SSL会话的简化过程

(1) 客户端发送可供选择的加密方式,并向服务器请求证书;
(2) 服务器端发送证书以及选定的加密方式给客户端;
(3) 客户端取得证书并进行证书验正:
   如果信任给其发证书的CA:
       (a) 验正证书来源的合法性;用CA的公钥解密证书上数字签名;
       (b) 验正证书的内容的合法性:完整性验正
       (c) 检查证书的有效期限;
       (d) 检查证书是否被吊销;
       (e) 证书中拥有者的名字,与访问的目标主机要一致;
(4) 客户端生成临时会话密钥(对称密钥),并使用服务器端的公钥加密此数据发送给服务器,完成密钥交换;
(5) 服务用此密钥加密用户请求的资源,响应给客户端;

注意:SSL会话是基于IP地址创建;所以单IP的主机上,仅可以使用一个https虚拟主机;

配置httpd支持https

(1) 为服务器申请数字证书;
   测试:通过私建CA发证书
       (a) 创建私有CA
       (b) 在服务器创建证书签署请求
       (c) CA签证

(2) 配置httpd支持使用ssl,及使用的证书;
   # yum -y install mod_ssl

   配置文件:/etc/httpd/conf.d/ssl.conf
       DocumentRoot
       ServerName
       SSLCertificateFile
       SSLCertificateKeyFile

https配置实现

1.安装mod_ssl包,配置http支持https

[root@centos7 ~]# yum -y install mod_ssl
[root@centos7 ~]# httpd -M | grep ssl
ssl_module (shared)
[root@centos7 ~]#

2.建立私有CA

(1)生成私钥

88HUE$[@3)OCK6IO]8LX5GC.png

(2)生成自签证书

_)`(84J1R2BP_[ZNPV}G[EJ.png

(3)为CA提供所需的目录及文件

$$C63W5$}_VDAA$$[_~[~7V.png

3.在服务器端创建签署请求,CA签证

(1)生成私钥

[root@centos7 ~]# mkdir /etc/httpd/ssl
[root@centos7 ~]# cd /etc/httpd/ssl
[root@centos7 ssl]# (umask 077; openssl genrsa -out /etc/httpd/ssl/httpd.key 2048)

(2)生成签署请求

{B3BZ~HS@__V6RC[4LXZM[U.png

(3)CA签证

[root@centos7 ssl]# openssl ca -in httpd.csr -out /etc/httpd/ssl/httpd.crt -days 365

4.配置httpd支持ssl

{`2`NL]4CBY244BYGP6@YKC.png

7F)W)00NEM@~V]BVM%X~$SJ.png

5.客户端验证

7O4N3_)WJ}HND~CJ[XO8D8O.png

E{@$WO1VU2]FPL17$XG~S_4.png

8V3H){(R1FJH$TDB66%F(7A.png

http自带应用程序

htpasswd:basic认证基于文件实现,用于生成账号和密码的程序;
   -c:自动创建此处指定的文件,因此,仅应该在此文件不存在时使用
       -m:md5格式加密
       -s:sha格式加密
       -D:删除指定用户
apachectl:httpd自带的服务控制脚本,支持start和stop等子命令;
apxs:- APache eXtenSion tool
   为httpd增添模块的;

rotatelogs:日志切割
   access_log,
   access_log, access_log.1, ...

ab - web service的压力测试工具    
       ab [OPTIONS]  [http[s]://]hostname[:port]/path
           请求数:[ -n requests ]
           并发数:[ -c concurrency ]
           长连接:[ -k ]

原创文章,作者:zhai796898,如若转载,请注明出处:http://www.178linux.com/55277

(0)
zhai796898zhai796898
上一篇 2016-10-31 00:18
下一篇 2016-10-31 00:40

相关推荐

  • 文件的权限详解(一)

    文件的权限 修改文件的属主和属组 chown 功能:更改属主命令,同时也能更改属组用法:   chown  选项  [属主名][:属组名]  文件名  (分隔符改成.也行) chown  选项   参考的文件=要更改的文件 chown [OPTION]… –reference=R…

    Linux干货 2016-08-04
  • 设计模式 ( 十九 ) 模板方法模式Template method(类行为型)

    设计模式 ( 十九 ) 模板方法模式Template method(类行为型) 1.概述 在面向对象开发过程中,通常我们会遇到这样的一个问题:我们知道一个算法所需的关键步骤,并确定了这些步骤的执行顺序。但是某些步骤的具体实现是未知的,或者说某些步骤的实现与具体的环境相关。例子1:银行业务办理流程在银行办理业务时,一般都包含几个基本固定步骤:取号排队->…

    Linux干货 2015-04-07
  • Linux磁盘管理详解

    linux磁盘管理 添加磁盘步骤: fdisk 管理磁盘分区 格式化文件系统。 设备挂载 开机自动挂载 UUID挂载 取消挂载点 Parted(gpt大于2G分区) 查看文件系统的使用情况。 df 查看挂载信息与磁盘使用量 du 查看使用量 查看分区状况lsblk 查看设备信息blkid linux磁盘管理 当全新安装了一块新的硬盘设备后,为了更充分、安全的…

    Linux干货 2016-09-07
  • lvs初探

    1,lvs是什么 lvs是Linux Virtual Server缩写,linux虚拟服务器,担任负载调度器(load balance)的角色,它不提供任何服务,用户请求到这里的时候,它是将客户需求转发至后端真正提供服务的服务,LVS分为两部分组成,ipvsadm管理集群服务的命令行工具,ipvs,是内核模块。由于ipvs采用基于ip负载均衡技术,所以具有很…

    Linux干货 2016-10-30
  • 马哥教育网络班21期+第8周课程练习

    1、请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别。 网桥:桥接器,是连接两个局域网的一种存储/转发设备,它能将一个大的LAN分割为多个网段,或将两个以上的LAN互联为一个逻辑LAN,使LAN上的所有用户都可访问服务器 集线器:集线器的英文称为“Hub”.集线器(hub)属于纯硬件网络底层设备,基本上不具有类似于交换机的"…

    Linux干货 2016-08-29
  • Linux 发展史

    摘要:     Linux是一款基于Unix的服务端操作系统,目前已广泛应用于国内外的服务器端操作系统领域,其开源性是其获得及其快速的发展,目前至少已有数百种发行版本。 本文主要讲述了linux的系统简介、发展历程和Linux的发行版;     1、Linux的哲学思想:    &nbsp…

    Linux干货 2016-10-19