Ansible流程控制-条件语句_循环语句

news2024/9/24 6:14:36

文章目录

    • Ansible流程控制
    • 条件语句
      • 且、或、非、是
      • 模糊条件
      • `when`指令的详细使用方法
    • 循环语句
      • 如何使用
        • 使用`item`变量`结合with_items`或`loop`指令
        • item变量有固定子元素?
      • 实例-服务器安装基础环境优化
        • 需求
        • 部分实现
          • 换指定新仓库
          • 安装基础软件包

Ansible流程控制

一、 1. 条件判断

when
when用于根据条件决定是否执行任务。

- hosts: all
  tasks:
    - name: Install package only on RedHat
      package:
        name: httpd
        state: present
      when: ansible_os_family == "RedHat"

二、 2. 循环

loop
loop用于遍历列表或集合。

- hosts: all
  tasks:
    - name: Install multiple packages
      package:
        name: "{{ item }}"
        state: present
      loop:
        - vim
        - git
        - curl

with_items
较老的循环方式,遍历列表。

- hosts: all
  tasks:
    - name: Install packages using with_items
      package:
        name: "{{ item }}"
        state: present
      with_items:
        - vim
        - git

with_dict
用于遍历字典。

- hosts: all
  tasks:
    - name: Print dictionary items
      debug:
        msg: "Key: {{ item.key }}, Value: {{ item.value }}"
      with_dict:
        item1: value1
        item2: value2

with_sequence
生成序列并遍历。

- hosts: all
  tasks:
    - name: Create files using with_sequence
      file:
        path: "/tmp/file{{ item }}"
        state: touch
      with_sequence: start=1 end=5

with_fileglob
遍历匹配文件名的文件。

- hosts: all
  tasks:
    - name: Read files from directory
      debug:
        msg: "Found file: {{ item }}"
      with_fileglob:
        - /tmp/*.txt

with_together
并行遍历多个列表。

- hosts: all
  tasks:
    - name: Combine items from two lists
      debug:
        msg: "Item from list1: {{ item.0 }}, Item from list2: {{ item.1 }}"
      with_together:
        - ['a', 'b', 'c']
        - [1, 2, 3]

三、 3. 循环控制

loop_control
提供更细粒度控制。

- hosts: all
  tasks:
    - name: Custom loop variable
      debug:
        msg: "Current item: {{ custom_item }}"
      loop:
        - a
        - b
      loop_control:
        loop_var: custom_item

在Ansible中,loop_control是一个用于提供循环过程中更细粒度控制的选项。它允许你自定义循环变量名、设置循环的标签、限制循环的并行执行数量等。这使得在处理循环时可以更加灵活和精确。

下面是一个使用loop_control的示例,展示了如何自定义循环变量名:

- hosts: all
  tasks:
    - name: Custom loop variable
      debug:
        msg: "Current item: {{ custom_item }}"
      loop:
        - a
        - b
      loop_control:
        loop_var: custom_item

在这个例子中,loop_control用于指定循环变量的名称。默认情况下,Ansible中的循环变量名为item,但通过loop_control,你可以将其更改为任何你想要的名称,比如这里的custom_item。这样,在循环体内部,就可以使用{{ custom_item }}来引用当前迭代的元素。

这种自定义循环变量的功能在需要在循环内部引用多个循环变量或在复杂的剧本中提高代码的可读性时非常有用。通过loop_control,你可以更精确地控制循环的行为,使其更符合你的特定需求。

四、 4. 错误处理

ignore_errors
在任务失败时继续执行后续任务。

- hosts: all
  tasks:
    - name: Failing task
      command: /bin/false
      ignore_errors: yes

    - name: This will run despite the previous failure
      debug:
        msg: "The previous task failed, but this still runs."

failed_when
自定义任务失败的条件。

- hosts: all
  tasks:
    - name: Custom failure condition
      command: /bin/true
      register: result

    - name: Check the result
      debug:
        msg: "This task will fail if the command did not return 0."
      failed_when: result.rc != 0

五、 5. 包含和导入
include_tasks
动态包含任务文件。

- hosts: all
  tasks:
    - name: Include tasks based on a condition
      include_tasks: my_tasks.yml
      when: ansible_os_family == "Debian"

import_tasks
静态导入任务文件。

- hosts: all
  tasks:
    - import_tasks: my_imported_tasks.yml

六、 6. 块和异常处理

block
将一组任务组合在一起,便于管理和错误处理。

- hosts: all
  tasks:
    - block:
        - name: Task 1
          command: /bin/true

        - name: Task 2
          command: /bin/false
      rescue:
        - name: Handle failure
          debug:
            msg: "One of the tasks failed, handling the error."
     # 当block中的任务错误时,会执行rescue中的任务

七、 7. 角色的流程控制

在角色中组织和控制任务执行。

# roles/myrole/tasks/main.yml
- name: Task in role
  command: /bin/echo "This is a task in a role"

- include_tasks: another_tasks.yml

这些示例展示了Ansible中的各种流程控制功能,帮助你在自动化任务和配置管理中实现更复杂的逻辑。



在Ansible中,include_tasksimport_tasksinclude指令都是用来组织和重用代码的,但它们在用法和上下文中有一些区别:

  1. include_tasks

    • 动态包含任务文件include_tasks可以根据条件动态地包含一个任务列表文件。

    • 使用场景:当你需要基于某些条件(如操作系统、环境变量等)来决定是否执行一组任务时,可以使用include_tasks

  • 示例

    - hosts: all
      tasks:
        - name: Include tasks based on a condition
          include_tasks: my_tasks.yml
          when: ansible_os_family == "Debian"
    
  1. import_tasks

    • 静态导入任务文件import_tasks用于静态地导入一个任务列表文件,它不会根据条件来决定是否导入。

    • 使用场景:当你需要在当前任务列表中静态地包含一组任务时,可以使用import_tasks

    • 示例

 ```yaml
 - hosts: all
   tasks:
     - import_tasks: my_imported_tasks.yml
 ```
  1. include

    • 包含变量或文件include用于包含变量文件或角色文件,它不是用于任务列表。

    • 使用场景:当你需要在当前剧本中包含一个变量文件或角色文件时,可以使用include

    • 示例

 ```yaml
 - hosts: all
   vars_files:
     - vars.yml
 ```

这些指令在Ansible中提供了灵活的代码组织和重用机制,使得剧本更加模块化和可维护。

include指令在Ansible中主要用于包含变量文件、任务文件、模板文件等,它的作用不仅限于任务列表,还包括其他资源类型。以下是include指令的一些额外说明:

  1. 变量文件

    • include_vars:用于包含变量文件,这些变量可以在任务中使用。

    • 示例:

 ```yaml
 - hosts: all
   vars_files:
     - vars.yml
 ```
  1. 任务文件

    • 虽然include_tasks用于动态包含任务文件,但include也可以用于静态包含任务文件,这通常用于角色中。

    • 示例:

 ```yaml
 - include: tasks/main.yml
 ```
  1. 模板文件

    • include可以用于包含模板文件,这些文件可以用于生成配置文件等。

    • 示例:

 ```yaml
 - name: Include a template file
   include: my_template.j2
 ```
  1. 文件路径

    • include指令支持相对路径和绝对路径。
    • 相对路径是相对于当前剧本文件的路径。
    • 绝对路径是从文件系统的根目录开始的路径。
  2. 条件包含

    • 虽然include本身不支持条件包含,但可以通过在包含的文件中使用条件语句来实现条件包含的效果。
  3. 循环包含

    • include指令可以与loop一起使用,实现循环包含文件。

    • 示例:

      - hosts: all
        tasks:
          - name: Include tasks from a list
            include: "{{ item }}"
            with_first_found:
              - "tasks/{{ ansible_os_family }}.yml"
              - "tasks/default.yml"
      
  4. 错误处理

    • 如果include指定的文件不存在,Ansible会报错。
  5. 角色中的使用

    • 在Ansible角色中,include指令通常用于包含任务文件、变量文件或模板文件。
  6. 静态与动态

    • include通常是静态的,意味着它在剧本解析时就确定了要包含的文件。
    • include_tasks相比,include不提供动态包含的能力。
  7. import的区别

    • import指令在Ansible的早期版本中用于包含任务,但现在推荐使用import_tasks

include指令是Ansible剧本编写中非常灵活和强大的工具,可以有效地组织和管理代码。

条件语句

使用when指令

且、或、非、是

且:and
或:or
非:!=
是:==
在这里插入图片描述

模糊条件

使用is match

...
yum:
  name:
    - xxx
    - xxx
when: ansible_hostname is match 'web*'
...

when指令的详细使用方法

在Ansible中,when指令用于条件判断,允许你根据特定条件决定是否执行某个任务。它可以根据变量的值、注册的结果或其他条件进行判断。

  1. 基本语法

    - name: Task name
      command: your_command
      when: condition
    
  2. 条件可以是

    • 变量比较:when: variable_name == 'value'
    • 布尔值:when: some_boolean_variable
    • 列表检查:when: item in my_list
    • 注册变量结果:when: result_variable is succeeded

以下是一个简单示例,展示如何使用when指令:

---
- hosts: all
  tasks:
    - name: Check if a file exists
      stat:
        path: /tmp/myfile.txt
      register: file_stat

    - name: Create a file if it does not exist
      file:
        path: /tmp/myfile.txt
        state: touch
      when: not file_stat.stat.exists

    - name: Notify if the file was created
      debug:
        msg: "The file was created!"
      when: file_stat.stat.exists == false

上面是示例的解释:

  1. stat模块:检查/tmp/myfile.txt是否存在,并将结果注册到file_stat
  2. 创建文件任务:仅在文件不存在时执行(when: not file_stat.stat.exists)。
  3. 调试任务:如果文件被创建,输出一条消息。


变量比较

假设你有一个变量my_os,它存储了目标机器的操作系统类型。你只想在操作系统为Ubuntu时执行某个任务。

- name: Install package if OS is Ubuntu
  apt: name=nginx state=present
  when: my_os == 'Ubuntu'

布尔值

如果你有一个布尔变量install_nginx,你想根据这个变量的值来决定是否安装Nginx。

- name: Install Nginx if the condition is true
  command: apt-get install nginx
  when: install_nginx

列表检查

如果你有一个列表packages_to_install,并且你只想在列表中包含nginx时安装它。

- name: Install nginx if it is in the list
  command: apt-get install nginx
  when: 'nginx' in packages_to_install

注册变量结果

假设你已经运行了一个任务来安装某些软件包,并且你将结果注册到了变量install_result中。只有当安装成功时,你才想执行下一个任务。

- name: Install some software
  command: apt-get install some_software
  register: install_result

- name: Run configuration script if software installed successfully
  command: ./configure_software.sh
  when: install_result is succeeded

组合条件

你也可以组合多个条件来创建更复杂的逻辑。

- name: Install nginx only if it's not installed and the OS is Ubuntu
  command: apt-get install nginx
  when: nginx_not_installed and my_os == 'Ubuntu'

在这个例子中,nginx_not_installed是一个布尔变量,表示Nginx是否已经安装。只有当Nginx未安装并且操作系统是Ubuntu时,才会执行安装Nginx的命令。



再探讨一下Ansible中的“列表检查”和“注册变量”的条件:

一、 列表检查(List Checking)

在Ansible中,你可以使用in关键字来检查一个值是否存在于一个列表中。这在你需要基于一组预定义的值来决定是否执行某个任务时非常有用。

例如,假设你有一个变量my_list,它是一个包含多个元素的列表,你想检查某个特定的值item是否在这个列表中:

- name: Check if item is in the list
  command: echo "Item is in the list"
  when: item in my_list

在这个例子中,如果变量item的值存在于变量my_list中,那么echo "Item is in the list"命令将被执行。
在这里插入图片描述

二、 注册变量(Registered Variables)

在Ansible中,你可以使用register关键字来保存任务的输出,这样你就可以在后续的任务中引用这个输出。注册的变量通常用于条件判断,以决定是否执行后续的任务。

例如,你有一个任务,它执行一个命令并注册了其结果:

- name: Run a command and register the result
  command: ls /nonexistent
  register: command_result
  ignore_errors: yes

在这个例子中,ignore_errors: yes告诉Ansible即使命令失败也继续执行。register: command_result将命令的输出保存到变量command_result中。

然后,你可以使用when语句来检查这个注册变量的状态,并决定是否执行后续的任务:

- name: Check if the command was successful
  command: echo "Command was successful"
  when: command_result is succeeded

在这个例子中,如果ls /nonexistent命令成功执行(即使它实际上没有找到任何文件,因为我们使用了ignore_errors: yes),那么echo "Command was successful"命令将被执行。

注册变量可以包含多种信息,包括命令的退出状态、标准输出和标准错误输出等。你可以根据这些信息来构建复杂的条件判断。例如,你可以检查命令是否失败:

- name: Check if the command failed
  command: echo "Command failed"
  when: command_result is failed

在这个例子中,如果ls /nonexistent命令失败(这是预期的,因为/nonexistent目录不存在),那么echo "Command failed"命令将被执行。
在这里插入图片描述


更多的例子:

例 1:根据操作系统类型执行任务

---
- hosts: all
  tasks:
    - name: Install packages based on OS
      package:
        name: 
          - "{{ item }}"
        state: present
      loop:
        - vim
        - wget
      when: ansible_os_family == 'Debian'

解释:

这个任务会在Debian家族的操作系统(如Ubuntu)上安装vimwget,只在when条件满足时执行。


例 2:根据变量值进行条件判断

---
- hosts: all
  vars:
    environment: production

  tasks:
    - name: Deploy application only in production
      shell: deploy_script.sh
      when: environment == 'production'

解释:

此任务仅在environment变量等于production时执行,确保应用程序只在生产环境中部署。


例 3:根据注册变量的结果执行任务

---
- hosts: all
  tasks:
    - name: Check if a service is running
      shell: systemctl is-active my_service
      register: service_status
      ignore_errors: yes

    - name: Start the service if it is not running
      service:
        name: my_service
        state: started
      when: service_status.stdout != 'active'

解释:

这个示例首先检查服务my_service是否正在运行。如果服务未运行(即service_status.stdout不是active),则会启动该服务。


例 4:使用多条件判断

---
- hosts: all
  vars:
    app_installed: true
    app_version: '1.0.0'

  tasks:
    - name: Run upgrade if app is installed and version is less than 2.0.0
      shell: upgrade_script.sh
      when: app_installed == true and app_version | version_compare('2.0.0', '<')

解释:

这个任务在应用程序已安装且版本低于2.0.0时执行升级脚本。使用version_compare函数进行版本比较。

循环语句

如何使用

使用item变量结合with_itemsloop指令

在Ansible中,with_itemsloop都是用来迭代列表或集合的指令,但它们有一些具体的区别和使用场景。以下是这两者的详细比较:

一、 1. 基本概念

  • with_items:是Ansible的一个古老的循环结构,用于遍历列表。它的语法较为简单,但功能较为有限。

  • loop:是Ansible中更现代的循环语法,提供了更强大的功能和灵活性。它是with_items的推荐替代品。

二、 2. 语法比较

with_items 示例

- name: Install packages using with_items
  yum:
    name: "{{ item }}"
    state: present
  with_items:
    - vim
    - wget
    - curl

loop 示例

- name: Install packages using loop
  yum:
    name: "{{ item }}"
    state: present
  loop:
    - vim
    - wget
    - curl

三、 3. 功能区别

  • 可嵌套
    • loop支持嵌套循环,可以与其他循环指令结合使用,而with_items则不支持。
- name: Loop over a list of lists
  debug:
    msg: "{{ item }}"
  loop:
    - [1, 2, 3]
    - [4, 5, 6]
  loop_control:
    subelements: 0
  • 更好的变量支持
    • loop可以与其他的控制指令(如loop_control)结合使用,可以更灵活地控制迭代过程。

四、 4. 性能和可读性

  • 性能

    • 在某些情况下,loop的性能可能会稍好,特别是在处理大型数据集时。
  • 可读性

    • loop的语法更一致,易于理解,尤其是在复杂的场景下。推荐在新项目中使用loop

五、 5. 使用建议

  • 推荐使用loop:由于loop是Ansible的现代循环方式,功能更强大且灵活性更高,因此在新项目中应优先选择loop
  • with_items的使用:对于一些简单的任务,可以继续使用with_items,但应注意其在未来可能会被弃用。

六、 总结

尽管with_itemsloop都可以实现相似的功能,loop在灵活性、功能和可读性方面具有明显的优势。因此,建议在编写Ansible剧本时优先选择使用loop

loop需在安装Ansible2X版本后才能使用

item变量有固定子元素?

在Ansible中,item变量通常用于循环(如with_itemsloop)来表示当前迭代的元素。具体来说,item可以用来访问循环中每个元素的子元素,特别是在处理字典或列表时。

  1. 列表中的字典
- name: Example with list of dictionaries
  debug:
    msg: "Name is {{ item.name }}, Age is {{ item.age }}"
  loop:
    - { name: 'Alice', age: 30 }
    - { name: 'Bob', age: 25 }

在这个例子中,item是每个字典,可以通过item.nameitem.age访问它的子元素。

  1. 字典中的列表
- name: Example with dictionary containing a list
  debug:
    msg: "Fruit is {{ item }} and Price is {{ prices[item] }}"
  vars:
    prices:
      apple: 1.2
      banana: 0.5
  loop:
    - apple
    - banana

这里,item是循环中的水果名,使用prices[item]来获取对应价格。

  • item是动态的,具体内容取决于当前循环的上下文
  • 可以在循环中使用item的子元素访问来处理复杂数据结构,例如列表和字典的组合。
  • 结合with_itemsloop使用,可以使配置和任务更加灵活和可重复。

实例-服务器安装基础环境优化

需求

优化一台刚安装完的虚拟机:

  • 改网卡信息
  • 换新仓库
  • 安装基础软件包(包括时间同步软件)
  • 优化文件描述符
  • *防火墙设置
部分实现
换指定新仓库
---
- name: the play1
  hosts: all
  become: no
  tasks:
	- name: task:备份原来的仓库
	  include: /path/to/task_backup_old_repos.yaml	
    - name: task:安装新仓库
      include: /path/to/task_install_new_repos.yaml

可使用get_url加其中的列表循环的方式安装新仓库:
在这里插入图片描述
当然也可以使用shell模块,里面使用wget命令
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

安装基础软件包
---
- name: the play1
  hosts: all
  tasks:
    - name: 安装好些个基础软件包
      yum:
        name: {{item}}
        state: present
      with_items:
        - chrony
        - aaa
        - bbb
        - ccc
        - ddd
        ...

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

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

相关文章

opencv4.5.5 GPU版本编译

一、安装环境 1、opencv4.5.5 下载地址&#xff1a;https://github.com/opencv/opencv/archive/refs/tags/4.5.5.ziphttps://gitee.com/mirrors/opencv/tree/4.5.0 2、opencv-contrib4.5.5 下载地址&#xff1a;https://github.com/opencv/opencv_contrib/archive/refs/tags/4…

塑料瓶回收流水线分拣系统源码分享

塑料瓶回收流水线分拣检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Comp…

介绍GPT-o1:一系列解决困难问题( science, coding, and math )的推理模型

openai o1介绍 一、官方技术报告要点剖析实验1 benchmark分析实验2:和phd比赛技术细节&#xff1a;Chain of Thought的使用人类偏好评估Human preference evaluationsatety技术细节&#xff1a;隐藏思维链为监控模型提供了机会:)openai的几点conclusion 二、官方介绍剖析 Intro…

【C++】8.类和对象(6)

文章目录 5. 内部类6. 匿名对象7. 对象拷贝时的编译器优化 5. 内部类 如果一个类定义在另一个类的内部&#xff0c;这个内部类就叫做内部类。内部类是一个独立的类&#xff0c;跟定义在全局相比&#xff0c;他只是受外部类类域限制和访问限定符限制&#xff0c;所以外部类定义的…

【信号与系统】2、系统

1、线性系统 举例&#xff1a; &#xff08;1&#xff09;&#xff0c;是线性系统 &#xff08;2&#xff09;&#xff0c;是线性系统 &#xff08;3&#xff09;&#xff0c;微分器&#xff0c;是线性系统 &#xff08;4&#xff09;&#xff0c;积分器&#xff0c;是线性…

具身智能火了,但规模落地还需时间

作者 | 辰纹 来源 | 洞见新研社 “人工智能下一个浪潮是具身智能&#xff0c;即能理解、推理并与物理世界互动的智能系统”&#xff0c; 英伟达CEO黄仁勋去年在ITF World 2023半导体大会上的预测正在成为现实。 5月份&#xff0c;日本横滨召开的国际顶级机器人学术会议&…

专业120+总分400+中国科学技术大学843信号与系统考研经验中科大电子信息通信工程,生物医学工程,苏医工,真题,大纲,参考书。

经过将近一年的复习备考&#xff0c;专业843信号与系统120&#xff0c;总分400&#xff0c;顺利上岸朝思暮想的中科大。总结一些自己的备考经验&#xff0c;希望能给大家一些参考&#xff0c;少走弯路。首先讲一下大家最关注的专业课&#xff1a;843信号与系统 中科大843专业课…

动态规划算法:10.路径问题_地下城游戏_C++

目录 题目链接&#xff1a;174. 地下城游戏 - 力扣&#xff08;LeetCode&#xff09; 一、题目解析 题目&#xff1a;​编辑 解析&#xff1a; 二、算法原理 1、状态表示 2、状态转移方程 状态转移方程推理&#xff1a; 3、初始化 dp表初始化: 特殊位置初始化&#…

Vue学习(五)生命周期、组件

生命周期 生命周期&#xff0c;又名生命周期回调函数、生命周期函数、生命周期钩子。 生命周期是Vue在关键时刻帮我们调用的一些特殊名称的函数。 生命周期函数的名字不可更改&#xff0c;但是函数的具体内容是程序员根据需求写的。 生命周期中的this指向的是vm或者组件实例…

NFTScan | 09.16~09.23 NFT 市场热点汇总

欢迎来到由 NFT 基础设施 NFTScan 出品的 NFT 生态热点事件每周汇总。 周期&#xff1a;2024.09.16~ 2024.09.22 NFT Hot News 01/ ​DeGods 推出代币 DEGOD&#xff0c;用户可通过 DeGods、y00ts 或 DUST 进行转换 9 月 16 日&#xff0c;Solana NFT 项目 DeGods 推出代币…

综合题第二题(路由器的配置)

题目 如何计算子网掩码 我们可以观察到上图的IP地址后面有“/26”、“30”。我们都知道子网掩码是由多个连续“1”和多个连续“0”组成的&#xff0c;“、26”表示子网掩码的二进制表达中有26个1。 例如&#xff1a;156.95.9.128/26 1111 1111.1111 1111.1111 1111.1100 0000…

idea插件开发系列1-环境搭建

前言 还记着10多年前有幸接触了eclipse插件开发&#xff0c;10多年后的今天有开发了idea的插件&#xff0c;真是一个轮回&#xff01; 为什么要学习idea插件开发呢&#xff1f; 目前公司使用自己的MVC框架&#xff0c;没有相应的idea插件支持&#xff08;如类似mybatis插件可…

基于51单片机智能家居监控系统设计

文章目录 前言资料获取设计介绍功能介绍设计程序具体实现截图设计获取 前言 &#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师&#xff0c;一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP430/AVR等单片机设计 主要对…

计算机毕业设计hadoop+hive航班预测系统 飞机票航班数据分析可视化大屏 机票预测 机票爬虫 飞机票推荐系统 大数据毕业设计

《HadoopHive航班预测系统》开题报告 一、课题背景与意义 随着全球航空业的快速发展&#xff0c;航班数据呈现出爆炸性增长的趋势。这些数据包含了航班时间、航线、价格、乘客量、天气条件等多种信息&#xff0c;对于航空公司来说&#xff0c;如何高效处理和分析这些数据&…

大模型培训讲师叶梓:Llama Factory 微调模型实战分享提纲

LLaMA-Factory ——一个高效、易用的大模型训练与微调平台。它支持多种预训练模型&#xff0c;并且提供了丰富的训练算法&#xff0c;包括增量预训练、多模态指令监督微调、奖励模型训练等。 LLaMA-Factory的优势在于其简单易用的界面和强大的功能。用户可以在不编写任何代码的…

高校大数据实训管理平台怎么选择?

泰迪智能科技大数据实训管理平台分为多个方向包括&#xff1a;人工智能方向、大数据方向、商务数据分析方向&#xff0c;不同高校可以结合高校情况选择合适自己院校的相关产品平台。 高校实训管理平台是实验室模块的核心母平台&#xff0c;对实验室的所有课程及实训资源进行统…

【题解】CF2013A

首先抽自己一巴掌&#xff0c;A题自信提交直接WA&#xff0c;故写此题解警示一下&#xff08;顺便水一水&#xff09;。 翻译 原题链接 思路 显然&#xff0c;若搅拌机单位时间能处理的水果数 x x x小于人每次丢进去的数量 y y y&#xff0c;那人只需要一直扔进去就好了&…

【d48】【Java】【力扣】LCR 123. 图书整理 I

思路 方法1&#xff1a;放进list,将list倒置&#xff0c;利用stream&#xff0c;将list改为int类型 方法2&#xff1a;递归&#xff1a;递归通用思路&#xff1b;明确每一层做什么确定返回值确定什么地方接收下层的返回值 每一层&#xff1a;调用下层&#xff0c;然后把自己…

护理陪护小程序|陪护系统||陪护系统开发

在当今社会&#xff0c;随着人口老龄化的加剧和家庭结构的变化&#xff0c;护理与陪护服务的需求日益增长。为了更好地满足这一市场需求&#xff0c;并提升服务效率与质量&#xff0c;护理陪护小程序应运而生。这类小程序不仅为用户提供了便捷、高效的服务预约与管理平台&#…

DANN GRL

域自适应是指在目标域与源域的数据分布不同但任务相同下的迁移学习&#xff0c;从而将模型在源域上的良好性能迁移到目标域上&#xff0c;极大地缓解目标域标签缺失严重导致模型性能受损的问题。 介绍一篇经典工作 DANN &#xff1a; 模型结构 在训练阶段需要预测如下两个任务…