Apache功能配置:访问控制、日志分割; 部署AWStats日志分析工具

目录

保持连接

访问控制

只允许指定ip访问

拒绝指定主机其他正常访问

用户授权

日志格式

日志分割

操作步骤

使用第三方工具cronolog分割日志

AWStats日志分析

操作步骤

访问AwStats分析系统


保持连接

Apache通过设置配置文件httpd-default.conf中相关的连接保持参数来开启与控制连接保持功能。

使用vim /usr/local/httpd/conf/extra/httpd-default.conf命令打开apache的默认配置文件

注意在httpd的主配置文件中将httpd-default.conf 的in         clude前的注释符去掉,让主配置文件包含该配置文件

参数

说明

KeepAlive

保持连接功能,OFF表示关闭,ON表示打开,可以根据网站的并发请求量决定是否打开,即在高并发时打开连接保持功能,并发量不高时关闭此功能。

MaxKeepAliveRequests

用于设置在一次长连接中可以传输的最大请求数量,超过此最大请求数量就会断开连接,最大值的设置决定于网站中网页的内容,一般设置数量会多于网站中所有的元素。

KeepAliveTimeout

表示一次连接多次请求之间的最大间隔时间,即两次请求之间超过该时间连接就会自动断开,从而避免客户端占用连接资源。

开启httpd服务后,在访问http服务时,在网页中按下F12,打开开发人员工具,在选中网络窗口,使用Ctrl + R刷新网页

选中主机ip,可以看到标头下的响应标头的信息,显示Keep-Alive已经开启,相关参数是timeout=5, max=97

现在来到默认配置文件(/usr/local/httpd/conf/extra/httpd-default.conf)中修改超时时间和最大连接数

保存并退出,使用systemctl restart httpd重启服务

此时来到浏览器刷新,可以看到最大连接数为90


访问控制

使用vim /usr/local/httpd/conf/httpd.conf命令进入httpd主配置文件

在末行模式下搜索Directory(:/Directory)可以找到单元,这个单元就规定了允许或拒绝用户访问哪些目录(访问权限)

<Directory "/usr/local/httpd/htdocs">
    # 省略注释
    Options Indexes FollowSymLinks
    AllowOverride None
    Require ip 192.168.10.102 # 修改为ip地址
#   Require ip 192.168.10.0/24 规定为网段也可以
</Directory>

图中的Require all denied规定了用户全都不能访问系统的根目录

往下翻一点,可以看到另一个Directory单元,这个单元中就规定了用户可以访问/usr/local/httpd/htdocs目录

只允许指定ip访问

<Directory "/usr/local/httpd/htdocs">
    # 省略注释
    Options Indexes FollowSymLinks
    AllowOverride None
    Require ip 192.168.10.102 # 修改为ip地址
#   Require ip 192.168.10.0/24 规定为网段也可以
</Directory>

修改后需要重启服务

然后打开一台带有图形化界面的虚拟机,比如win10或win11,或者使用第二台Linux主机,通过curl命令也可以

将其ip修改为192.168.10.102,访问Web服务器(192.168.10.101),可以看到访问是通过的

 

使用宿主机访问也不能正常访问了,403状态码

拒绝指定主机其他正常访问

<Directory "/usr/local/httpd/htdocs">
    # 省略注释
    Options Indexes FollowSymLinks
    AllowOverride None
    <RequireAll>
        Require all granted    # 允许所有主机访问
        Require not ip 192.168.10.102    # 拒绝192.168.10.102访问
    </RequireAll>
</Directory>

此时除了刚刚开启的102主机其他的都可以正常访问Web服务器

用户授权

验证授权的方式变成账号密码,需要用到Apache自带的htpasswd工具生成

使用htpasswd命令生成文件,第一次创建需要加-c选项,后续就不需要加-c了

通过cat命令可以查看到生存的用户和密钥

[root@localhost ~]# cat /usr/local/httpd/conf/.example 
tom:$apr1$9E2tS/4/$28pw.i5heCsVXYY9TA7Og/
jerry:$apr1$dQtbTAQw$w3QYXr8E62MzoYnNbUEiC1

再修改配置文件(/usr/local/httpd/conf/httpd.conf

<Directory "/usr/local/httpd/htdocs">
    # 省略注释
    Options Indexes FollowSymLinks
    AllowOverride None
    
    AuthName "abc" # 指定授权域的名称或描述
    AuthType Basic # 指定了认证的类型为 Basic,即基本认证方式。
    AuthUserFile /usr/local/httpd/conf/.example # 指定了存储用户账号和密码的文件的路径
    Require valid-user # 要求访问受保护资源的用户必须提供有效的用户名和密码。
</Directory>

Basic:指定了认证的类型为 Basic,即基本认证方式。Basic Authentication 是一种简单的认证方式,客户端(通常是浏览器)会将用户名和密码以明文形式通过 HTTP 的 Authorization 头部发送给服务器。

最后在访问Web服务器时,就会被要求输入账号和密码


日志格式

打开Apache的主配置文件(/usr/local/httpd/conf/httpd.conf),在末行模式下搜索Log(:/Log)

可以看到httpd提供的两种日志格式,第一种是combined(组合格式),第二种是common(通用格式)

在下方可以看到access_log(访问日志)用的是通用格式来生成日志的,这里我们改成组合格式

 

改为组合模式

保存并退出,重启httpd服务,再次访问Web服务器。然后cat查看/usr/local/httpd/logs/access_log文件

可以看到最后一行的组合日志格式生成的日志

192.168.10.1 - - [10/Jul/2024:10:19:23 +0800] "GET / HTTP/1.1" 200 154 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 Safari/537.36 Edg/126.0.0.0"

参数

说明

&h

客户端的IP地址或主机名

%l

客户端的标识符,如果启用了标识符(如通过 IdentLookups 配置),否则为 -

%u

请求时客户端提供的用户名(如果是用户认证登录,就显示为用户),否则显示 -

%t

请求的时间戳

\"%r\"

客户端请求的第一行,包括 HTTP 方法、请求路径和协议

这里的 \ 是转义符

%>s

服务器返回给客户端的HTTP状态码

%b

传输给客户端的字节数,不包括HTTP头部的大小

\"%{Referer}i\"

请求报文中首部 "referer" 的值;即从哪个页面中的超链接跳转至当前页面的,防止盗链,i就是首部的意思,Referer是链接到此URL的页面。

i是首部的意思,即请求头

\"%{User-Agent}i\"

此项是客户端提供的浏览器识别信息,i是首部的意思,即请求头

&I

服务器接收得字节数,需要启用mod_logio模块。

%O

服务器发送得字节数,需要启用mod_logio模块。


日志分割

日志分割需要使用Apache自带的日志分割工具rotatelogs

操作步骤

依旧打开httpd主配置文件

将刚才修改日志格式的行注释掉,使用CustomLog指定日志记录的方式

#CustomLog "logs/access_log" combined
CustomLog "|/usr/local/bin/rotatelogs -l /var/log/httpd/access_%Y%m%d.log 86400" combined

参数

说明

|

将生成的日志数据传递给一个外部程序进行处理或存储

/usr/local/bin/rotatelogs

指定日志分割工具的路径

-l /var/log/httpd/access_%Y%m%d.log

指定了日志文件的格式和存储位置

-l:用于指定日志文件的命名模式和路径

%Y%m%d

表示将日期格式化为年(四位数)、月、日,例如 access_20240710.log

86400

日志文件的滚动时间间隔,单位是秒。这里代表一天的秒数,即每隔一天就会生成一个新的日志文件。

保存并退出,重启服务。手动在指定的/var/log下创建httpd目录

再通过浏览器访问Web服务器,然后去/var/log/httpd/下查看access_20240710.log文件

[root@localhost httpd]# cat access_20240710.log 
192.168.10.1 - - [10/Jul/2024:10:40:07 +0800] "GET / HTTP/1.1" 304 - "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 Safari/537.36 Edg/126.0.0.0"
192.168.10.1 - - [10/Jul/2024:10:40:07 +0800] "GET / HTTP/1.1" 304 - "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 Safari/537.36 Edg/126.0.0.0"
192.168.10.1 - - [10/Jul/2024:10:40:08 +0800] "GET / HTTP/1.1" 304 - "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 Safari/537.36 Edg/126.0.0.0"

使用第三方工具cronolog分割日志

将源代码软件包拖入XShell,使用tar zxvf命令解压,进入解压目录

使用 ./configuremake && make instll 安装

进入/usr/local/sbin/目录下可以看到自动将命令安装进sbin目录下了

[root@localhost cronolog-1.6.2]# cd /usr/local/sbin/
[root@localhost sbin]# ls
cronolog  cronosplit

进入httpd主配置文件,修改日志记录方式

#CustomLog "logs/access_log" combined
CustomLog "|/usr/local/sbin/cronolog /var/log/httpd/my_access_%Y%m%d.log" combined

保存并退出,重启服务。

再通过浏览器访问Web服务器,然后去/var/log/httpd/下查看my_access_20240710.log文件

[root@localhost httpd]# cat my_access_20240710.log 
192.168.10.1 - - [10/Jul/2024:10:48:30 +0800] "GET / HTTP/1.1" 304 - "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 Safari/537.36 Edg/126.0.0.0"

实验完成后把日志记录方式改为原来的,用于下一步日志分析的实验

CustomLog "logs/access_log" combined
#CustomLog "|/usr/local/sbin/cronolog /var/log/httpd/my_access_%Y%m%d.log" combined

AWStats日志分析

Awstats是一个免费非常简洁而且强大有个性的网站日志分析工具。

操作步骤

将源代码软件包拖入XShell,使用tar zxvf命令解压,然后使用mv awstats-7.7 /usr/local/awstats命令将解压出的目录移动到/usr/local/下并将目录名重命名为awstats

cd到/usr/local/awstats目录下,再进入tools子目录,可以看到这里存放着工具集

[root@localhost ~]# cd /usr/local/awstats/
[root@localhost awstats]# ls
docs  README.md  tools  wwwroot
[root@localhost awstats]# cd tools/
[root@localhost tools]# ls
awstats_buildstaticpages.pl  dolibarr            maillogconvert.pl   xslt
awstats_configure.pl         geoip_generator.pl  nginx
awstats_exportlib.pl         httpd_conf          urlaliasbuilder.pl
awstats_updateall.pl         logresolvemerge.pl  webmin

在该目录下使用awstats_configure.pl初始化

[root@localhost tools]# ./awstats_configure.pl

Enter full config file path of your Web server.
Example: /etc/httpd/httpd.conf    # 使用yum安装的位置
Example: /usr/local/apache2/conf/httpd.conf    # 使用源代码可能安装的位置
Example: c:\Program files\apache group\apache\conf\httpd.conf    # Windows系统下可能安装apache的安装路径
Config file path ('none' to skip web server setup):
> /usr/local/httpd/conf/httpd.conf    # 填入Apache的配置文件路径,回车

-----> Need to create a new config file ?    # 是否需要创建一个新的配置文件
Do you want me to build a new AWStats config/profile    # 是否希望它创建一个新的AWStats配置文件或配置文件模板
file (required if first install) [y/N] ? y

-----> Define config file name to create    # 要求定义要创建的配置文件的名称
What is the name of your web site or profile analysis ?
Example: www.mysite.com
Example: demo
Your web site, virtual server or profile name:
> www.tom.com      # 输入想命名的AWStats配置文件的名称

-----> Define config file path    # 设置配置文件的路径
In which directory do you plan to store your config file(s) ?
Default: /etc/awstats
Directory path to store config file(s) (Enter for default):
> 
    # 这里使用默认路径 所以直接回车

Press ENTER to continue...
# 回车,以继续
Press ENTER to finish...
# 回车,以结束

修改httpd配置文件,在命令模式下按下大写字母G,来到文件末尾,修改<Directory>标签为允许全部客户端访问该目录下的文件和脚本

[root@localhost ~]# vim /usr/local/httpd/conf/httpd.conf
<Directory "/usr/local/awstats/wwwroot">
    Options None
    AllowOverride None
    Require all granted
</Directory>

编辑awstats初始化后生成的配置文件,然后创建存储AWStats数据的目录

[root@localhost tools]# vim /etc/awstats/awstats.www.tom.com.conf
在第50行,改为httpd路径位置
Logile="/usr/local/httpd/logs/access_log"
在第220行,改为如下内容
DirData="/var/lib/awstats"    # 指定了AWStats存储数据文件的目录路径
[root@localhost awstats]# mkdir /var/lib/awstats

编辑当前用户的 cron 任务

[root@localhost tools]# crontab -e
*/2 * * * * /usr/local/awstats/tools/awstats_updateall.pl now

*/2:表示每隔2分钟执行一次后面的命令
*:通配符,表示所有可能的值
/usr/local/awstats/tools/awstats_updateall.pl now:是要执行的命令或者脚本

再修改httpd配置文件,在命令模式下按下大写G来到文件末尾,在文件末尾添加IfModule标签加载不同模块,最后重启服务

[root@localhost ~]# vim /usr/local/httpd/conf/httpd.conf
<IfModule !mpm_prefork_module>
    LoadModule cgid_module modules/mod_cgid.so
</IfModule>
<IfModule mpm_prefork_module>
    LoadModule cgi_module modules/mod_cgi.so
</IfModule>

重启服务
[root@localhost tools]# systemctl restart httpd

访问AwStats分析系统

在浏览器访问站点:http://192.168.10.101/awstats/awstats.pl?config=www.tom.com

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/790682.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

鸿蒙语言基础类库:【@ohos.util.TreeSet (非线性容器TreeSet)】

非线性容器TreeSet 说明&#xff1a; 本模块首批接口从API version 8开始支持。后续版本的新增接口&#xff0c;采用上角标单独标记接口的起始版本。开发前请熟悉鸿蒙开发指导文档&#xff1a;gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md点击或者复制转到。 T…

022-GeoGebra中级篇-几何对象之直线与坐标轴

本文主要介绍一下GeoGebra中直线的常见输入方式&#xff0c;比如工具栏输入、表达式输入、函数输入&#xff0c;最后再把坐标轴的调用简单介绍一下。内容比起传统的教学更偏向于实战一些&#xff0c;若感兴趣欢迎继续阅读。 目录 一、直线1. 关于工具栏绘制&#xff08;1&#…

OpenGL笔记七之顶点数据绘制命令和绘制模式

OpenGL笔记七之顶点数据绘制命令和绘制模式 —— 2024-07-07 杭州 下午 总结自bilibili赵新政老师的教程 code review! 文章目录 OpenGL笔记七之顶点数据绘制命令和绘制模式1.OpenGL版本号更改和编译更改2.GL_TRIANGLES模式绘制一个三角形、支持NFC坐标随窗口缩放2.1.三个点…

Clion中怎么切换不同的程序运行

如下图&#xff0c;比如这个文件夹下面有那么多的项目&#xff1a; 那么我想切换不同的项目运行怎么办呢&#xff1f;如果想通过下图的Edit Configurations来设置是不行的&#xff1a; 解决办法&#xff1a; 如下图&#xff0c;选中项目的CMakeLists.txt&#xff0c;右键再点击…

QImage显示图片像素

在Qt中&#xff0c;QImage 类是用来表示和处理图像的。如果你想查看或显示一个图片的像素数据&#xff0c;你可以使用 QImage 提供的方法来访问这些数据。以下是一些基本的方法来获取和显示图片的像素信息&#xff1a; 获取图像的像素格式&#xff1a; 使用 QImage::format() …

数字化转型领航者:佑美科技塑造智能健康新生态

在全球数字化转型的浪潮中,佑美专注于智能健康解决方案的创新,正以其卓越的技术实力和前瞻性的战略眼光,引领着智能穿戴设备和健身器械行业的未来趋势。佑美科技不仅深耕数字化转型,更在多个领域获得了国家级和省级的权威认可,彰显了其在智能健康领域的影响力。 智能穿戴设备正…

每日一题~abc356(对于一串连续数字 找规律,开数值桶算贡献)

添加链接描述 题意&#xff1a;对于给定的n,m 。计算0~n 每一个数和m & 之后&#xff0c;得到的数 的二进制中 1的个数的和。 一位一位的算。最多是60位。 我们只需要计算 在 1-n这些数上&#xff0c;有多少个数 第i位 为1. 因为是连续的自然数&#xff0c;每一位上1 的…

echarts使用自定义图形实现3D柱状图

先看下效果吧 实现思路 使用graphic创建并注册自定义图形。根据每组的数据值&#xff0c;得到一个对应的点&#xff0c;从点出发用canvas绘制一组图形&#xff0c;分别为 顶部的菱形 const CubeTop echarts.graphic.extendShape({buildPath: function (ctx, shape) {const c1…

odoo视图继承

odoo视图继承 在模型时候&#xff0c;不对视图、菜单等进行修改&#xff0c;原视图和菜单等视图数据仍然可以使用&#xff0c;不需要重新构建 form视图继承案例 model&#xff1a;为对应模型 inherit_id&#xff1a;为继承的视图&#xff0c;ref:为继承视图的id&#xff0…

学圣学最终的目的是:达到思无邪的状态( 纯粹、思想纯正、积极向上 )

学圣学最终的目的是&#xff1a;达到思无邪的状态&#xff08; 纯粹、思想纯正、积极向上 &#xff09; 中华民族&#xff0c;一直以来&#xff0c;教学都是以追随圣学为目标&#xff0c;所以中华文化也叫圣学文化&#xff0c;是最高深的上等学问&#xff1b; 圣人那颗心根本…

linux创建定时任务

crontab方式 先查看是否有cron systemctl status crond 没有的话就安装 yum install cronie 打开你的crontab文件进行编辑。使用以下命令打开当前用户的crontab文件&#xff1a; crontab -e * * * * * /export/test.sh >> /export/test.log 2>&1/export/test.s…

大语言模型里的微调vs RAG vs 模板提示词

文章目录 介绍微调&#xff08;Fine-tuning&#xff09;定义优点&#xff1a;缺点&#xff1a;应用场景&#xff1a;技术细节 检索增强生成&#xff08;RAG&#xff0c;Retrieval-Augmented Generation&#xff09;定义优点&#xff1a;缺点&#xff1a;应用场景&#xff1a;技…

嵌入式应用开发之代码整洁之道

前言&#xff1a;本系列教程旨在如何将自己的代码写的整洁&#xff0c;同时也希望小伙伴们懂如何把代码写脏&#xff0c;以备不时之需&#xff0c;同时本系列参考 正点原子 &#xff0c; C代码整洁之道&#xff0c;编写可读的代码艺术。 #好的代码的特点 好的代码应该都有着几…

联想拯救者Y7000 IRX9 笔记本接口功能介绍

适用机型&#xff1a;Legion Y7000 IRX9; 83JJ&#xff1b; USB&#xff08;3.2 Gen 1&#xff09;Type-接口摄像头开关组合音频插孔 多用于USB Type-C接口 以太网接口 多用途USB Type-C接口&#xff08;支持USB Power Delivery&#xff09;HDMI接口USB&#xff08;3.2 Gen 1&…

勇攀新高峰|暴雨信息召开2024年中述职工作会议

7月8日至9日&#xff0c;暴雨信息召开2024年中述职工作会议&#xff0c;总结回顾了上半年的成绩和不足&#xff0c;本次会议采用线上线下的方式举行&#xff0c;公司各部门管理人员、前台市场营销人员参加述职&#xff0c;公司领导班子出席会议。 本次述职采取了现场汇报点评的…

[CTF]-PWN:House of Cat堆题型综合解析

原理&#xff1a; 调用顺序&#xff1a; exit->_IO_wfile_jumps->_IO_wfile_seekoff->_IO_switch_to_wget_mode _IO_wfile_seekoff源码&#xff1a; off64_t _IO_wfile_seekoff (FILE *fp, off64_t offset, int dir, int mode) {off64_t result;off64_t delta, new…

[论文笔记]RAPTOR: RECURSIVE ABSTRACTIVE PROCESSING FOR TREE-ORGANIZED RETRIEVAL

引言 今天带来又一篇RAG论文笔记&#xff1a;RAPTOR: RECURSIVE ABSTRACTIVE PROCESSING FOR TREE-ORGANIZED RETRIEVAL。 检索增强语言模型能够更好地适应世界状态的变化并融入长尾知识。然而&#xff0c;大多数现有方法只能从检索语料库中检索到短的连续文本片段&#xff0…

引用计数器(kref)

1、什么是引用计数器 如果我们写了一个字符驱动&#xff0c;当硬件设备插上时&#xff0c;系统会生成一个设备节点。用户在应用空间操作这个设备节点就可以操作设备。如果此时将硬件断开&#xff0c;驱动是不是就要立刻释放呢&#xff1f;如果立刻释放&#xff0c;应用程序是不…

【Spring成神之路】老兄,来一杯Spring AOP源码吗?

文章目录 一、引言二、Spring AOP的使用三、Spring AOP的组件3.1 Pointcut源码3.2 Advice源码3.3 Advisor源码3.4 Aspect源码 四、Spring AOP源码刨析4.1 configureAutoProxyCreator源码解析4.2 parsePointcut源码解析4.3 parseAdvisor源码解析4.4 parseAspect源码解析4.5 小总…

HDFS 块重构和RedundancyMonitor详解

文章目录 1. 前言2 故障块的重构(Reconstruct)2.1 故障块的状态定义和各个状态的统计信息2.2 故障文件块的查找收集2.5.2.1 misReplica的检测2.5.2.2 延迟队列(postponedMisreplicatedBlocks)的构造和实现postponedMisreplicatedBlocks中Block的添加postponedMisreplicatedBloc…