Linux 文件系统与日志分析「建议收藏」

大家好,又见面了,我是你们的朋友全栈君。

文章目录1.前言2.深入理解 Linux 文件系统2.1 inode 与 block 详解(1) inode 和 block 概述(2) inode 内容(3) 查看文件的 inode 号码(4) inode的大小(5) 文件存储总结(6) inode 节点耗尽故障处理(7) 恢复误删除的 ext 格式文件(8) 恢复误删除的 xfs 格式文件2.2 软链接和硬链接(1) 概念(2) 命令管理 — ln3. Linux 日志文件分析3.1 日志简介3.2 常见的一些日志文件(1) 内核及公共消息日志(2) 计划任务日志(3) 系统引导日志(4) 邮件系统日志(5) 用户登录日志3.3 日志消息的级别3.4 rsyslog 日志管理服务3.5 日志分析工具3.6 日志轮替 — logrotate4.总结

1.前言

  Linux,全称 GNU/Linux,是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX 的多用户、多任务、支持多线程和多 CPU 的操作系统。伴随着互联网的发展,Linux 得到了来自全世界软件爱好者、组织、公司的支持。它除了在服务器方面保持着强劲的发展势头以外,在个人电脑、嵌入式系统上都有着长足的进步。使用者不仅可以直观地获取该操作系统的实现机制,而且可以根据自身的需要来修改完善Linux,使其最大化地适应用户的需要。   Linux 的基本思想有两点:一切都是文件;每个文件都有确定的用途。其中第一条详细来讲就是系统中的所有都归结为一个文件,包括命令、硬件和软件设备、操作系统、进程等等对于操作系统内核而言,都被视为拥有各自特性或类型的文件。至于说 Linux 是基于 Unix 的,很大程度上也是因为这两者的基本思想十分相近。

2.深入理解 Linux 文件系统2.1 inode 与 block 详解(1) inode 和 block 概述

  文件是存储在硬盘上的,硬盘的最小存储单位叫做 “扇区” (sector),每个扇区存储 512 字节。一般连续八个扇区组成一个 “块” (block),一个块是 4K 大小,是文件存取的最小单位。操作系统读取硬盘的时候,是一次性连续读取多个扇区,即一个块一个块的读取的。   文件数据包括实际数据与元信息(类似文件属性)。文件数据存储在 “块” 中,存储文件元信息(比如文件的创建者、创建日期、文件大小、文件权限等)的区域就叫做 inode。 因此,一个文件必须占用一个 inode,并且至少占用一个 block。inode 不包含文件名,文件名是存放在目录当中的。Linux 系统中一切皆文件,因此目录也是一种文件。   每个 inode 都有一个号码,操作系统用 inode 号码来识别不同的文件。Linux 系统内部不使用文件名,而使用 inode 号码来识别文件。对于系统来说,文件名只是 inode 号码便于识别的别称,文件名和 inode 号码是一一对应关系,每个 inode 号码对应一个文件名。所以当用户在 Linux 系统中试图访问一个文件时,系统会先根据文件名去查找它对应的 inode 号码,通过 inode 号码获取 inode 信息,根据 inode 信息看该用户是否具有访问这个文件的权限,如果有就指向对应的数据 block,并读取数据。

Linux 文件系统与日志分析「建议收藏」

(2) inode 内容

inode 包含文件的元信息,具体来说有以下内容:

文件的字节数文件拥有者的 User ID文件的 Group ID文件的读、写、执行权限文件的时间戳,共有三个:

简写

全名

中文名

含义

atime

access time

访问时间

文件内容最后被访问的时间

mtime

modify time

修改时间

文件内容最后被修改的时间

ctime

change time

变化时间

文件的元数据发生变化的时间(比如权限,所有者等)

链接数,即有多少文件名指向这个 inode文件数据 block 的位置(3) 查看文件的 inode 号码

查看文件名对应的 inode 号码有两种方式:

代码语言:javascript代码运行次数:0运行复制

ls -i 文件名stat 文件名

示例:

代码语言:javascript代码运行次数:0运行复制

[root@c7-1 ~]#touch test1[root@c7-1 ~]#ls -i test1 100764458 test1[root@c7-1 ~]#stat test1  文件:"test1"  大小:0         块:0          IO 块:4096   普通空文件设备:802h/2050dInode:100764458   硬链接:1权限:(0644/-rw-r--r--)  Uid:(    0/    root)   Gid:(    0/    root)最近访问:2021-08-23 00:06:53.974603350 +0800最近更改:2021-08-23 00:06:53.974603350 +0800最近改动:2021-08-23 00:06:53.974603350 +0800创建时间:-

(4) inode的大小

  inode 也会消耗硬盘空间,所以格式化的时候,操作系统自动将硬盘分成两个区域。一个是数据区,存放文件数据;另一个是 inode 区,存放 inode 所包含的信息。每个inode的大小,一般是 128 字节或 256 字节。假定在一块 1GB 的硬盘中,每个 inode 节点的大小为 128 字节,每 1KB 就设置一个 inode,那么 inode table 的大小就会达到 128MB,占整块硬盘的 12.8%。   通常情况下不需要关注单个 inode 的大小,而是需要重点关注 inode 总数。inode 的总数在格式化时就给定了,执行 “df-i” 命令即可查看每个硬盘分区对应的的 inode 总数和已经使用的 inode 数量。

代码语言:javascript代码运行次数:0运行复制

[root@c7-1 ~]#df -i文件系统          Inode 已用(I)  可用(I) 已用(I)% 挂载点devtmpfs         479977     406   479571       1% /devtmpfs            482670       1   482669       1% /dev/shmtmpfs            482670    1260   481410       1% /runtmpfs            482670      16   482654       1% /sys/fs/cgroup/dev/sda2      26214400   59040 26155360       1% //dev/sda5      20971520       3 20971517       1% /data/dev/sda1       1048576     328  1048248       1% /boottmpfs            482670       1   482669       1% /run/user/0

由于 inode 号码与文件名分离,导致 Linux 系统具备以下几种特有的现象:

文件名包含特殊字符,可能无法正常删除。这时直接删除 inode,能够起到删除文件的作用代码语言:javascript代码运行次数:0运行复制

find ./ -inum 52305140 -exec rm -i {    } ;find ./ -inum 50464299 -delete

移动文件或重命名文件,只是改变文件名,不影响 inode 号码打开一个文件以后,系统就以 inode 号码来识别这个文件,不再考虑文件名文件数据被修改保存后,会生成一个新的 inode 号码代码语言:javascript代码运行次数:0运行复制

[root@c7-1 ~]#touch test[root@c7-1 ~]#ls -i100764458 test[root@c7-1 ~]#find ./ -inum 100764458 -exec rm -i {} ;rm:是否删除普通空文件 "./test"?y[root@c7-1 ~]#ls[root@c7-1 ~]#

(5) 文件存储总结

硬盘分区后的结构:

Linux 文件系统与日志分析「建议收藏」

用户访问文件流程:

Linux 文件系统与日志分析「建议收藏」

(6) inode 节点耗尽故障处理代码语言:javascript代码运行次数:0运行复制

添加一块硬盘,不用太大,我们分区只需要 15M echo "- - -" > /sys/class/scsi_host/host0/scan#扫描磁盘,fdisk -l 查看,如果没有显示 /dev/sdb,扫描 host1/host2echo -e "nnpn1nn+15Mnwn" | fdisk /dev/sdbpartprobe /dev/sdbmkfs.ext3 /dev/sdb1mkdir /testmount /dev/sdb1 /test/df -i#查看 inode for ((i=1;i<=3829;i++));do touch /test/file${i};done        或者        touch {    1..3829}.txtls /test |wc -ldf -i#此时 /dev/sdb1 的 inode 已用尽touch test.txt#创建失败,容量还有,但是 inode 已经用尽rm -rf /test/*#删除无用文件,恢复 inode 占用

(7) 恢复误删除的 ext 格式文件代码语言:javascript代码运行次数:0运行复制

#extundelete 是一个开源的 Linux 数据恢复工具,支持 ext3、ext4 文件系统。(ext4 只能在 centos6 版本恢复,ext3 可以在 centos7 版本恢复)添加一块硬盘echo "- - -" > /sys/class/scsi_host/host0/scanecho -e "nnpn1nnnwn" | fdisk /dev/sdbpartprobe /dev/sdbmkfs.ext3 /dev/sdb1mkdir /testmount /dev/sdb1 /test/df -Th#安装依赖包yum -y install e2fsprogs-devel e2fsprogs-libs gcc gcc-c++ make wget#编译安装 extundelete cd /testwget http://nchc.dl.sourceforge.net/project/extundelete/extundelete/0.2.4/extundelete-0.2.4.tar.bz2tar jxvf extundelete-0.2.4.tar.bz2cd extundelete-0.2.4/./configure --prefix=/usr/local/extundelete && make && make installls /usr/local/extundelete/bin/extundeleteln -s /usr/local/extundelete/bin/* /usr/bin/#模拟删除并执行恢复操作cd /testecho a>aecho a>becho a>cecho a>dectundelete /dev/sdb1 --inode 2#查看文件系统 /dev/sdb1下存在哪些文件,inode 节点是从 2 开始的,2 代表该文件系统最开始的目录rm -rf /test/*cdumount /test/df -Thextundelete /dev/sdb1 --restore-all#恢复 /dev/sdb1 下的所有数据,在当前目录下会出现一个 RECOVERED_FILES 目录,里面保存了已经恢复的文件ls RECOVERED_FILES/

(8) 恢复误删除的 xfs 格式文件

xfs 类型文件备份和恢复:

代码语言:javascript代码运行次数:0运行复制

centos7 系统默认采用 xfs 类型的文件,xfs 类型的文件可使用 xfsdump 与 xfsrestore 工具进行备份恢复xfsdump 的备份级别有两种: 0 表示完全备份; 1-9 表示增量备份。xfsdump 的备份级别默认为 0

xfsdump 的命令格式为:

代码语言:javascript代码运行次数:0运行复制

xfsdump [参数] [备份存放位置] [要备份的路径或设备文件]

xfsdump 命令常用的选项:

代码语言:javascript代码运行次数:0运行复制

-f: 指定备份文件目录-L: 指定标签 session label-M: 指定设备标签 media label-s:备份单个文件,-s 后面不能直接跟路径

xfsdump使用限制:

代码语言:javascript代码运行次数:0运行复制

只能备份已挂载的文件系统必须使用 root 的权限才能操作只能备份 xfs 文件系统备份后的数据只能让 xfsrestore 解析不能备份两个具有相同 UUID 的文件系统(可用 blkid 命令查看)

xfsrestore 命令格式:

代码语言:javascript代码运行次数:0运行复制

xfsrestore -f [恢复文件的位置] [存放恢复后文件的位置]

示例:

代码语言:javascript代码运行次数:0运行复制

添加一块硬盘echo "- - -" > /sys/class/scsi_host/host0/scanecho -e "nnpn1nnnwn" | fdisk /dev/sdbpartprobe /dev/sdbmkfs.xfs -f /dev/sdb1mkdir /datamount /dev/sdb1 /datadf -Thcd /data && cp /etc/passwd ./ && cp -r /var/log/ ./ && ls#使用 xfsdump 命令备份整个分区rpm -qa | grep xfsdumpyum -y install xfsdumpxfsdump -f /opt/dump_sdb1 /dev/sdb1#输入标签dump_sdb1 sdb1#上面步骤等同于 xfsdump -f /opt/dump_sdb1 /dev/sdb1 -L dump_sdb -M sdb1ls /opt#此时存在文件 dump_sdb1#模拟数据丢失并使用 xfsrestore 命令恢复文件rm -rf /data/*ls /dataxfsrestore -f /opt/dump_sdb1 /data/ls /data

2.2 软链接和硬链接(1) 概念

作用:为文件或目录建立链接文件

链接文件分类:

软链接

硬链接

删除原始文件后

失效

仍旧可用

使用范围

适用于文件或目录

只可用于文件

保存位置

与原始文件可以位于不同的文件系统中

讯飞听见会议 讯飞听见会议

科大讯飞推出的AI智能会议系统

讯飞听见会议 19 查看详情 讯飞听见会议

必须与原始文件在同一个文件系统中(如一个 Linux 分区内)

(2) 命令管理 – ln

格式:

代码语言:javascript代码运行次数:0运行复制

ln [参数] [源文件或目录] [目标文件或目录]

参数

含义

-s

软链接(符号链接)

-b

删除,覆盖以前建立的链接

-f

强制执行

-i

交互模式,文件存在则提示用户是否覆盖

-n

把符号链接视为一般目录

-d

允许超级用户制作目录的硬链接

示例:

代码语言:javascript代码运行次数:0运行复制

[root@c7-1 data]#lltotal 4drwxr-xr-x 2 root root 19 Jul 28 17:51 test-rw-r--r-- 1 root root 10 Jul 28 17:35 test.txt[root@c7-1 data]#ln test.txt test.link[root@c7-1 data]#ln -s test.txt test.soft.link[root@c7-1 data]#lltotal 8drwxr-xr-x 2 root root 19 Jul 28 17:51 test-rw-r--r-- 2 root root 10 Jul 28 17:35 test.linklrwxrwxrwx 1 root root  8 Jul 28 19:56 test.soft.link -> test.txt-rw-r--r-- 2 root root 10 Jul 28 17:35 test.txt

3. Linux 日志文件分析3.1 日志简介

  Linux 系统拥有非常灵活和强大的日志功能,可以保存几乎所有的操作记录,并可以从中检索出我们需要的信息。   内核及系统日志由系统服务 rsyslog 统一管理,主配置文件为 /etc/rsyslog.conf。Linux 操作系统本身和大部分服务器程序的日志文件都默认放在目录 /var/log/ 下。

3.2 常见的一些日志文件(1) 内核及公共消息日志代码语言:javascript代码运行次数:0运行复制

/var/log/messages

  记录 Linux 内核消息及各种应用程序的公共日志信息,包括启动、IO错误、网络错误、程序故障等。对于未使用独立日志文件的应用程序或服务,一般都可以从该日志文件中获得相关的事件记录信息。

(2) 计划任务日志代码语言:javascript代码运行次数:0运行复制

/var/log/cron

  记录 crond 计划任务产生的事件信息。

(3) 系统引导日志代码语言:javascript代码运行次数:0运行复制

/var/log/dmesg

  记录 Linux 系统在引导过程中的各种事件信息。

(4) 邮件系统日志代码语言:javascript代码运行次数:0运行复制

/var/log/maillog

  记录进入或发出系统的电子邮件活动。

(5) 用户登录日志代码语言:javascript代码运行次数:0运行复制

/var/log/secure

  记录用户认证相关的安全事件信息。

代码语言:javascript代码运行次数:0运行复制

/var/log/lastlog

  记录每个用户最近的登录事件。二进制格式

代码语言:javascript代码运行次数:0运行复制

/var/log/wtmp

  记录每个用户登录、注销及系统启动和停机事件。二进制格式

代码语言:javascript代码运行次数:0运行复制

/var/run/btmp

  记录失败的、错误的登录尝试及验证事件。二进制格式

3.3 日志消息的级别

Linux 系统内核日志消息的优先级别数字等级越小,优先级越高,消息越重要。

代码语言:javascript代码运行次数:0运行复制

0  EMERG(紧急):会导致主机系统不可用的情况1  ALERT(警告):必须马上采取措施解决的问题2  CRIT(严重):比较严重的情况3  ERR(错误):运行出现错误4  WARNING(提醒):可能影响系统功能,需要提醒用户的重要事件5  NOTICE(注意):不会影响正常功能,但是需要注意的事件6  INFO(信息):一般信息7  DEBUG(调试):程序或系统调试信息等

3.4 rsyslog 日志管理服务

  在 centos 6.x 中日志服务已经用 rsyslogd 取代了原先的 syslogd 服务。rsyslogd 日志服务更加先进,功能更多。但是不论该服务的使用,还是日志文件的格式其实都是和 syslogd 服务相兼容的,所以操作方法基本和 syslogd 服务一致。

rsyslogd 的新特点:

代码语言:javascript代码运行次数:0运行复制

基于 TCP 网络协议传输日志信息更安全的网络传输方式有日志消息的及时分析框架后台数据库配置文件中可以写简单的逻辑判断与 syslog 配置文件相兼容

查看 rsyslog 服务:

代码语言:javascript代码运行次数:0运行复制

[root@c7-1 ~]#systemctl status rsyslog● rsyslog.service - System Logging Service   Loaded: loaded (/usr/lib/systemd/system/rsyslog.service; enabled; vendor preset: enabled)   Active: active (running) since 五 2021-08-13 21:57:13 CST; 1 weeks 2 days ago......[root@c7-1 ~]#ps aux | grep rsyslogroot       3422  0.0  0.1 222760  4404 ?        Ssl  15:25   0:00 /usr/sbin/rsyslogd -nroot      21148  0.0  0.0 112728   976 pts/2    R+   17:17   0:00 grep --color=auto rsyslog

rsyslog 的配置使用较复杂,本文碍于篇幅不细讲,参考: rsyslog 日志管理服务 Rsyslog 详解

3.5 日志分析工具代码语言:javascript代码运行次数:0运行复制

users

  命令只是简单地输出当前登录的用户名称,每个显示的用户名对应一个登录会话。如果一个用户有不止一个登录会话,那他的用户名将显示与其相同的次数。

代码语言:javascript代码运行次数:0运行复制

who

  命令用于报告当前登录到系统中的每个用户的信息。使用该命令,系统管理员可以查看当前系统存在哪些不合法用户,从而对其进行审计和处理。who 的默认输出包括用户名、终端类型、登录日期及远程主机。

代码语言:javascript代码运行次数:0运行复制

w

  命令用于显示当前系统中的每个用户及其所运行的进程信息,比 users、who 命令的输出内容要丰富一些。

代码语言:javascript代码运行次数:0运行复制

last

  命令用于查询成功登录到系统的用户记录,最近的登录情况将显示在最前面。通过last 命令可以及时掌握 Linux 主机的登录情况,若发现未经授权的用户登录过,则表示当前主机可能已被入侵。

代码语言:javascript代码运行次数:0运行复制

lastb

  命令用于查询登录失败的用户记录,如登录的用户名错误、密码不正确等情况都将记录在案。登录失败的情况属于安全事件,因为这表示可能有人在尝试猜解你的密码。除了使用 lastb 命令查看以外,也可以直接从安全日志文件 /var/log/secure 中获得相关信息。

代码语言:javascript代码运行次数:0运行复制

journalctl

  journalctl 工具是 centos7 才有的工具。Systemd 统一管理所有 Unit 的启动日志带来的好处就是可以只用 journalctl 一个命令查看所有日志。日志的配置文件是 /etc/systemd/journald.conf

3.6 日志轮替 – logrotate

  默认情况下,logrotate 命令作为放在 /etc/cron.daily 中的 cron 任务,每天运行一次,它会帮助你设置一个策略,其中超过某个时间或大小的日志文件被轮换。

代码语言:javascript代码运行次数:0运行复制

[root@c7-1 ~]#ll /usr/sbin/logrotate-rwxr-xr-x. 1 root root 70344 10月 31 2018 /usr/sbin/logrotate

配置文件:

/etc/logrotate.conf:logrotate 的主配置文件/etc/logrotate.d/:存储了特定服务的配置代码语言:javascript代码运行次数:0运行复制

[root@c7-1 ~]#ll /etc/logrotate.conf-rw-r--r--. 1 root root 662 7月  31 2013 /etc/logrotate.conf[root@c7-1 ~]#ll /etc/logrotate.d总用量 16-rw-r--r--. 1 root root  91 8月   6 2019 bootlog-rw-r--r--. 1 root root 224 8月   6 2019 syslog-rw-r--r--. 1 root root 100 10月 31 2018 wpa_supplicant-rw-r--r--. 1 root root 103 8月   8 2019 yum

logrotate 比较重要的选项:

代码语言:javascript代码运行次数:0运行复制

ompress              --> 压缩日志文件的所有非当前版本daily,weekly,monthly --> 按指定计划轮换日志文件delaycompress        --> 压缩所有版本,除了当前和下一个最近的endscript            --> 标记 prerotate 或 postrotate 脚本的结束errors "emailid"     --> 给指定邮箱发送错误通知missingok            --> 如果日志文件丢失,不要显示错误notifempty           --> 如果日志文件为空,则不轮换日志文件olddir "dir"         --> 指定日志文件的旧版本放在 “dir” 中postrotate           --> 引入一个在日志被轮换后执行的脚本prerotate            --> 引入一个在日志被轮换前执行的脚本rotate 'n'           --> 在轮换方案中包含日志的 n 个版本sharedscripts        --> 对于整个日志组只运行一次脚本size='logsize'       --> 在日志大小大于 logsize(例如 100K,4M)时轮换

配置案例参考:配置 logrotate 的终极指导

4.总结

  与 Windows 系统不同,在 Linux 系统中一切皆文件,独特的文件管理机制是 Linux 能够广泛流传应用的原因之一。通过 inode 号来管理具体的数据,不仅方便运维人员的管理,也提高了系统运行的效率。   Linux 强大的日志功能让我们了解到系统运行的各种错误信息、警告信息和其他提示信息,这些信息对管理员了解系统的运行状态是非常有用的。我们从中检索出有用的信息,及时了解系统的运行状况,预防意外事故的发生,这对于系统能否长久安全稳定运行有重大意义。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/141400.html原文链接:https://javaforall.cn

以上就是Linux 文件系统与日志分析「建议收藏」的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/455004.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 01:01:02
下一篇 2025年11月8日 01:02:10

相关推荐

  • Uniapp 中如何不拉伸不裁剪地展示图片?

    灵活展示图片:如何不拉伸不裁剪 在界面设计中,常常需要以原尺寸展示用户上传的图片。本文将介绍一种在 uniapp 框架中实现该功能的简单方法。 对于不同尺寸的图片,可以采用以下处理方式: 极端宽高比:撑满屏幕宽度或高度,再等比缩放居中。非极端宽高比:居中显示,若能撑满则撑满。 然而,如果需要不拉伸不…

    2025年12月24日
    400
  • 如何让小说网站控制台显示乱码,同时网页内容正常显示?

    如何在不影响用户界面的情况下实现控制台乱码? 当在小说网站上下载小说时,大家可能会遇到一个问题:网站上的文本在网页内正常显示,但是在控制台中却是乱码。如何实现此类操作,从而在不影响用户界面(UI)的情况下保持控制台乱码呢? 答案在于使用自定义字体。网站可以通过在服务器端配置自定义字体,并通过在客户端…

    2025年12月24日
    800
  • 如何在地图上轻松创建气泡信息框?

    地图上气泡信息框的巧妙生成 地图上气泡信息框是一种常用的交互功能,它简便易用,能够为用户提供额外信息。本文将探讨如何借助地图库的功能轻松创建这一功能。 利用地图库的原生功能 大多数地图库,如高德地图,都提供了现成的信息窗体和右键菜单功能。这些功能可以通过以下途径实现: 高德地图 JS API 参考文…

    2025年12月24日
    400
  • 如何使用 scroll-behavior 属性实现元素scrollLeft变化时的平滑动画?

    如何实现元素scrollleft变化时的平滑动画效果? 在许多网页应用中,滚动容器的水平滚动条(scrollleft)需要频繁使用。为了让滚动动作更加自然,你希望给scrollleft的变化添加动画效果。 解决方案:scroll-behavior 属性 要实现scrollleft变化时的平滑动画效果…

    2025年12月24日
    000
  • 如何为滚动元素添加平滑过渡,使滚动条滑动时更自然流畅?

    给滚动元素平滑过渡 如何在滚动条属性(scrollleft)发生改变时为元素添加平滑的过渡效果? 解决方案:scroll-behavior 属性 为滚动容器设置 scroll-behavior 属性可以实现平滑滚动。 html 代码: click the button to slide right!…

    2025年12月24日
    500
  • 如何选择元素个数不固定的指定类名子元素?

    灵活选择元素个数不固定的指定类名子元素 在网页布局中,有时需要选择特定类名的子元素,但这些元素的数量并不固定。例如,下面这段 html 代码中,activebar 和 item 元素的数量均不固定: *n *n 如果需要选择第一个 item元素,可以使用 css 选择器 :nth-child()。该…

    2025年12月24日
    200
  • 使用 SVG 如何实现自定义宽度、间距和半径的虚线边框?

    使用 svg 实现自定义虚线边框 如何实现一个具有自定义宽度、间距和半径的虚线边框是一个常见的前端开发问题。传统的解决方案通常涉及使用 border-image 引入切片图片,但是这种方法存在引入外部资源、性能低下的缺点。 为了避免上述问题,可以使用 svg(可缩放矢量图形)来创建纯代码实现。一种方…

    2025年12月24日
    100
  • 如何让“元素跟随文本高度,而不是撑高父容器?

    如何让 元素跟随文本高度,而不是撑高父容器 在页面布局中,经常遇到父容器高度被子元素撑开的问题。在图例所示的案例中,父容器被较高的图片撑开,而文本的高度没有被考虑。本问答将提供纯css解决方案,让图片跟随文本高度,确保父容器的高度不会被图片影响。 解决方法 为了解决这个问题,需要将图片从文档流中脱离…

    2025年12月24日
    000
  • CSS元素设置em和transition后,为何载入页面无放大效果?

    css元素设置em和transition后,为何载入无放大效果 很多开发者在设置了em和transition后,却发现元素载入页面时无放大效果。本文将解答这一问题。 原问题:在视频演示中,将元素设置如下,载入页面会有放大效果。然而,在个人尝试中,并未出现该效果。这是由于macos和windows系统…

    2025年12月24日
    200
  • 为什么 CSS mask 属性未请求指定图片?

    解决 css mask 属性未请求图片的问题 在使用 css mask 属性时,指定了图片地址,但网络面板显示未请求获取该图片,这可能是由于浏览器兼容性问题造成的。 问题 如下代码所示: 立即学习“前端免费学习笔记(深入)”; icon [data-icon=”cloud”] { –icon-cl…

    2025年12月24日
    200
  • 如何利用 CSS 选中激活标签并影响相邻元素的样式?

    如何利用 css 选中激活标签并影响相邻元素? 为了实现激活标签影响相邻元素的样式需求,可以通过 :has 选择器来实现。以下是如何具体操作: 对于激活标签相邻后的元素,可以在 css 中使用以下代码进行设置: li:has(+li.active) { border-radius: 0 0 10px…

    2025年12月24日
    100
  • 如何模拟Windows 10 设置界面中的鼠标悬浮放大效果?

    win10设置界面的鼠标移动显示周边的样式(探照灯效果)的实现方式 在windows设置界面的鼠标悬浮效果中,光标周围会显示一个放大区域。在前端开发中,可以通过多种方式实现类似的效果。 使用css 使用css的transform和box-shadow属性。通过将transform: scale(1.…

    2025年12月24日
    200
  • 如何用HTML/JS实现Windows 10设置界面鼠标移动探照灯效果?

    Win10设置界面中的鼠标移动探照灯效果实现指南 想要在前端开发中实现类似于Windows 10设置界面的鼠标移动探照灯效果,有两种解决方案:CSS 和 HTML/JS 组合。 CSS 实现 不幸的是,仅使用CSS无法完全实现该效果。 立即学习“前端免费学习笔记(深入)”; HTML/JS 实现 要…

    2025年12月24日
    000
  • 为什么我的 Safari 自定义样式表在百度页面上失效了?

    为什么在 Safari 中自定义样式表未能正常工作? 在 Safari 的偏好设置中设置自定义样式表后,您对其进行测试却发现效果不同。在您自己的网页中,样式有效,而在百度页面中却失效。 造成这种情况的原因是,第一个访问的项目使用了文件协议,可以访问本地目录中的图片文件。而第二个访问的百度使用了 ht…

    2025年12月24日
    000
  • 如何用前端实现 Windows 10 设置界面的鼠标移动探照灯效果?

    如何在前端实现 Windows 10 设置界面中的鼠标移动探照灯效果 想要在前端开发中实现 Windows 10 设置界面中类似的鼠标移动探照灯效果,可以通过以下途径: CSS 解决方案 DEMO 1: Windows 10 网格悬停效果:https://codepen.io/tr4553r7/pe…

    2025年12月24日
    000
  • 如何用前端技术实现Windows 10 设置界面鼠标移动时的探照灯效果?

    探索在前端中实现 Windows 10 设置界面鼠标移动时的探照灯效果 在前端开发中,鼠标悬停在元素上时需要呈现类似于 Windows 10 设置界面所展示的探照灯效果,这其中涉及到了元素外围显示光圈效果的技术实现。 CSS 实现 虽然 CSS 无法直接实现探照灯效果,但可以通过以下技巧营造出类似效…

    2025年12月24日
    000
  • 使用CSS mask属性指定图片URL时,为什么浏览器无法加载图片?

    css mask属性未能加载图片的解决方法 使用css mask属性指定图片url时,如示例中所示: mask: url(“https://api.iconify.design/mdi:apple-icloud.svg”) center / contain no-repeat; 但是,在网络面板中却…

    2025年12月24日
    000
  • 如何用CSS Paint API为网页元素添加时尚的斑马线边框?

    为元素添加时尚的斑马线边框 在网页设计中,有时我们需要添加时尚的边框来提升元素的视觉效果。其中,斑马线边框是一种既醒目又别致的设计元素。 实现斜向斑马线边框 要实现斜向斑马线间隔圆环,我们可以使用css paint api。该api提供了强大的功能,可以让我们在元素上绘制复杂的图形。 立即学习“前端…

    2025年12月24日
    000
  • 图片如何不撑高父容器?

    如何让图片不撑高父容器? 当父容器包含不同高度的子元素时,父容器的高度通常会被最高元素撑开。如果你希望父容器的高度由文本内容撑开,避免图片对其产生影响,可以通过以下 css 解决方法: 绝对定位元素: .child-image { position: absolute; top: 0; left: …

    2025年12月24日
    000
  • CSS 帮助

    我正在尝试将文本附加到棕色框的左侧。我不能。我不知道代码有什么问题。请帮助我。 css .hero { position: relative; bottom: 80px; display: flex; justify-content: left; align-items: start; color:…

    2025年12月24日 好文分享
    200

发表回复

登录后才能评论
关注微信