文本匹配.grep与Select-String用法对比

news2025/1/12 20:40:35
Linux Shell与PowerShell上匹配字符串
grep与Select-String用法对比

- 文章信息 - Author: 李俊才 (jcLee95)
Visit me at CSDN: https://jclee95.blog.csdn.net
My WebSitehttp://thispage.tech/
Email: 291148484@163.com.
Shenzhen China
Address of this article:https://blog.csdn.net/qq_28550263/article/details/139253970
HuaWei:https://bbs.huaweicloud.com/blogs/428150

【介绍】:grep用于在 Linux 和其他类 Unix 系统中搜索文本。Select-String 是 PowerShell 中用于搜索和匹配文本的cmdlet。它提供了类似于 grep 的功能。现在将两者放在一起做个总结。

在这里插入图片描述


1. 用法简介

在文本搜索方面,Linux 和 PowerShell 提供了各自强大的工具。grep 是 Linux 中用于搜索文本的命令行工具,而 Select-String 是 PowerShell 中用于搜索文本的 cmdlet,功能类似于 grep

1.1 grep 命令

grep(Global Regular Expression Print)用于在 Linux 和其他类 Unix 系统中搜索文本。它可以在一个或多个文件中查找包含指定模式的行,并将匹配的行输出到标准输出。grep 支持正则表达式,提供了多种选项来控制搜索行为和输出格式。

grep 命令的基本格式如下:

grep [OPTIONS] PATTERN [FILE...]

其中,OPTIONS 表示可选的命令行选项,PATTERN 表示要搜索的模式(可以是普通字符串或正则表达式),FILE 表示要搜索的一个或多个文件。如果未指定文件,grep 将从标准输入读取文本。

1.2 Select-String 命令

Select-StringPowerShell 中用于搜索和匹配文本的 cmdlet。它提供了类似于 grep 的功能,可以在文件、字符串或管道输入中查找指定的模式。Select-String 支持正则表达式和通配符,并提供了各种参数来控制搜索行为和输出格式。

Select-String 命令的基本格式如下:

Select-String [-Path] <string[]> [-Pattern] <string[]> [-AllMatches] [-CaseSensitive] [-Context <Int32[]>] [-Encoding <string>] [-Exclude <string[]>] [-Include <string[]>] [-List] [-NotMatch] [-Quiet] [-SimpleMatch] [<CommonParameters>]

Select-String -InputObject <psobject> [-Pattern] <string[]> [-AllMatches] [-CaseSensitive] [-Context <Int32[]>] [-Encoding <string>] [-Exclude <string[]>] [-Include <string[]>] [-List] [-NotMatch] [-Quiet] [-SimpleMatch] [<CommonParameters>]

其中:

  • -Pattern 参数指定要搜索的模式(可以是普通字符串或正则表达式);
  • -Path 参数指定要搜索的一个或多个文件。

Select-String 还提供了其他参数,如 -SimpleMatch(简单字符串匹配)、-CaseSensitive(区分大小写)、-Quiet(仅返回布尔值)等,用于控制搜索行为和输出格式。

2. grep详细用法与示例

2.1 基本用法

Linux上,grep命令用于在每个文件中搜索指定的模式。其基本使用格式为:

grep [选项]... 模式 [文件]...

grep命令会在指定的文件中查找匹配的模式,并输出包含该模式的行。如果未指定文件,grep会从标准输入读取数据。

例如,下面的命令在menu.hmain.c文件中搜索不区分大小写的字符串“hello world”:

grep -i 'hello world' menu.h main.c

在这个例子中:

  • -i选项表示忽略大小写,因此Hello, HELLO,或hello都能匹配模式hello world
  • 'hello world'是要搜索的模式。
  • menu.hmain.c是要搜索的文件。

这条命令会输出包含“hello world”的所有行,无论这些行中的“hello world”是大写、小写还是混合大小写。

2.2 模式

其中,模式可以包含多个由换行符分隔的模式。模式选择及其解释如下:

  -E, --extended-regexp     模式为扩展正则表达式
  -F, --fixed-strings       模式为字符串
  -G, --basic-regexp        模式为基本正则表达式
  -P, --perl-regexp         模式为Perl正则表达式
  -e, --regexp=模式         使用指定的模式进行匹配
  -f, --file=文件           从文件中获取模式
  -i, --ignore-case         忽略模式和数据中的大小写区别
      --no-ignore-case      不忽略大小写区别(默认)
  -w, --word-regexp         仅匹配整个单词
  -x, --line-regexp         仅匹配整个行
  -z, --null-data           数据行以0字节结束,而不是换行符
杂项:
  -s, --no-messages         抑制错误消息
  -v, --invert-match        选择不匹配的行
  -V, --version             显示版本信息并退出
      --help                显示此帮助文本并退出

【注】:在接下来的示例中,输出结果中的颜色是由 grep 命令自动添加的,用于突出显示匹配的部分。这是 grep 的一个特性,称为 “颜色输出”。
当在终端中运行 grep 命令时,它会自动检测是否支持颜色输出,并相应地着色。
可以参考2.4.3小节。

2.2.1 例:使用扩展正则表达式

使用-E选项,可以使用扩展正则表达式。

例如,以下命令会在file.txt中搜索匹配任意一个字母后跟一个数字的字符串:

grep -E '[a-zA-Z][0-9]' file.txt

再如,搜索包含一个到三个’a’字符的模式。

echo "aaa abbb aaaa" | grep -E 'a{1,3}'

输出为:
在这里插入图片描述

在输出结果 “aaa abbb aaaa” 中:

  • 第一部分 “aaa” 匹配正则表达式,因为它包含连续的三个 ‘a’ 字符,所以显示为红色;

  • 第二部分 “abbb” 不匹配正则表达式,因为 ‘a’ 后面没有连续的 ‘a’ 字符,所以显示为白色。

  • 第三部分 “aaaa” 匹配正则表达式,因为它包含连续的四个 ‘a’ 字符,前三个 ‘a’ 匹配,所以前三个 ‘a’ 显示为红色,剩下的 ‘a’ 显示为白色。

2.2.2 例:将模式视为固定字符串

搜索包含确切字符串’a*b’的行。

echo "a*b a b" | grep -F 'a*b'

结果为:
在这里插入图片描述

2.2.3 例:从文件中获取模式

echo "hello" > patterns.txt
echo "world" >> patterns.txt
echo "hello world" | grep -f patterns.txt

2.2.4 例:忽略大小写

echo "Hello WORLD" | grep -i 'hello'

结果为:

在这里插入图片描述

2.2.5 例: 选择不匹配的行

echo "hello world
hello universe
goodbye world
hello hello" | grep -v 'hello'

在这个例子中,我们使用 echo 命令生成了一个包含多行文本的字符串,每行文本之间用换行符 \n 分隔。然后,我们使用管道将这个多行文本传递给 grep -v 'hello' 命令。

-v 选项表示 “反转匹配”,即选择不包含指定模式的行。在这里,grep -v 'hello' 会输出所有不包含 “hello” 的行。

输出结果为:

goodbye world

2.2.6 例: 匹配整行

-x 选项用于匹配整行,即只有当整行完全匹配指定的模式时才会被选中。例如:

echo "hello
hello world
world
hello hello" | grep -x 'hello'

输出结果为:

hello

在这个例子中,我们使用 echo 命令生成了一个包含多行文本的字符串,每行文本之间用换行符 \n 分隔。然后,我们使用管道将这个多行文本传递给 grep -x 'hello' 命令。

-x 选项表示 “匹配整行”,即只有当一行文本完全匹配指定的模式时才会被选中。在这里,grep -x 'hello' 会输出完全匹配 “hello” 的行。

其中,只有第 1 行完全匹配 “hello”,所以被选中并输出。其他行虽然包含 “hello”,但并不是完全匹配,所以被过滤掉了。

2.3 输出控制

grep命令中也可以通过下面的选项对输出内容进行控制:

  -m, --max-count=NUM       在选择NUM行后停止
  -b, --byte-offset         打印输出行的字节偏移量
  -n, --line-number         打印输出行的行号
      --line-buffered       在每行后刷新输出
  -H, --with-filename       打印输出行的文件名
  -h, --no-filename         输出时不显示文件名前缀
      --label=LABEL         使用LABEL作为标准输入文件名前缀
  -o, --only-matching       仅显示匹配的非空部分
  -q, --quiet, --silent     抑制所有正常输出
      --binary-files=TYPE   假定二进制文件为TYPE;
                            TYPE可以是'binary'(二进制)、'text'(文本)或'without-match'(无匹配)
  -a, --text                等同于--binary-files=text
  -I                        等同于--binary-files=without-match
  -d, --directories=ACTION  如何处理目录;
                            ACTION可以是'read'(读取)、'recurse'(递归)或'skip'(跳过)
  -D, --devices=ACTION      如何处理设备、FIFO和套接字;
                            ACTION可以是'read'(读取)或'skip'(跳过)
  -r, --recursive           等同于--directories=recurse
  -R, --dereference-recursive  同样,但跟随所有符号链接
      --include=GLOB        仅搜索匹配GLOB(文件模式)的文件
      --exclude=GLOB        跳过匹配GLOB的文件
      --exclude-from=FILE   跳过匹配FILE中的任何文件模式的文件
      --exclude-dir=GLOB    跳过匹配GLOB的目录
  -L, --files-without-match  仅打印没有选中行的文件名
  -l, --files-with-matches  仅打印有选中行的文件名
  -c, --count               每个文件仅打印选中行的计数
  -T, --initial-tab         对齐制表符(如有需要)
  -Z, --null                在文件名后打印0字节

2.3.1 例: 限制输出行数

seq 10 | grep -m 3 -E '[0-9]'

输出结果为:

1
2
3

在这个例子中,我们使用seq命令生成1到10的整数序列,然后通过管道传递给grep -m 3 -E '[0-9]'命令。

-m 3选项表示最多输出匹配的前3行. -E '[0-9]'使用正则表达式匹配所有包含数字的行。

2.3.2 例: 显示匹配内容的字节偏移

echo "hello world" | grep -b 'world'

输出结果为:

hello world

在这里插入图片描述

-b选项会在输出的每一行前面显示该行在原始输入中的字节偏移量。在这个例子中,"world"在输入字符串中的起始字节位置为6。

2.3.3 例: 显示行号

seq 10 | grep -n -E '[24680]$' 

-n选项会在输出的每一行前面显示该行在原始输入中的行号. 在这个例子中,我们匹配所有以偶数结尾的行。输出结果为:

2:2
4:4
6:6
8:8
10:10

在这里插入图片描述

2.4 上下文控制

上下文控制是指在输出匹配行的同时,也输出匹配行前后的一些行作为上下文,以便更好地理解匹配行在原始文本中的位置和含义。grep提供了一些选项来控制输出的上下文行数和格式。

  -B, --before-context=NUM  打印匹配前NUM行的上下文
  -A, --after-context=NUM   打印匹配后NUM行的上下文
  -C, --context=NUM         打印匹配前后各NUM行的上下文
  -NUM                      等同于--context=NUM
      --group-separator=SEP  在带有上下文的匹配行之间打印分隔符SEP
      --no-group-separator  不打印带有上下文的匹配行的分隔符
      --color[=WHEN],
      --colour[=WHEN]       使用标记突出显示匹配的字符串;
                            WHEN可以是'always'(总是)、'never'(从不)或'auto'(自动)
  -U, --binary              不去除行尾的CR字符(MSDOS/Windows)

2.4.1 例: 输出匹配行前后的行作为上下文

seq 10 | grep -A 2 -B 2 '5'
  • -A 2选项表示输出匹配行后的2行作为上下文;
  • -B 2选项表示输出匹配行前的2行作为上下文;
    因此,这个命令会输出匹配行'5'以及它前后各2行。输出结果为:
3
4
5
6
7

在这里插入图片描述

2.4.2 例: 使用-C选项控制上下文行数

seq 10 | grep -C 1 '5'

-C 1选项等同于-A 1 -B 1,表示输出匹配行前后各1行作为上下文。出结果为:

4
5
6

在这里插入图片描述

2.4.3 例: 使用–color选项高亮匹配的字符串

--color=always选项会使用标记突出显示匹配的字符串,以便更容易识别匹配的位置。例如:

echo "Hello World" | grep --color=always 'World'

你可以尝试在终端中运行这个命令,看看’World’是否被高亮显示:

在这里插入图片描述

3. Select-String详细用法与示例

Select-String 是 PowerShell 中用于搜索和匹配文本的cmdlet。它提供了类似于 grep 的功能,可以在文件、字符串或管道输入中查找指定的模式。Select-String 支持正则表达式和通配符,并提供了各种参数来控制搜索行为和输出格式。

3.1 格式与参数

Select-String的基本格式如下:

Select-String [-Path] <string[]> [-Pattern] <string[]> [-AllMatches] [-CaseSensitive] [-Context <Int32[]>] [-Encoding <string>] [-Exclude <string[]>] [-Include <string[]>] [-List] [-NotMatch] [-Quiet] [-SimpleMatch] [<CommonParameters>]

Select-String -InputObject <psobject> [-Pattern] <string[]> [-AllMatches] [-CaseSensitive] [-Context <Int32[]>] [-Encoding <string>] [-Exclude <string[]>] [-Include <string[]>] [-List] [-NotMatch] [-Quiet] [-SimpleMatch] [<CommonParameters>]

3.2 用法示例

3.2.1 例: 在文件中搜索模式

Select-String -Pattern 'hello' -Path 'file.txt'

file.txt 文件中搜索包含 “hello” 的行。

3.2.2 例: 在文件中搜索模式

"hello world", "hello universe", "goodbye world" | Select-String -Pattern 'hello'

在给定的字符串数组中搜索包含 “hello” 的行。输出结果为:
在这里插入图片描述

3.2.3 例: 区分大小写

通过 -CaseSensitive 选项可以指定是否区分大小写。默认情况下,Select-String 不区分大小写,这意味着它会匹配模式的任何大小写组合。使用 -CaseSensitive 选项可以强制 Select-String 进行区分大小写的匹配。

"Hello world", "hello universe" | Select-String -Pattern 'hello' -CaseSensitive

在这里插入图片描述

3.2.4 例: 简单字符串匹配

"hello*world", "hello world" | Select-String -Pattern 'hello*world' -SimpleMatch

3.2.5 例: 简单字符串匹配

通过 -SimpleMatch 选项可以指定 Select-String 进行简单字符串匹配,而不是使用正则表达式。默认情况下,Select-String 会将模式解释为正则表达式。如果你希望进行简单的字符串匹配,可以使用 -SimpleMatch 选项。例如:

"hello*world", "hello world" | Select-String -Pattern 'hello*world' -SimpleMatch

输出结果为:

hello*world

在这个例子中,我们有一个包含两行文本的字符串数组:

  1. “hello*world”

  2. “hello world”

我们使用管道将这个字符串数组传递给 Select-String 命令,并指定 -Pattern 'hello*world'-SimpleMatch 选项。

  • -Pattern 'hello*world' 指定要搜索的模式是 “hello*world”。

  • -SimpleMatch 选项指示 Select-String 进行简单字符串匹配,而不是将模式解释为正则表达式。

由于 -SimpleMatch 选项的作用,Select-String 会将模式 “helloworld" 作为一个普通字符串进行匹配。因此,只有第一行 "helloworld” 会被匹配并输出,因为它完全包含了字符串 “hello*world”。第二行 “hello world” 不会被匹配,因为它不包含星号 *

3.2.6 例: 显示匹配的上下文行

通过 -Context 选项可以指定在输出中显示匹配行的前后上下文行。这在需要查看匹配行周围的内容时非常有用。

"line1", "line2 hello", "line3", "line4 hello", "line5" | Select-String -Pattern 'hello' -Context 1,1

输出结果为:

  line1
> line2 hello
  line3
> line4 hello
  line5

在这里插入图片描述

在这个例子中,我们有一个包含多行文本的字符串数组:

  1. “line1”
  2. “line2 hello”
  3. “line3”
  4. “line4 hello”
  5. “line5”

我们使用管道将这个字符串数组传递给 Select-String 命令,并指定 -Pattern ‘hello’ 和 -Context 1,1 选项。

-Pattern ‘hello’ 指定要搜索的模式是 “hello”。

-Context 1,1 选项指示 Select-String 显示每个匹配行的前一行和后一行。

由于 -Context 1,1 选项的作用,Select-String 会输出包含 “hello” 的行以及每个匹配行的前一行和后一行。

3.2.7 例: 搜索多个模式

通过 -Pattern 选项可以指定多个模式进行搜索。Select-String 会匹配任意一个指定的模式。

"hello world", "goodbye world" | Select-String -Pattern 'hello', 'goodbye'

搜索结果为:

hello world
goodbye world

在这里插入图片描述

在这个例子中,我们有一个包含两行文本的字符串数组: "hello world"和 “goodbye world”。

我们使用管道将这个字符串数组传递给 Select-String 命令,并指定 -Pattern 'hello', 'goodbye' 选项。

  • -Pattern 'hello', 'goodbye' 指定要搜索的模式是 “hello” 或 “goodbye”。

由于 -Pattern 选项的作用,Select-String 会输出包含 “hello” 或 “goodbye” 的行。

3.2.8 例: 只返回第一个匹配项

通过 -List 选项可以指定 Select-String 只返回每个输入中的第一个匹配项。这在你只关心第一个匹配结果时非常有用。

假设我们有两个文件 file1.txtfile2.txt,它们的内容如下:

file1.txt:

hello world
hello universe

file2.txt:

goodbye world
hello again

我们可以使用以下命令来搜索这两个文件,并只返回每个文件中的第一个匹配项:

Select-String -Pattern 'hello' -Path 'file1.txt', 'file2.txt' -List

输出结果为:

file1.txt:1:hello world
file2.txt:2:hello again

在这里插入图片描述

在这个例子中,Select-String 搜索 file1.txtfile2.txt 中包含 “hello” 的行,并使用 -List 选项只返回每个文件中的第一个匹配项。

3.2.9 例: 在指定编码的文件中搜索

Select-String -Pattern 'hello' -Path 'file.txt' -Encoding UTF8

在这个例子中,我们在名为 file.txt 的文件中搜索包含 “hello” 的行,并指定文件的编码为 UTF8。

  • -Pattern 'hello' 指定要搜索的模式是 “hello”。

  • -Path 'file.txt' 指定要搜索的文件是 file.txt。

  • -Encoding UTF8 选项指示 Select-String 使用 UTF8 编码来读取文件。

假设 file.txt 的内容如下:

hello world
goodbye world

运行上述命令的输出结果为:

file.txt:1:hello world

在这里插入图片描述

这个例子展示了如何使用 -Encoding 选项来在指定编码的文件中搜索。在处理不同编码的文件时,这可以确保 Select-String 正确读取文件内容并进行搜索。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Lin网络二

目录 根据域名查找出IP地址的流程&#xff1a; DNS域名的功能&#xff1a; 正向解析&#xff1a; 反向解析&#xff1a; DNS的端口&#xff1a; DNS域名解析工作原理&#xff1a; DNS域名解析查询方式&#xff1a; 递归查询&#xff1a;&#xff08;简单来说就是将DNS解…

ICML 2024 | 北大、字节提出新型双层位置编码方案,有效改善长度外推效果

在这项工作中&#xff0c;我们利用语言序列的内在分段特性&#xff0c;设计了一种新的位置编码方法来达到更好的长度外推效果&#xff0c;称为双层位置编码&#xff08;BiPE&#xff09;。对于每个位置&#xff0c;我们的 BiPE 融合了段内编码和段间编码。段内编码通过绝对位置…

LOTO示波器软件新增导览功能

新版本的大部分型号LOTO示波器的上位机软件我们改成了导航工具条方式。原来的方式是把所有功能都显示在不同的标签页中&#xff0c;这样的优点是非常快捷方便&#xff0c;基本上用鼠标一两次点击就能直达想要的功能设置。但是缺点是不熟练的客户可能记不住各种功能的标签位置在…

安全攻防三

一、IDS: 当黑客绕过了防火墙&#xff0c;你该如何发现&#xff1f; IDS &#xff08;Intrusion Detection System&#xff0c;入侵检测系统&#xff09; NIDS 内网中检测网络流量攻击 黑客如果已经进去内网&#xff0c;防火墙就没办法保护了 NIDS部署在交换机和路由器这些路…

曲线拟合工具软件(免费)

曲线拟合是数据处理中经常用到的数值方法,本质是使用某一个模型(方程或者方程组)将一系列离散的数据拟合成平滑的曲线或者曲面,数值求解出对应的函数参数,大家可以利用MATLAB的曲线拟合工具箱也可以使用第三方的拟合软件,今天我们介绍Welsim免费的曲线拟合软件 1、MATLA…

视频技术在智慧营业厅中的应用:AI识别与智能化转型

一、方案背景 随着信息技术的快速发展&#xff0c;图像和视频分析技术已广泛应用于各行各业&#xff0c;特别是在营业厅场景中&#xff0c;该技术能够有效提升服务质量、优化客户体验&#xff0c;并提高安全保障水平。TSINGSEE青犀智慧营业厅视频管理方案旨在探讨视频监控和视…

Kafka之【存储消息】

数据已经由生产者Producer发送给Kafka集群&#xff0c;当Kafka接收到数据后&#xff0c;会将数据写入本地文件中。 存储组件 Kafka 的消息存储涉及多个关键组件&#xff0c;每个组件在消息的存储和管理过程中扮演着特定的角色。以下是 Kafka 存储消息过程中涉及的主要存储组件及…

linux--实时性优化

linux--实时性优化 1 介绍2 实时性需求3 代表性实时系统4 嵌入式系统嵌入式软件系统结构处理器时钟节拍多任务机制任务调度方式任务调度算法时间片调度算法优先级调度算法基于优先级的时间片调度算法 5 cyclictest 测试工具命令说明 6 linux 实时性改进某版本上发布实时补丁或者…

(三)MySQL 索引

欢迎访问 什么是索引&#xff1f; 提高查询效率的一种数据结构&#xff0c;索引是数据的目录 索引的分类 按「数据结构」分类&#xff1a;Btree索引、Hash索引、Full-text索引。按「物理存储」分类&#xff1a;聚簇索引、二级索引。按「字段特性」分类&#xff1a;主键索引…

JavaScript: Uncaught SyntaxError: Invalid or unexpected token

好久没有碰前端的代码了。。。 今天测试WebSocket功能&#xff0c;Client端&#xff1a;使用HtmlJavaScript&#xff0c;通过浏览器解析后&#xff0c;当做客户端&#xff1b; 客户端代码如下&#xff1a; <!DOCTYPE html> <html lang"en"><head&g…

装饰模式:鸡腿堡

文章目录 UML类图目录结构Humburger.javaChickenBurger.javaCondiment.javaChuilli.javaLettuce.javaTest.java深度理解test怎么写 UML类图 目录结构 我们从指向最多的开始写 Humburger.java package zsms;public abstract class Humburger {protected String name;public S…

学至乎没而后止也

开场白 学至后没而后止也这个题目的原话来自与荀子《劝学》。大家知道什么意思吗&#xff1f;学习要学到你人没了&#xff0c;才算停止了。通俗点说就是只要没学死就往死里学&#xff0c;高雅点说就是要保持终身学习。 在以前说终身学习好像是一种良好习惯或品德&#xff0c;…

AIGC 009-DaLLE2遇见达利!文生图过程中另外一种思路。

AIGC 009-DaLLE2遇见达利&#xff01;文生图过程中另外一种思路。 0 论文工作 首先&#xff0c;遇见达利是我很喜欢的名字&#xff0c;达利是跟毕加索同等优秀的画家。这个名字就很有意思。 这篇论文提出了一种新颖的分层文本条件图像生成方法&#xff0c;该方法利用 CLIP&…

C语言笔记20 •整数和浮点数在内存中存储•

整数和浮点数在内存中存储 1.整数在内存中存储 整数在内存中存储比较简单&#xff0c;整数存储分为正整数存储和负整数存储。 对于有符号整数 符号位中0表示正整数&#xff0c;1表示负整数。 正整数在内存中存储&#xff1a; 正整数原码&#xff0c;反码 &#xff0c;补码…

这款网站测试工具,炫酷且强大!【送源码】

随着互联网的普及和发展&#xff0c;Web 应用程序的数量也越来越多&#xff0c;各种网络问题也是层出不穷&#xff0c;因而监测这些 Web 应用程序的性能和可用性变得非常重要。 今天的文章&#xff0c;了不起和大家分享一款十分好用的的网站分析项目 - Web-Check。 项目简介 …

MemoryDB 2024 论文分享

论文地址点这里。 TL;DR MemoryDB 通过底层依赖 AWS 内部系统 Multi-AZ Transaction Log 实现了 11 个 9 的持久性保证。 通过依赖 Transaction Log 的 Condition API 和租约机制来实现了一致性和可用性保证。 通过周期性调度 Off-box 节点来外部 Rewrite binlog 避免了内存…

FastReport 主子表关系

代码中只需要绑定主表的数据就可以&#xff0c;子表的数据会通过报表中的关连关系自动到数据库中带出。 using CloudSaaS.DB.Handler; using CloudSaaS.Model; using CloudSaaS.DAL; using FastReport; using FastReport.Web; using System; using System.Collections.Generic;…

Llama模型家族训练奖励模型Reward Model技术及代码实战(一)

LlaMA 3 系列博客 基于 LlaMA 3 LangGraph 在windows本地部署大模型 &#xff08;一&#xff09; 基于 LlaMA 3 LangGraph 在windows本地部署大模型 &#xff08;二&#xff09; 基于 LlaMA 3 LangGraph 在windows本地部署大模型 &#xff08;三&#xff09; 基于 LlaMA…

安全术语 | 软件包purl详解:跨工具、数据库、API和语言之间可靠地识别和定位软件包

软件包URL&#xff08;purl&#xff0c;Package URL&#xff09;是一个URL字符串&#xff0c;用于在编程语言、包管理器、包约定、工具、API和数据库中以最通用和统一的方式识别和定位软件包。purl是对现有方法进行标准化的尝试&#xff0c;以可靠地识别和定位软件包。 有望取代…

服务案例|网络攻击事件的排查与修复

LinkSLA智能运维管家V6.0版支持通过SNMP Trap对设备进行监控告警&#xff0c;Trap是一种主动推送网络设备事件或告警消息的方式&#xff0c;与SNMP轮询&#xff08;polling&#xff09;不同&#xff0c;具有以下几点优势&#xff1a; 1. 实时监控与快速响应 SNMP Trap能够实时…