liunx文件系统,日志分析
文章目录
- 1.inode与block
 - 1.1 inode与block概述
 - 1.2 inode的内容
 - 1.3 文件存储
 - 1.4 inode的大小
 - 1.5 inode的特殊作用
 
- 2.硬链接与软链接
 - 2.1链接文件分类
 
- 3.恢复误删除的文件
 - 3.1 案例:恢复EXT类型的文件
 - 3.2 案例:恢复XFS类型的文件
 - 3.2.1 xfsdump使用限制
 
- 4.分析日志文件
 - 4.1日志文件
 - 4.2 内核及系统日志
 - 4.3用户日志分析
 - 4.4 程序日志分析
 - 4.4.1由相应的应用程序独立进行管理
 - 4.4.2分析工具
 - 4.4.3日志管理策略
 
1.inode与block
1.1 inode与block概述
- 文件数据包括元信息与实际数据 
- 文件存储在硬盘上,硬盘最小存储单位是“扇区”,每个
 
 - 扇区存储512字节 
- block(块) 
- 连续的八个扇区组成一个 block (8x512) 元信息--------------inode
 - 是文件存取的最小单位
 
 - **inode(索引节点) ** 数据----------------block 
- 中文译名为“索引节点”,也叫i节点 一个文件必须占用一个inode,但至少占用一block
 - 用于存储文件元信息
 
 
 - block(块) 
 
1.2 inode的内容
-  
inode包含文件的元信息
- 文件的字节数
 - 文件拥有者的User ID 不包含文件名
 - 文件的Group ID
 - 文件的读、写、执行权限
 - 文件的时间戳
 
 -  
用stat命令可以查看某个文件的inode信息
- 示例:stat aa.txt
 
 

- Linux系统文件三个主要的时间属性 
- atime(access time)
 
 
最后一次访问文件或目录的时间
- ctime(change time)
 
最后一次改变文件或目录(属性)的时间
- mtime(modify time)
 
最后一次修改文件或目录(内容)的时间

 输入内容后时间会变化成最近一次操作的时间
 
 用查看会让atime变化
 
- 目录文件的结构 
- 目录也是一种文件
 - 目录文件的结构
 
 - 每个inode都有一个号码,操作系统用inode号码来识别不同的文件
 - Linux系统内部不使用文件名,而使用inode号码来识别文件
 - 对于用户,文件名只是inode号码便于识别的别称
 
用户通过文件名打开文件时,系统内部的过程
 1.系统找到这个文件名对应的inode号码
 2.通过inode号码,获取inode信息
 3.根据inode信息,找到文件数据所在的block,读出数据
 
 查看inode号码的方法
 ls-i命令:查看文件名对应的inode号码
 Is -i aa.txt
 
 stat命令:查看文件inode信息中的inode号码
 stat aa.txt
 
1.3 文件存储
硬盘分区后的结构
 
 访问文件的简单流程
 
1.4 inode的大小
- inode也会消耗硬盘空间 
- 每个inode的大小
 - 一般是128字节或256字节
 
 - 格式化文件系统时确定inode的总数
 - 使用df-i命令可以查看每个硬盘分区的inode总数和已经使用的数量
 

1.5 inode的特殊作用
- 由于inode号码与文件名分离,导致Linux系统具备以下几种特有的现象 
- 文件名包含特殊字符,可能无法正常删除。这时直接删除inode,能够起到删除文件的作用;
 - 移动文件或重命名文件,只是改变文件名,不影响inode 号码
 - 打开一个文件以后,系统就以inode 号码来识别这个文件,不再考虑文件名
 - 文件数据被修改保存后,会生成一个新的inode 号码
 
 
删除的两种格式
 find ./ -inum inode号 -exec rm -i {} \ ;
 find ./ -inum inode号 -delete
添加硬盘分30M,挂载在test1中,使用命令创建多个文件实现故障现象,查看空余空间,尝试在/opt/test下创建目录无法创建





2.硬链接与软链接
2.1链接文件分类
- 为文件或目录建立链接文件
 - 链接文件分类
 
| 特性 | 软链接(符号链接) | 硬链接 | 
|---|---|---|
| 删除原始文件后 | 链接失效,变成一个指向不存在的文件的符号链接 | 仍旧可用,因为链接指向的是文件的数据块,而非文件名 | 
| 使用范围 | 适用于文件或目录 | 只可用于文件 | 
| 保存位置 | 可以与原始文件位于不同的文件系统中 | 必须与原始文件在同一个文件系统内(例如同一个Linux分区) | 
| 文件大小 | 链接本身的大小是符号链接的大小,通常很小 | 硬链接不增加文件大小,因为它们共享相同的数据块 | 
| 创建方式 | ln -s [源文件或目录] [链接名] | ln [源文件] [链接名] | 
| 文件属性 | 软链接有自己的权限和所有者,与原始文件无关 | 硬链接没有自己的权限和所有者,与原始文件相同 | 
| 文件计数 | 查看链接数时,软链接不计入原始文件的链接数 | 每个硬链接都会增加原始文件的链接数(ls -l 中的 ln 值) | 
| 跨文件系统 | 可以创建跨文件系统的软链接 | 不能创建跨文件系统的硬链接,因为不同文件系统的数据块结构不同 | 
- 硬链接
 - In 源文件 目标位置
 

- 软链接
 - In -s 源文件或目录 … 链接文件或目标位置
 

3.恢复误删除的文件
3.1 案例:恢复EXT类型的文件
extundelete 是一一个开源的Linux 数据恢复工具,支持ext3、 ext4文件系统。 ( ext4只能在centos6版本恢复)
- 编译安装extundelete软件包 
- 安装依赖包 
- +e2fsprogs-libs-1.41.12-18.el6.x86_64.rpm
 - +e2fsprogs-devel-1.41.12-18.el6.x86_64.rpm
 
 - 配置、编译及安装 
- extundelete-0.2.4.tar.bz2
 
 
 - 安装依赖包 
 - 模拟删除并执行恢复操作
 
模拟过程
 1.使用fdisk创建分区/dev/sdc1, 格式化ext3文件系统
 fdisk /dev/sdc
 partprobe /dev/sdc
 mkfs.ext3 /dev/sdc1
 mkdir /test
 mount /dev/sdc1/test
 df -hT
 2.安装依赖包
 yum -y install e2fsprogs-devel e2fsprogs-libs gcc gcc-c++
 3.编译安装extundelete
 cd /test
 wget http://nchc.dl.sourceforge.net/project/extundelete/extundelete/0.2.4/extundelete-0.2.4.tar.bz2
 tar jxvf extundelete-0.2.4.tar.bz2
 cd extundelete-0.2.4/
 ./configure --prefix=/usr/1ocal/extundelete && make && make install 或
 ./configure && make && make install
 ln -s /usr/local/extundelete/bin/* /usr/bin/
 4.模拟删除并执行恢复操作
 cd /test
 echo a>a
 echo a>b
 echo a>c
 echo a>d
 ls
 extundelete /dev/sdc1 --inode 2 #查看文件系统/dev/sdc1下存在哪些文件,i节点是从2开始的,2代表该文件系统最开始的目录
 rm -rf a b
 extundelete /dev/sdc1 --inode 2
 cd ~
 umount /test
 extundelete /dev/sdc1 --restore-all #恢复/dev/sdc1 文件系统下的所有内容
 在当前目录下会出现一个RECOVERED_FILES/目录,里面保存了已经恢复的文件
 ls RECOVERED FILES/
添加一块硬盘并分512M
 
 
 格式化文件系统
 
 创建一个目录把/dev/sdb1挂载在上面,yum下载e2fsprogs-devel e2fsproges-libs
 
 把extundelete-0.2.1.tar.bz2上传到linux并解压
 
 将extundelete-0.2.1.tar.bz2移动到新建目录下./configure安装,make制作
 
 在hj目录下创建四个文件并输入内容,使用extundelete保存inode号2以后的
 
 删除两个测试文件
 
 使用extundelete查看
 
 
 解除挂载/de/sdb1并查看
 
 使用extundelete恢复数据
 
 切换到extundelete保存的目录下查看删除的文件
 
 接着将文件拷贝到源目录下
3.2 案例:恢复XFS类型的文件
- xfsdump命令格式
 
xfsdump-f +备份存放位置 +要备份的路径或设备文件
- xfsdump备份级别(默认为0) 
- 0:完全备份
 - 1-9:增量备份
 
 - **xfsdump常用选项 ** 
-  
- f 指定备份文件目录
 
 - -L 指定标签session label
 - -M指定设备标签media labe
 - -S 备份单个文件,-s后面不能直接跟路径
 
 -  
 - xfsrestore命令格式
 
xfsrestore -f 恢复文件的位置 存放恢复后文件的位置
- 模拟删除并执行恢复操作
 
模拟过程
 1.使用fdisk创建分区/dev/sdb1,格式化xfs文件系统
 fdisk /dev/sdb 或 partprobe /dev/sdb
 mkfs.xfs /dev/sdb1 或者 mkfs.xfs [-f] /dev/sdb1
 mkdir /data
 mount /dev/sdb1 /data/
 cd /data
 cp /etc/passwd ./
 mkdir test
 touch test/a
 2.使用xfsdump命令备份整个分区
 rpm -qa | grep xfsdump
 yum install -y xfsdump
 xfsdump -f /opt/dump_sdb1 /dev/sdb1 [-L dump_sdb1 -M sdb1]
 xfsdump -f /opt/dump_sdb /dev/sdb1 -L dump_sdb -M sdb1
 3.模拟数据丢失并使用xfsrestore 命令恢复文件
 cd /data/
 rm -rf ./*
 ls
 xfsrestore -f /opt/dump_sdb1 /data/
备份有两种·0·表示完全备份(默认),1-9·表示增量备份呢
 xfsdump.按照·inode·顺序备份·一个·xfs·文件系统
 第二次备份也就是增量备份
 xfsdump .- 1.1 .- f/opt/dump_sdb1_level_1/dev/sdb2 .- L.dump_sdb2_level 1-M.sdb2
使用fdisk创建分区/dev/sdb2,格式化xfs文件系统,挂载在创建的hk目录
 
 

 创建文件在hk目录下
 
 用rpm查看xfsdump是否安装
 
 使用xfsdump命令备份hk目录,并保存在opt下
 
 保存的文件位置 磁盘位置 磁盘
 备份成功提示
 
 备份文件位置
 
 删除文件
 

 查看hk目录确认已删除
 
 恢复备份
 
 成功提示
 
 查看恢复的文件
 
3.2.1 xfsdump使用限制
- 只能备份已挂载的文件系统
 - 必须使用root的权限才能操作
 - 只能备份XFS文件系统
 - 备份后的数据只能让xfsrestore解析
 - 不能备份两个具有相同UUID的文件系统
 
4.分析日志文件
4.1日志文件
4.1.1日志的功能
- 用于记录系统、程序运行中发生的各种事件
 - 通过阅读日志,有助于诊断和解决系统故障
 
4.1.2日志文件的分类
- 内核及系统日志 
- 由系统服务rsyslog统一进行管理,日志格式基本相似
 
 - 用户日志 
- 记录系统用户登录及退出系统的相关信息
 
 - 程序日志 
- 由各种应用程序独立管理的日志文件,记录格式不统一
 
 
4.1.3日志保存位置
- 默认位于:/var/lcg目录下
 
4.1.4主要日志文件介绍
 内核及公共消息日志 · /var/log/messages
 记录Linux内核消息及各种应用程序的公共日志信息,包括启动、IO错误、网络错误、程序故障等,对于未使用独立日志文件的应用程序或服务,一般都可以从该日志文件中获得相关的事件记录信息
计划任务日志 · /var/log/cron
 记录crond计划任务产生的事件信息
系统引导日志 · /var/log/dmesg
 记录Linux系统在引导过程中的各种事件信息
邮件系统日志 · /var/log/maillog
 记录进入或发出系统的电子邮件活动
用户登录日志 · /var/log/lastlog
 记录每个用户最近的登录事件,是二进制格式
 可以用lastlog查看
                                     · /var/log/secure记录用户认证相关的安全事件信息       · /var/log/wtmp记录每个用户登录、注销及系统启动和停机事件,是二进制格式可以用lastlog查看,存放在./var/log/secure· /var/run/btmp记录失败的、错误的登录尝试及验证事件,是二进制格式可以用lastlog查看,存放在./var/log/secure
 
4.2 内核及系统日志
4.2.1 由系统服务 rsyslog 统一管理
- 软件包:rsyslog-7.4.7-16.el7.x86 64
 - 主要程序:/sbin/rsyslogd(服务)
 - 配置文件:/etc/rsyslog.conf
 
4.2.1.1rsyslog服务常用命令
 ps -ef | grep rsyslogd 查看服务是否开启
 grep -v “^$” /etc/rsyslog.conf 过滤掉空行
4.2.1.2自定义日志
 用编辑器配置vim /etc/rsyslog.conf
 
 加入一行内容*.info /var/log/info.log
 
日志中符号
 mail.* 代表比*等级高的都记录,代表任何,也就是说任何日志都记录
 .none 代表不记录日志
 日志存放位置为:所有日志高于这个等级就会对所有在线用户广播
 .=代表只记录=后面级别的日志
 .!代表除了!后面级别的日志不记录其他的都记录
 存放路径之前有“-”代表先放入缓存足够大之后再存放在路径
systemctl restart rsyslog 重启服务之后/var/log下面就生成info.log
 
 用vim编辑器查看
 
 
4.2.2日志消息的级别
 级号 消息 级别 说明
 0 EMERG 紧急 会导致主机系统不可用的情况
 1 ALERT 警告 必须马上采取措施解决的问题
 2 CRIT 严重 比较严重的情况
 3 ERR 错误 运行出现错误
 4 WARNING 错误 可能会影响系统功能的事件
 5 NOTICE 注意 不会影响系统但值得注意
 6 INFO 信息 一般信息
 7 DEBUG 调试 程序或系统调试信息等
4.2.3日志记录的一般格式
 
4.3用户日志分析
4.3.1保存了用户登录、退出系统等相关信息
- /var/log/lastlog:最近的用户登录事件
 - /var/log/wtmp:用户登录、注销及系统开、关机事件
 - /var/run/utmp:当前登录的每个用户的详细信息
 - /var/log/secure:与用户验证相关的安全性事件
 
4.3.2分析工具
- users、who、w、last、lastb(查询登录失败的)
 

4.4 程序日志分析
4.4.1由相应的应用程序独立进行管理
- Web服务:/var/log/httpd/ 
- access_log error_log
 
 
设置httpd的登录和报错日志
 
 serverroot"/etc/httpd"
 
 重启httpd服务查看实时的倒数access_log
 
 查询结果
 
- 代理服务:/var/log/squid/ 
- access.log cache.log
 
 - FTP服务:/var/log/xferlog
 
编译安装不在上面的位置
4.4.2分析工具
- 文本查看、grep过滤检索、Webmin管理套件中查看
 - awk、sed等文本过滤、格式化编辑工具
 - Webalizer、Awstats等专用日志分析工具
 
journalctl工具
 是CentOS-7独有的工具
 Systemd 统一管理所有 Unit 的启动日志。好处就是 ,可以只用journalctl一个命令,查看所有日志(内核日志和 应用日志)
 日志的配置文件/etc/systemd/journald.conf
 ps -ef | grep journald
 journalctl -b 查看本次启动的日志
 journalctl -k 查看内核日志
 journalctl | wc -l 查看系统总共的日志
 journalctl -xe 经常用来查看最近报错的日志
 -e:从结尾开始看
 -x:提供问题相关的网址
 journalctl -u httpd.service 指定服务服务报错
 journalctl -p err 指定日志等级查看级别
4.4.3日志管理策略
- 及时作好备份和归档
 - 延长日志保存期限
 - 控制日志访问权限 
- 日志中可能会包含各类敏感信息,如账户、口令等
 
 - 集中管理日志 
- 将服务器的日志文件发到统一的日志文件服务器
 - 便于日志信息的统一收集、整理和分析
 - 杜绝日志信息的意外丢失、恶意篡改或删除
 
 
将日志文件全部放在日志文件服务器上(集中管理)
 1.rpm -ql rsyslog 查看模块有么有
 2.服务端配置
 [root@localhost ~]#vim /etc/rsyslog.conf
 
 3.编辑文件取消第19 20 行注释允许服务器使用TCP 514端口接收日志 ;开启日志的远程传输功能在192.168.10.19
 19 $ModLoad imtcp
 20 $InputTCPServerRun 514
 
 4.重启rsyslog日志服务
 [root@localhost ~]# systemctl restart rsyslog
 
 5.查看514端口是否开启
 [root@localhost ~]#netstat -ntap |grep 514
 
 6.客户端配置
 [root@www1 ~]# vim /etc/rsyslog.conf
 
 7.修改日志服务配置文件
 90 . @@192.168.72.20:514
 行数 所有 TCP 服务端IP 端口
 
 8.把所有日志采用TCP协议发送到192.168.72.20的514端口上 ; #两个@ 代表使用 tcp 一个代表udp
 [root@localhost ~]# systemctl restart rsyslog
 
 9.客户端创建用户
 
 10.去服务端查看
 
 
相关文章:
liunx文件系统,日志分析
文章目录 1.inode与block1.1 inode与block概述1.2 inode的内容1.3 文件存储1.4 inode的大小1.5 inode的特殊作用 2.硬链接与软链接2.1链接文件分类 3.恢复误删除的文件3.1 案例:恢复EXT类型的文件3.2 案例:恢复XFS类型的文件3.2.1 xfsdump使用限制 4.分析日志文件4.1日志文件4.…...
Apipost接口测试工具的原理及应用详解(二)
本系列文章简介: 随着软件行业的快速发展,API(应用程序编程接口)作为不同软件组件之间通信的桥梁,其重要性日益凸显。API的质量直接关系到软件系统的稳定性、性能和用户体验。因此,对API进行严格的测试成为软件开发过程中不可或缺的一环。在众多API测试工具中,Apipost凭…...
「AIGC」大数据开发语言Scala入门
Scala 是一种多范式编程语言,设计初衷是集成面向对象编程和函数式编程的特点。它运行在 Java 虚拟机(JVM)上,因此可以与 Java 库无缝集成。Scala 也因其在大数据处理领域的应用而受到欢迎,特别是与 Apache Spark 这类框架结合使用。 1. 环境搭建 安装 Scala:可以从 Scala…...
2.1 tmux和vim
文章目录 前言概述tmuxvim总结 前言 开始学习的时间是 2024.7.6 ,13:47 概述 最好多使用,练成条件反射式的 直接使用终端的工具,可以连接到服务器,不需要使用本地的软件 tmux 这个主要有两个功能,第一个功能是分…...
运行vue : 无法加载文件 C:\Program Files\nodejs\node_global\vue.ps1,因为在此系统上禁止运行脚本。
报错背景: 重装了win10系统,然后准备安装Vue,这个时候我已经安装好了node.js和npm,输入node -v和npm -v都有正确输出,但是每次输入npm install -g vue/cli 安装的时候,就会报错. 大家安装node.js的时候最好就是默认路径(C:\Program Files\nodejs),别去修改不然很多报错.(个人…...
Lambda架构
1.Lambda架构对大数据处理系统的理解 Lambda架构由Storm的作者Nathan Marz提出,其设计目的在于提供一个能满足大数据系统关键特性的架构,包括高容错、低延迟、可扩展等。其整合离线计算与实时计算,融合不可变性、读写分离和复杂性隔离等原则&…...
数据库作业day3
创建一个student表用于存储学生信息 CREATE TABLE student( id INT PRIMARY KEY, name VARCHAR(20) NOT NULL, grade FLOAT ); 向student表中添加一条新记录 记录中id字段的值为1,name字段的值为"monkey",grade字段的值为98.5 insert into …...
计算机网络——数据链路层(以太网扩展、虚拟局域网、高速以太网)
在许多情况下,我们希望把以太网的覆盖范围扩展。本节先讨论在物理层把以太网扩展,然后讨论在数据链路层把以太网扩展。这种扩展的以太网在网络层看来仍然是一个网络。 在物理层扩展以太网 现在,扩展主机和集线器之间的距离的一种简单方法就是…...
Nuxt 项目集成第三方UI组件库(九)
Nuxt.js 本身并不提供内置的 UI 组件库,它是一个用于构建服务端渲染(SSR)和静态生成(SSG)Vue.js应用的框架。Nuxt.js 的设计目的是提供基础的架构和配置,以便开发者可以根据自己的需求选择和集成第三方 UI …...
vulnhub靶场之Jarbas
1 信息收集 1.1 主机发现 arp-scan -l 发现主机IP地址为:192.168.1.16 1.2 端口发现 nmap -sS -sV -A -T5 -p- 192.168.1.16 存在端口22,80,3306,8080 1.3 目录扫描 dirsearch -u 192.168.1.16 2 端口访问 2.1 80端口 2.2…...
解决onlyoffice警告的一些思路
解决思路: 1、监听出现警告的事件:已经实现 <script setup> import {message} from "ant-design-vue";const onError (event) > {console.log("ONLYOFFICE Document Editor reports an error: code " event.data.error…...
快速上手指南:使用 Minikube 在本地运行 Kubernetes 集群
前言 Minikube 是一个开源工具,用于在本地运行 Kubernetes 集群。它提供了一种简单的方法来在本地开发和测试 Kubernetes 应用程序,而无需设置完整的 Kubernetes 集群。以下是 Minikube 的基本使用步骤: 安装 Minikube 安装依赖项 虚拟化…...
【C语言】指针(1):入门理解篇
目录 一、内存和地址 1.1内存 1.2 深入理解计算机编址 二、指针变量和地址 2.1 取地址操作符(&) 2.2 指针变量和解应用操作符 2.2.1 指针变量 2.2.2 解引用操作符 2.3指针变量的大小 三、指针变量类型的意义 3.1 指针的解引用 3.1指针-整数…...
经典双运算放大器LM358
前言 LM358双运放有几十年的历史了吧?通用运放,很常用,搞电路的避免不了接触运放,怎么选择运放,是工程师关心的问题吧? 从本文开始,将陆续发一些常用的运放,大家选型可以参考&#…...
adb不插usb线通过wifi调试
说起做手机开发也有好多年了,说来惭愧,我最近才知道安卓手机是可以不插数据线进行开发调试的。起因是公司近期采购了一批安卓一卡通设备,需要对其进行定制开发APP,但是由于我插USB调试发现没有反应。通过询问厂家才知道可以通过WIFI进行调试。…...
vulnhub--IMF
环境 攻击机:192.168.96.4 靶机:ip未知 主机探测 确定靶机ip为32的主机 端口扫描 访问80端口 外围打点 在contact.php页面源码中找到了flag1 之后没啥突破 但查看网络后发现contact.php页面请求的三个js文件的文件名很有特点,猜测是base64编码…...
ePTFE膜(膨体聚四氟乙烯膜)应用前景广阔 本土企业技术水平不断提升
ePTFE膜(膨体聚四氟乙烯膜)应用前景广阔 本土企业技术水平不断提升 ePTFE膜全称为膨体聚四氟乙烯膜,指以膨体聚四氟乙烯(ePTFE)为原材料制成的薄膜。ePTFE膜具有耐化学腐蚀、防水透气性好、耐候性佳、耐磨、抗撕裂等优…...
C++与C#创建位图,是否需要区分RGB和BGR模式
在处理位图时,确实需要区分RGB和BGR模式,因为不同的库和API对颜色通道的排序有不同的约定。具体到C与C#,这一点也是需要注意的。 C 创建位图 使用GDI或WIC (Windows Imaging Component): 当你在C中使用这些Windows API创建或操作位图时&…...
web学习笔记(八十)
目录 1.小程序实现微信一键登录 2. 小程序的授权流程 3.小程序配置vant库 4.小程序配置分包 5.小程序配置独立分包 6.小程序分包预下载 1.小程序实现微信一键登录 要先实现小程序一键登录首先我们需要给按钮设置一个绑定事件,然后在绑定事件内部通过wx.login…...
深度解析 Raft 分布式一致性协议
本文参考转载至:浅谈 Raft 分布式一致性协议|图解 Raft - 白泽来了 - 博客园 (cnblogs.com) 深度解析 Raft 分布式一致性协议 - 掘金 (juejin.cn) raft-zh_cn/raft-zh_cn.md at master maemual/raft-zh_cn (github.com) 本篇文章将模拟一个KV数据读写服…...
【Axure高保真原型】引导弹窗
今天和大家中分享引导弹窗的原型模板,载入页面后,会显示引导弹窗,适用于引导用户使用页面,点击完成后,会显示下一个引导弹窗,直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…...
华为云AI开发平台ModelArts
华为云ModelArts:重塑AI开发流程的“智能引擎”与“创新加速器”! 在人工智能浪潮席卷全球的2025年,企业拥抱AI的意愿空前高涨,但技术门槛高、流程复杂、资源投入巨大的现实,却让许多创新构想止步于实验室。数据科学家…...
Golang 面试经典题:map 的 key 可以是什么类型?哪些不可以?
Golang 面试经典题:map 的 key 可以是什么类型?哪些不可以? 在 Golang 的面试中,map 类型的使用是一个常见的考点,其中对 key 类型的合法性 是一道常被提及的基础却很容易被忽视的问题。本文将带你深入理解 Golang 中…...
P3 QT项目----记事本(3.8)
3.8 记事本项目总结 项目源码 1.main.cpp #include "widget.h" #include <QApplication> int main(int argc, char *argv[]) {QApplication a(argc, argv);Widget w;w.show();return a.exec(); } 2.widget.cpp #include "widget.h" #include &q…...
镜像里切换为普通用户
如果你登录远程虚拟机默认就是 root 用户,但你不希望用 root 权限运行 ns-3(这是对的,ns3 工具会拒绝 root),你可以按以下方法创建一个 非 root 用户账号 并切换到它运行 ns-3。 一次性解决方案:创建非 roo…...
第一篇:Agent2Agent (A2A) 协议——协作式人工智能的黎明
AI 领域的快速发展正在催生一个新时代,智能代理(agents)不再是孤立的个体,而是能够像一个数字团队一样协作。然而,当前 AI 生态系统的碎片化阻碍了这一愿景的实现,导致了“AI 巴别塔问题”——不同代理之间…...
相机从app启动流程
一、流程框架图 二、具体流程分析 1、得到cameralist和对应的静态信息 目录如下: 重点代码分析: 启动相机前,先要通过getCameraIdList获取camera的个数以及id,然后可以通过getCameraCharacteristics获取对应id camera的capabilities(静态信息)进行一些openCamera前的…...
什么是EULA和DPA
文章目录 EULA(End User License Agreement)DPA(Data Protection Agreement)一、定义与背景二、核心内容三、法律效力与责任四、实际应用与意义 EULA(End User License Agreement) 定义: EULA即…...
精益数据分析(97/126):邮件营销与用户参与度的关键指标优化指南
精益数据分析(97/126):邮件营销与用户参与度的关键指标优化指南 在数字化营销时代,邮件列表效度、用户参与度和网站性能等指标往往决定着创业公司的增长成败。今天,我们将深入解析邮件打开率、网站可用性、页面参与时…...
Device Mapper 机制
Device Mapper 机制详解 Device Mapper(简称 DM)是 Linux 内核中的一套通用块设备映射框架,为 LVM、加密磁盘、RAID 等提供底层支持。本文将详细介绍 Device Mapper 的原理、实现、内核配置、常用工具、操作测试流程,并配以详细的…...
