【基于 GitLab 的 CI/CD 实践】03、GitLab Pipeline 实践(上)

news2025/1/24 11:42:27

目录

一、GitLab Pipeline 流水线语法有哪些?流水线参数列表

如何检查语法错误?流水线语法检测

二、Pipeline 基础语法

job

script

before_script

after_script

stages

未定义 stages

​定义 stages 控制 stage 运行顺序  

.pre & .post

stage

variables

综合实例(一)

tags

allow_failure

when

manual 手动

delayed 延迟

实验 demo

retry-重试

实验

timeout 超时

项目设置流水线超时时间

runner 超时时间

parallel-并行作业

综合实例(二)

only & except-限制分支标签

rules-构建规则

rules:if

rules:changes

rules:exists

rules:allow_failure

workflow:rules

综合实例(三)


 

一、GitLab Pipeline 流水线语法有哪些?流水线参数列表

KeywordDescription
script运行的 Shell 命令或脚本。
image使用 docker 映像。
services使用 docker 服务映像。
before_script在作业运行前运行脚本。
after_script在作业运行后运行脚本。
stages定义管道中的阶段,运行顺序。
stage为job定义一个阶段,可选,未指定默认为test阶段。
only限制创建作业的条件。
except限制未创建作业的条件。
rules条件列表,用于评估和确定作业的选定属性,以及是否创建该作业。不能 only与/ except一起使用。
tags用于选择 Runner 的标签列表。
allow_failure允许作业失败,失败的 job 不会影响提交状态。
when什么时候开始运行工作。
environment作业部署到的环境的名称。
cache在后续运行之间应缓存的文件列表。
artifacts成功时附加到作业的文件和目录列表。
dependencies通过提供要从中获取工件的作业列表,限制将哪些工件传递给特定作业。
retry发生故障时可以自动重试作业的时间和次数。
timeout定义自定义作业级别的超时,该超时优先于项目范围的设置。
parallel多个作业并行运行。
trigger定义下游管道触发。
include允许此作业包括外部 YAML 文件。
extends该作业将要继承的配置条目。
pages上载作业结果以用于 GitLab 页面。
variables在作业级别上定义作业变量。

如何检查语法错误?流水线语法检测

        GitLab CI 的每个实例都有一个称为 Lint 的嵌入式调试工具,该工具可以验证 .gitlab-ci.yml 文件的内容.。

二、Pipeline 基础语法

job

在每个项目中,我们使用名为 .gitlab-ci.yml 的 YAML 文件配置 GitLab CI / CD 管道。

  • 可以定义一个或多个作业(job)。

  • 每个作业必须具有唯一的名称(不能使用关键字)。

  • 每个作业是独立执行的。

  • 每个作业至少要包含一个 script。

job1:
  script: "execute-script-for-job1"

job2:
  script: "execute-script-for-job2"

注释: 这里在 pipeline 中定义了两个作业,每个作业运行不同的命令。命令可以是 shell 或脚本。

script

每个作业(job)至少要包含一个 script。

job:
  script:
    - uname -a
    - bundle exec rspec

注意:有时,script 命令将需要用单引号或双引号引起来. 例如,包含冒号命令( : )需要加引号,以便被包裹的 YAML 解析器知道来解释整个事情作为一个字符串,而不是一个"键:值"对。使用特殊字符时要小心::{}[], &* #?|-< >= !% @ .  

before_script

        用于定义一个命令,该命令在每个作业之前运行。必须是一个数组。指定的 script 与主脚本中指定的任何脚本串联在一起,并在单个 shell 中一起执行。 

        before_script 失败会导致整个作业失败,其他作业将不再执行。作业失败不会影响 after_script 运行。

after_script

        用于定义将在每个作业(包括失败的作业)之后运行的命令。这必须是一个数组。指定的脚本在新的 shell 中执行,与任何 before_script 或 script 脚本分开。可以在全局定义,也可以在 job 中定义,在 job 中定义会覆盖全局。

before_script:
  - echo "before-script!!"

variables:
  DOMAIN: example.com

stages:
  - build
  - deploy
 

build:
  before_script:
    - echo "before-script in job"
  stage: build
  script:
    - echo "mvn clean "
    - echo "mvn install"
  after_script:
    - echo "after script in job"


deploy:
  stage: deploy
  script:
    - echo "hello deploy"
    
after_script:
  - echo "after-script"

after_script 失败不会影响作业失败。  

stages

        用于定义作业可以使用的阶段,并且是全局定义的。同一阶段的作业并行运行,不同阶段按顺序执行。  

stages:
  - build
  - test
  - deploy

        这里定义了三个阶段,首先 build 阶段并行运行,然后 test 阶段并行运行,最后 deploy 阶段并行运行。deploy 阶段运行成功后将提交状态标记为 passed 状态。如果任何一个阶段运行失败,最后提交状态为 failed。

未定义 stages

        全局定义的 stages 是来自于每个 job。如果 job 没有定义 stage 则默认是 test 阶段。如果全局未定义 stages,则按顺序运行 build,test,deploy。

        如果作业中定义了其他阶段,例如"codescan"则会出现错误。原因是因为除了 build test deploy 阶段外的其他阶段作为 .pre 运行(也就是作为第一个阶段运行,需要将此作业的 stage 指定为 .pre)。  

定义 stages 控制 stage 运行顺序  

一个标准的 yaml 文件中是需要定义 stages,可以帮助我们对每个 stage 进行排序。

stages:
  - build
  - test
  - codescan
  - deploy

.pre & .post

        .pre 始终是整个管道的第一个运行阶段,.post 始终是整个管道的最后一个运行阶段。 用户定义的阶段都在两者之间运行。.pre 和 .post 的顺序无法更改。如果管道仅包含 .pre 或 .post阶段的作业,则不会创建管道。  

stage

        是按 JOB 定义的,并且依赖于全局定义的 stages 。它允许将作业分为不同的阶段,并且同一 stage 作业可以并行执行(取决于特定条件 )。  

unittest:
  stage: test
  script:
    - echo "run test"
    
interfacetest:
  stage: test
  script:
    - echo "run test"

可能遇到下面问题: 阶段并没有并行运行。

        在这里我把这两个阶段在同一个 runner 运行了,所以需要修改 runner 每次运行的作业数量。默认是 1,改为 10.

vim /etc/gitlab-runner/config.toml 更改后自动加载无需重启。  

concurrent = 10

variables

定义变量,pipeline 变量、job 变量、Runner 变量。job 变量优先级最大。

综合实例(一)

before_script:
  - echo "before-script!!"

variables:
  DOMAIN: example.com
  
stages:
  - build
  - test
  - codescan
  - deploy

build:
  before_script:
    - echo "before-script in job"
  stage: build
  script:
    - echo "mvn clean "
    - echo "mvn install"
    - echo "$DOMAIN"
  after_script:
    - echo "after script in buildjob"

unittest:
  stage: test
  script:
    - echo "run test"

deploy:
  stage: deploy
  script:
    - echo "hello deploy"
    - sleep 2;
  
codescan:
  stage: codescan
  script:
    - echo "codescan"
    - sleep 5;
 
after_script:
  - echo "after-script"

实验效果

        可能遇到的问题:pipeline 卡主,为降低复杂性目前没有学习 tags,所以流水线是在共享的runner 中运行的。需要设置共享的 runner 运行没有 tag 的作业。

tags

        用于从允许运行该项目的所有 Runner 列表中选择特定的 Runner,在 Runner 注册期间,您可以指定 Runner 的标签。

tags 可让您使用指定了标签的跑步者来运行作业,此 runner 具有 ruby 和 postgres 标签。

job:
  tags:
    - ruby
    - postgres

        给定带有 deploy 标签的 deploy Runner 和带有 build 标签的 build Runner,以下作业将在各自的平台上运行。

build job:
  stage:
    - build
  tags:
    - build
  script:
    - echo Hello, %USERNAME%!

deploy job:
  stage:
    - build
  tags:
    - deploy
  script:
    - echo "Hello, $USER!"

allow_failure

  allow_failure 允许作业失败,默认值为 false 。启用后,如果作业失败,该作业将在用户界面中显示橙色警告。但是,管道的逻辑流程将认为作业成功/通过,并且不会被阻塞。假设所有其他作业均成功,则该作业的阶段及其管道将显示相同的橙色警告。但是,关联的提交将被标记为"通过",而不会发出警告。  

job1:
  stage: test
  script:
    - execute_script_that_will_fail
  allow_failure: true

when

  • on_success:前面阶段中的所有作业都成功(或由于标记为 allow_failure 而被视为成功)时才执行作业。 这是默认值。
  • on_failure:当前面阶段出现失败则执行。
  • always:执行作业,而不管先前阶段的作业状态如何,放到最后执行。总是执行。

manual 手动

  manual 手动执行作业,不会自动执行,需要由用户显式启动。手动操作的示例用法是部署到生产环境。可以从管道,作业,环境和部署视图开始手动操作。

        此时在 deploy 阶段添加 manual,则流水线运行到 deploy 阶段为锁定状态,需要手动点击按钮才能运行 deploy 阶段。

delayed 延迟

delayed 延迟一定时间后执行作业(在 GitLab 11.14中已添加)。

有效值 '5', 10 seconds, 30 minutes, 1 day, 1 week

实验 demo

before_script:
  - echo "before-script!!"

variables:
  DOMAIN: example.com
  
stages:
  - build
  - test
  - codescan
  - deploy

build:
  before_script:
    - echo "before-script in job"
  stage: build
  script:
    - echo "mvn clean "
    - echo "mvn install"
    - echo "$DOMAIN"
  after_script:
    - echo "after script in buildjob"

unittest:
  stage: test
  script:
    - ech "run test"
  when: delayed
  start_in: '30'
  allow_failure: true
  

deploy:
  stage: deploy
  script:
    - echo "hello deploy"
    - sleep 2;
  when: manual
  
codescan:
  stage: codescan
  script:
    - echo "codescan"
    - sleep 5;
  when: on_success
 
after_script:
  - echo "after-script"

retry-重试

配置在失败的情况下重试作业的次数。

        当作业失败并配置了 retry ,将再次处理该作业,直到达到 retry 关键字指定的次数。如果retry 设置为 2,并且作业在第二次运行成功(第一次重试),则不会再次重试;retry 值必须是一个正整数,等于或大于 0,但小于或等于 2(最多两次重试,总共运行 3 次)。

unittest:
  stage: test
  retry: 2
  script:
    - ech "run test"

        默认情况下,将在所有失败情况下重试作业。为了更好地控制 retry 哪些失败,可以是具有以下键的哈希值:

  • max :最大重试次数.

  • when :重试失败的案例.

根据错误原因设置重试的次数。

always :在发生任何故障时重试(默认).
unknown_failure :当失败原因未知时。
script_failure :脚本失败时重试。
api_failure :API失败重试。
stuck_or_timeout_failure :作业卡住或超时时。
runner_system_failure :运行系统发生故障。
missing_dependency_failure: 如果依赖丢失。
runner_unsupported :Runner不受支持。
stale_schedule :无法执行延迟的作业。
job_execution_timeout :脚本超出了为作业设置的最大执行时间。
archived_failure :作业已存档且无法运行。
unmet_prerequisites :作业未能完成先决条件任务。
scheduler_failure :调度程序未能将作业分配给运行scheduler_failure。
data_integrity_failure :检测到结构完整性问题。

实验

定义当出现脚本错误重试两次,也就是会运行三次。

unittest:
  stage: test
  tags:
    - build
  only:
    - master
  script:
    - ech "run test"
  retry:
    max: 2
    when:
      - script_failure

timeout 超时

特定作业配置超时,作业级别的超时可以超过项目级别的超时,但不能超过 Runner 特定的超时。

build:
  script: build.sh
  timeout: 3 hours 30 minutes

test:
  script: rspec
  timeout: 3h 30m

项目设置流水线超时时间

        超时定义了作业可以运行的最长时间(以分钟为单位)。 这可以在项目的 "设置">" CI / CD">"常规管道"设置下进行配置 。 默认值为 60 分钟。  

runner 超时时间

        此类超时(如果小于项目定义的超时 )将具有优先权。此功能可用于通过设置大超时(例如一个星期)来防止 Shared Runner 被项目占用。未配置时,Runner 将不会覆盖项目超时。

此功能如何工作:

示例1-运行程序超时大于项目超时

runner 超时设置为 24 小时,项目的 CI / CD 超时设置为 2 小时。该工作将在 2 小时后超时。

示例2-未配置运行程序超时

runner 不设置超时时间,项目的 CI / CD 超时设置为2 小时。该工作将在 2 小时后超时。

示例3-运行程序超时小于项目超时

runner 超时设置为 30 分钟,项目的 CI / CD 超时设置为 2 小时。工作在 30 分钟后将超时。

parallel-并行作业

配置要并行运行的作业实例数,此值必须大于或等于 2 并且小于或等于 50。

这将创建 N 个并行运行的同一作业实例。它们从 job_name 1/N 到 job_name N/N 依次命名。

codescan:
  stage: codescan
  tags:
    - build
  only:
    - master
  script:
    - echo "codescan"
    - sleep 5;
  parallel: 5

综合实例(二)

before_script:
  - echo "before-script!!"

variables:
  DOMAIN: example.com
  
stages:
  - build
  - test
  - codescan
  - deploy

build:
  before_script:
    - echo "before-script in job"
  stage: build
  script:
    - echo "mvn clean "
    - echo "mvn install"
    - echo "$DOMAIN"
  after_script:
    - echo "after script in buildjob"

unittest:
  stage: test
  script:
    - ech "run test"
  when: delayed
  start_in: '5'
  allow_failure: true
  retry:
    max: 1
    when:
      - script_failure
  timeout: 1 hours 10 minutes
  
  

deploy:
  stage: deploy
  script:
    - echo "hello deploy"
    - sleep 2;
  when: manual
  
codescan:
  stage: codescan
  script:
    - echo "codescan"
    - sleep 5;
  when: on_success
  parallel: 5
 
after_script:
  - echo "after-script"
  - ech

only & except-限制分支标签

only 和 except 是两个参数用分支策略来限制 jobs 构建:

  1. only 定义哪些分支和标签的 git 项目将会被 job 执行。

  2. except 定义哪些分支和标签的 git 项目将不会被 job 执行。

job:
  # use regexp
  only:
    - /^issue-.*$/
  # use special keyword
  except:
    - branches

rules-构建规则

  rules 允许按顺序评估单个规则对象的列表,直到一个匹配并为作业动态提供属性;请注意, rules 不能 only/except 与 only/except 组合使用。

可用的规则条款包括:

  • if (类似于 only:variables )

  • changes ( only:changes 相同)

  • exists

rules:if

        如果 DOMAIN 的值匹配,则需要手动运行。不匹配 on_success。 条件判断从上到下,匹配即停止。多条件匹配可以使用 && ||

variables:
  DOMAIN: example.com

codescan:
  stage: codescan
  tags:
    - build
  script:
    - echo "codescan"
    - sleep 5;
  #parallel: 5
  rules:
    - if: '$DOMAIN == "example.com"'
      when: manual
    - when: on_success

rules:changes

接受文件路径数组。 如果提交中 Jenkinsfile 文件发生的变化则为 true。

codescan:
  stage: codescan
  tags:
    - build
  script:
    - echo "codescan"
    - sleep 5;
  #parallel: 5
  rules:
    - changes:
      - Jenkinsfile
      when: manual
    - if: '$DOMAIN == "example.com"'
      when: on_success
    - when: on_success

rules:exists

接受文件路径数组。当仓库中存在指定的文件时操作。

codescan:
  stage: codescan
  tags:
    - build
  script:
    - echo "codescan"
    - sleep 5;
  #parallel: 5
  rules:
    - exists:
      - Jenkinsfile
      when: manual 
    - changes:
      - Jenkinsfile
      when: on_success
    - if: '$DOMAIN == "example.com"'
      when: on_success
    - when: on_success

rules:allow_failure

使用 allow_failure: true  rules:在不停止管道本身的情况下允许作业失败或手动作业等待操作.

job:
  script: "echo Hello, Rules!"
  rules:
    - if: '$CI_MERGE_REQUEST_TARGET_BRANCH_NAME == "master"'
      when: manual
      allow_failure: true

在此示例中,如果第一个规则匹配,则作业将具有以下 when: manual 和 allow_failure: true

workflow:rules

        顶级 workflow:关键字适用于整个管道,并将确定是否创建管道。when :可以设置为 always或 never;如果未提供,则默认值 always。  

variables:
  DOMAIN: example.com

workflow:
  rules:
    - if: '$DOMAIN == "example.com"'
    - when: always

综合实例(三)

before_script:
  - echo "before-script!!"

variables:
  DOMAIN: example.com
  
workflow:
  rules:
    - if: '$DOMAIN == "example.com"'
      when: always
    - when: never
    
stages:
  - build
  - test
  - codescan
  - deploy

build:
  before_script:
    - echo "before-script in job"
  stage: build
  script:
    - echo "mvn clean "
    - echo "mvn install"
    - ech "$DOMAIN"
  after_script:
    - echo "after script in buildjob"
  rules:
    - exists:
      - Dockerfile
      when: on_success 
      allow_failure: true

    - changes:
      - Dockerfile
      when: manual
    - when: on_failure

unittest:
  stage: test
  script:
    - ech "run test"
  when: delayed
  start_in: '5'
  allow_failure: true
  retry:
    max: 1
    when:
      - script_failure
  timeout: 1 hours 10 minutes
  
  

deploy:
  stage: deploy
  script:
    - echo "hello deploy"
    - sleep 2;
  rules:
    - if: '$DOMAIN == "example.com"'
      when: manual
    - if: '$DOMAIN == "aexample.com"'
      when: delayed
      start_in: '5'
    - when: on_failure
  
codescan:
  stage: codescan
  script:
    - echo "codescan"
    - sleep 5;
  when: on_success
  parallel: 5
 
after_script:
  - echo "after-script"
  - ech

上一篇文章:【基于 GitLab 的 CI/CD 实践】02、gitlab-runner 实践_Stars.Sky的博客-CSDN博客

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

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

相关文章

2010年中国生态系统服务空间数据集

摘要 生态系统服务是生态系统形成并维持的人类赖以生存和发展的环境条件与效用&#xff0c;是测度自然生态系统保护价值的重要指标。采用科学方法模拟生态系统服务的空间分布对掌握当前我国生态本底状况&#xff0c;识别生态保护重要区&#xff0c;从而有效支持生态管理决策具…

关于金融英语的翻译技巧,你了解多少呢

据了解&#xff0c;金融英语除了具备通用英语特点之外 &#xff0c;还具备自己独特的特征&#xff0c;如专有名词多、专业术语量大、专业缩略词等。为了确保译文的准确性&#xff0c;翻译金融英语时要注意以下几点技巧。 一、专业术语坚持直译。金融翻译中涉及大量金融英语特有…

day10_practice

用面向对象思想实现数据分析 1、设计类&#xff0c;完成数据封装 2、设计抽象类&#xff0c;定义文件读取相关功能&#xff0c;使用子类实现具体功能(由于两份文件格式不同) 3、读取文件&#xff0c;产生数据对象 4、计算每天销售额 5、绘图 一、数据封装类设计 ""…

Python读取骑行fit文件

目录 故事背景安装输出有心率和无心率的数据为NO.fit文件增加心率数据并保存参考文献 故事背景 有一天&#xff0c;我使用wahoo码表骑行记录了一段没有心率带的数据&#xff0c;导出fit文件至电脑。上传至捷安特APP&#xff0c;结果说数据不完整&#xff0c;此时想用代码把心率…

以结果为导向的网络安全需要全面的方法

Positive Technologies 信息安全分析师 Fedor Chunizhekov 谈论了该地区不断变化的网络安全形势&#xff0c;并重点介绍了其 "中东网络安全威胁形势 "报告中影响中东地区的要点。他还强调&#xff0c;为了解决核心安全问题&#xff0c;我们需要采用一种全面的方法来实…

安全性测试的测试点

安全性测试的测试点 1.跨网站脚本攻击 通过脚本语言的缺陷模拟合法用户&#xff0c;控制其账户&#xff0c;盗窃敏感数据 2.注入攻击 通过构造查询对数据库、LDAP和其他系统进行非法查询 3.恶意文件执行 在服务器上执行Shell 命令Execute&#xff0c;获取控制权 4.伪造跨…

企业如何选择通配符SSL证书?

很多企业网站因为业务需要&#xff0c;在同一个主域名下通常会有多个子域名。在这种情况下申请SSL证书就要很慎重&#xff0c;既要考虑到网站安全需要&#xff0c;又要考虑经济实惠。因此 OV 型的通配符证书非常适合这类企业网站。 为什么要选择通配符SSL证书&#xff1f; 通…

(Linux)查看端口占用并关闭进程

端口 查看端口占用 查看端口占用netstat -anp | grep 端口号 → 列出所有端口netstat -tunlp |grep 3306 → 端口号netstat -tunlp |grep mysql → 进程名称netstat -tunlp |grep 29520 → 进程IDnetstat -tunlp | grep 3306-t: 显示 TCP 连接-u: 显示 UDP 连接-n: 显示数字…

(linux) 查看日志文件

工作用常用 服务器查看日志cat opt/service/logs/logfile.log查看 logfile.log 日志文件tail -f -n -500 opt/service/logs/logfile.log动态查看日志vim opt/service/logs/file.logvi opt/service/logs/file.log可以快速查看日志第一行cat opt/service/logs/logfile.log | gre…

idea 自定义类注释模板和方法模板,无警告

背景&#xff1a;idea&#xff1a;IntelliJ IDEA 2023.1.3 (Ultimate Edition) 效果&#xff1a;&#xff08;主要是没无参&#xff0c;不会换行&#xff09; 类&#xff1a; /** * author sss* date ${DATE} on ${TIME}* desc $NAME*/# 完全复制上面的&#xff0c;删除这一行…

grpc --- protoc生成的pb.go文件的位置

目录 一、环境相关版本二、go_package配置为当前目录下三、go_package配置为指定目录四、结论 一、环境相关版本 go v1.20.5 protoc v4.24.0 protoc-gen-go v1.26.0protoc-gen-go版本过高时需要指定包名&#xff0c;即go_package 二、go_package配置为…

JMeter:性能测试和压力测试工具

JMeter简介 JMeter时Apache下基于java的一款性能测试和压力测试工具。它基于Java开发&#xff0c;可对HTTP服务器华人FTP服务器&#xff0c;甚至是数据库进行压力测试。作为一款专业的压测工具&#xff0c;JMeter功能强大&#xff0c;本片文章中仅简单介绍与本次压测相关的内容…

【Ceph集群应用】CephFS文件系统之MDS接口详解

CephFS文件系统之MDS接口详解 1.创建CephFS文件系统MDS接口1.1 创建cephfs1.2 基于内核的客户端挂载1.3 基于fuse工具方式的客户端挂载 接上文基于ceph-deploy部署Ceph集群详解 1.创建CephFS文件系统MDS接口 服务端操作 &#xff08;1&#xff09;在admin管理节点创建mds服务…

【LocalSend】开源跨平台的局域网文件传输工具,支持IOS、Android、Mac、Windows、Linux

工作前提条件&#xff1a;设备使用相同的局域网。 LocalSend is a cross-platform app that enables secure communication between devices using a REST API and HTTPS encryption. Unlike other messaging apps that rely on external servers, LocalSend doesn’t require …

Spring核心和设计思想(1)

1.Spring是什么&#xff1f; 我们通常说的Spring指的是Spring FrameWork&#xff08;Spring 框架&#xff09;&#xff0c;它是一个开源框架&#xff0c;有着活跃而庞大的社区&#xff0c;这就是它长久不衰的原因。Spring支持广泛的应用场景&#xff0c;它让Java企业级的应用程…

SUNSET_DECOY靶机详解

SUNSET_DECOY靶机复盘 这个靶机还是有点难度的&#xff0c;尤其在提权时候&#xff0c;毫无思路。 下载地址&#xff1a;https://download.vulnhub.com/sunset/decoy.ova 首先扫描IP&#xff0c;打开网站&#xff0c;这个靶机我是没有扫描目录的&#xff0c;因为没给我机会扫…

3组6通道DRP通道USB PD3.1控制SOC芯片LDR6020P

前言 2021年5月&#xff0c;USB-IF 协会发布了全新的USB PD3.1规范&#xff0c;该规范将快充功率上限从100 W提升至240 W&#xff0c;充电功率的提升也让USB PD的应用从手机、笔记本电脑&#xff0c;扩展到便携式设备、物联网设备、智能家居、通信和安防设备、汽车和医疗等领域…

小研究 - 面向 Java 的高对抗内存型 Webshell 检测技术(三)

由于 Web 应用程序的复杂性和重要性, 导致其成为网络攻击的主要目标之一。攻击者在入侵一个网站后, 通常会植入一个 Webshell, 来持久化控制网站。但随着攻防双方的博弈, 各种检测技术、终端安全产品被广泛应用, 使得传统的以文件形式驻留的 Webshell 越来越容易被检测到, 内存…

浅谈一下自动化运维优点和缺点,哪款工具好?

面对越来越复杂的业务&#xff0c;以及越来越多样化的用户需求&#xff0c;IT运维的要求也越来越高&#xff0c;IT运维人员工作也越来越繁琐复杂&#xff0c;因此如何又快又安全的保障IT服务是重中之重。这个时候就需要用到自动化运维了。今天我们就来一起简单聊聊什么是自动化…

Linux中的动态库与静态库

文章目录 软链接与硬链接动态库与静态库静态库动态库 动静态库的区别 软链接与硬链接 软链接 当我们不在本地路径下运行时,运行目标二进制文件一般要写明该程序路径. 但是这样运行对于路径较为复杂的程序极为耗费时间,为了简便操作,我们可以将该可执行程序的路径设置为软链接.…