当前位置: 首页 > news >正文

linux部署ansible自动化运维

ansible自动化运维

1,编写ansible的仓库(比赛已经安装,无需关注)

1、虚拟机右击---设置---添加---CD/DVD驱动器---完成---确定

2、将ansible.iso的光盘连接上(右下角呈绿色状态)

3、查看光盘挂载信息

df -h

4、挂载光盘(/dev/sr1)

mount /dev/sr1 /opt

df -h

5、编写ansible的仓库

cd /etc/yum.repos.d/

ls

vim ansible.repo

  1 [Ansible]

  2 name=Ansible

  3 baseurl=file:///opt

  4 gpgcheck=0

  5 enabled=1

yum clean all  #清理缓存

yum makecache #建立缓存

yum repolist #刷新

 

2,部署ansible(前面的仓库就是用来部署ansible的)

CentOS7安装ansible

更新yum仓库的镜像源

wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo

1c5f245c093e43bebb29b77565db6fee.png

安装epel扩展包(扩展包才有ansible软件包)

wget -O /etc/yum.repos.d/epel.repo https://mirrors.aliyun.com/repo/epel-7.repo

5a6f69cbbc9d4efb8b5f32d8393c1544.png

安装ansible

yum install -y ansible

752767fd07ad400a89635ae550c1f679.png

5、查询ansible是否安装

rpm -q ansible

78299a033a0346ca8f3048ce26b24c6b.png

 

3,ansible生效配置文件

1、当系统中有多个absible的配置文件时,只能有一个生效,谁的优先级越大谁就生效

2、查看生效的配置文件

ansible --version

1041c0bc73f949819635ff1fd6d23314.png

3、要求使用普通用户来做ansible,并且ansible的生效文件有要求,例如在用户的家目录

cp /etc/ansible/ansible.cfg .

ls

422473ebcedf4ecf9ee8bcee83b59840.png

ansible --version

b5509c3cdfb8471f874e7ffd762dd36d.png

  

4、因为当前生效的配置文件为/root/ansible.cfg,所以必须修改/root/ansible.cfg的文件才能往后面做

 

4,清单文件

1、相当于老师手中的花名册,清单文件中有哪些主机就说明这些主机可以被控制节点管理

vim /root/ansible.cfg

 14 inventory      = /root/inventory   指的清单文件的位置

 15 #inventory      = /etc/ansible/hosts  默认清单文件存放的位置

928a063bc668474a8027cff0febd079c.png

2、创建指定的清单文件

vim /root/inventory

[test]    #表示主机组的名字

192.168.23.142  #表示主机组下面的主机

e32bcfd7322c4ac7b887eed744d64aeb.png

3、验证清单文件是否生效,简称:列出清单树

ansible-inventory --graph

1ffea3701ef0482db69e743895f89f8a.png

备注:带@表示组名

 

5,ad-hoc临时命令

命令格式:ansible 主机/主机组 [-m 模块]  -a "命令"

1、使用临时命令测试ls(报错,原因:因为没有输入密码)

ansible test -a "ls"

c34914a9184f40a9ab43380ddbce58a4.png

2、再次使用临时命令 -k 指定密码

ansible test -a "ls" -k

511aa09fb9d84db6a05881491297ca54.png

3、使用临时命令查看对端的当前所在路径

ansible test -a "pwd" -k

0c6bf7d2033d4c14b6ca2eb3ecc9a0f0.png

 

4、使用临时命令查看对端的主机名

ansible test -a "hostname" -k

6fca61861acb4e7a81d9cf0cb7988408.png

 

5、使用临时命令在对端主机上的当前所在路径创建文件

ansible test -a "touch 1.txt" -k

d76edbdc989a45a7afa9c11a10524c6c.png

6、使用临时命令查看对端的当前所在路径的文件

ansible test -a "ls" -k

412da71947754ecea50972816e35b638.png

 

6,免密

因为当前是root用户,所以只需要做以下2步

1、在主配置文件中取消指纹验证

vim /root/ansible.cfg  

 72 host_key_checking = False

 73 #host_key_checking = False

caa636e6f9f74ccb913ec91b3c34566d.png

 

2、在清单文件中添加密码

vim /root/inventory

 [all:vars]

 ansible_password=123456

 [test]

 192.168.23.142

939f263ed2c24e94840bb1c0d3f945b6.png

 

3、再次测试

ansible test -a "useradd user1"

ansible test -a "id user1"

74ea8b8d4c6c43a499cfe1540f6366ac.png

 

7.修改tab的缩进-为playbook做准备

vim ~/.vimrc

set number ts=2 sw=2 et

4b6d162bed344b398a9fabc6626336d2.png

 

8.帮助

1、统计ansible中有多少个模块有帮助

ansible-doc -l  | wc -l

0b7c74aa42744e49b45491f652e99a1c.png

2、在模块中过滤出user

ansible-doc -l  | grep user

ef5889ab135f4064be906ec3bfbed003.png

3、查看user的帮助

ansible-doc user

/EX

1adc311dbc0c471ca66575875873007a.png

 

9.集中缩进

1、跳转到要缩进的行

2、按ctrl v进入可视化块模式

3、按↑↓键选中要缩进的行

4、按I在行首输入

5、按tab缩进

6、按ecs(两下)

 

10.编写简单的playbook

Ansible常用模块列表:

模块名称

功能描述

ping

检查指定节点机器是否还能连通。

command

在远程主机执行命令,不支持管道符和重定向。

raw

执行原始的命令,不通过模块子系统。

shell

类似于command模块,但支持更全面的功能,包括管道和重定向。

script

在远程主机上执行本地脚本。

template

将模板文件复制到远程主机并支持变量替换。

yum

管理RedHat/CentOS系统的软件包。

apt

管理Ubuntu/Debian系统的软件包。

copy

复制文件到远程主机。

fetch

从远程主机获取文件到本地。

file

管理文件和目录的属性。

unarchive

解压归档文件到远程主机。

user

管理用户账户。

group

管理用户组。

service

管理系统服务。

firewalld

管理firewalld防火墙规则。

cron

管理定时任务。

dnf

管理Fedora系统的软件包(类似于yum)。

synchronize

同步本地和远程主机之间的文件和目录。

wait_for

等待某个条件满足后再继续执行。

pause

暂停执行一段时间。

fail

人为地使任务失败,并显示错误信息。

debug

输出变量的值,用于调试。

 

创建用户

vim user.yml

  1. ---              #表示playbook的开头(可省,但不建议省)
  1. - name: useradd  # - name:表示解释说明,解释此playbook的功能
  2.   hosts: test    #表示此playbook应该到哪些主机组和主机上,如果有多个用,隔开
  3.   tasks:         #接下来具体要实施的任务
  4.   - name: Add the user 'johnd'   #- name:解释说明,对此任务的解释说明
  5.     user:        #模块名
  6.        name: qq1  #创建用户的名
  7.        uid: 1010  #用户的uid

 

ansible-playbook user.yml

备注:红色表示错误,黄色表示更改,绿色表示没有更改

3cf090a7bba6496c8c86c84c176a8489.png

根据红色报错信息修正错误之后

09257193a8a94e39bd1afa39625399f4.png

验证实验效果

ansible test -a "grep qq1 /etc/passwd"

a485c896685b4ccd8ff1ffdd4aa0bf30.png

 

创建组

1、在模块中过滤出group

ansible-doc -l  | grep group

7d545a8c41584931970092e592516837.png

2、查看user的帮助

ansible-doc group

/EX

ce03f15452944107afb2b8a1dc832075.png

3,编写playbook vim group.yml

---

- name: groupadd

   hosts: test

   tasks:

   - name: Ensure group "somegroup" exists

     group:

        name: group1

        state: present

4,根据检查排错 ansible-playbook group.yml

b8b2c0a436aa40348a245496c19bf31f.png

5,验证实验效果 ansible test -a "tail -n 1 /etc/group"

fd3f1b5f1fdb4db0940028e2e194ca62.png

 

安装软件包+开启服务

管理软件包的模块

ansible-doc -l | grep yum

ce9c6b58d0be44b9a87d37877413f3b1.png

ansible-doc  yum

/EX

3ea417284ada4073b7d170ad701f92bc.png

管理服务的模块

ansible-doc -l | grep service

a53dbabc6d7149309a9712e411ddce89.png

ansible-doc service

/EX

a181ebbbbee64e31a7b47e4d26089977.png

编写vim httpd.yml

  1 ---

  2 - name: web

  3   hosts: test

  4   tasks:

  5   - name: install the latset version of Apache

  6     yum:

  7         name: httpd

  8         state: latest

  9   - name: Start service httpd, if not started

 10     service:

 11        name: httpd

 12        state: started

 13        enabled: yes

验证playbook是否配置成功 ansible-playbook httpd.yml

33328fff92ab4e6a9a34924759cfce43.png

验证实验效果 ansible test -a "systemctl status  httpd"

2c13576d9f84424c913c0e51c63ea6e6.png

 

修改httpd的端口号(默认80端口)

替换配置文件中某一行的模块

ansible-doc -l | grep line

8886a57a205e454eb97a8cd2ae9f8bf8.png

ansible-doc lineinfile

/EX

708f52f3253e488293b363a7b065f29e.png

编辑playbook vim apache.yml

---

- name: listen

  hosts: test

  tasks:

    - name: Ensure the default Apache port is 8080

      lineinfile:

        path: /etc/httpd/conf/httpd.conf 

        regexp: '^Listen '

        insertafter: '^#Listen '

        line: 'Listen 8080'

        state: present

        backup: yes

检验配置是否成功:ansible-playbook apache.yml

9a824d8fbfdf4136a820066b31d76a1b.png

验证配置效果

ansible test -a "grep ^Listen  /etc/httpd/conf/httpd.conf"

be39a8ffc45248d5b2d3eb56ea2a1064.png

 

复制文件

查找复制文件的模块

ansible-doc -l | grep copy

383802459cfd4b7e87b932946f58a380.png

ansible-doc copy

/EX

b5174ba6d28b4da4a195cc2df80a7bbb.png

编辑playbook vim copy.yml

---
- name: copy
  hosts: test
  tasks:
  - name: Copy file with owner and permissions
    copy:
      src: /etc/fstab
      dest: /var/tmp/fstab

排查错误 ansible-playbook copy.yml

26441c8d86e749f58ee6a5f6ffd8a968.png

验证实验结果  ansible test -a "ls -ld /var/tmp/fstab"

ccaf566c5613464eb412aeefb5a8d46a.png

 

11.循环(loop)

1,批量创建用户(未循环操作)vim useradd.yml

---
- name: loop useradd
  hosts: test
  tasks:
  - name: Add the user
    user:
      name: qq10
  - name: Add the user
    user:
      name: qq11
  - name: Add the user
    user:
      name: qq12

排查错误 ansible-playbook useradd.yml

0caa97fb82cd4241af487e696b439c02.png

 验证实验结果 ansible test -a "tail -n 3 /etc/passwd"

5a40fa56903e49cd97af17d0357065ad.png

 

2,批量创建用户(使用循环操作)vim useradd1.yml

---
- name: loop
  hosts: test
  tasks:
  - name: Add the user
    user:
      name: "{{ item }}"
    loop:
    - wx1
    - wx2
    - wx3

#"{{ item }}"跟loop是固定搭配

#loop下面就行你要循环的名字

ansible-playbook useradd1.yml

985ac863a3cc450cb3577389e6b06c8c.png

 ansible test -a "tail -n 3 /etc/passwd"

1d14f0c9a82a4aeb98f13972fcfc83f9.png

 

3,通过循环批量创建组 vim group1.yml

---
- name: groupadd loop
  hosts: test
  tasks:
  - name: Ensure group "somegroup" exists
    group:
      name: "{{ item }}"
      state: present
    loop:
    - group10
    - group20
    - group30

 

ansible-playbook group1.yml

fd59920bef2042ad89652fc8076a40f4.png

ansible test -a "tail -n 3 /etc/group"

a43a62514dd04b569d30208987c8851b.png

 

12,利用变量实现模板复制

查看帮助

ansible-doc -l |grep setup

e28603cd853644168b42cf0c3ce18a17.png

ansible-doc setup

/EX

f9e196738a29429087d53b1fa48b7fee.png

 

使用临时命令找变量

查找ipv4相关的变量 ansible test -m setup -a "filter=*ipv4*"

5cba48e8a6ff448886d4cbe6ef321bf0.png

查找bios相关的变量 ansible test -m setup -a "filter=*bios*"

0ec95bb4f21746e686bfc5e03a2be1bd.png

查找cpu相关的变量 ansible test -m setup -a "filter=*cpu*"

67c4be16fc754edc80c72a3aa5cb9e46.png

 

1、编写模板,需求内容如下:

被控节点的ipv4地址

被控节点的bios版本

被控节点的CPU颗数

 

2、编写模板

vim test.j2

{{ ansible_default_ipv4.address }} {{ ansible_bios_version }}  {{ ansible_processor_vcpus }}

 

3、编写playbook将test.j2的模板复制到被控节点并显示具体值

复制带有变量的模板

ansible-doc -l | grep temp

e019d6f8735f4be2987e652b7773eb1e.png

ansible-doc template

8891a92e783440738fca55aa1747a8bb.png

编写playbook vim template.yml

---
- name: template
  hosts: test
  tasks:
  - name: Template a file to /etc/files.conf 
    template:
      src: test.j2
      dest: /tmp/test.txt 

 

ansible-playbook template.yml

c7f42cc881de4991acb17f5392707bba.png

ansible test -a "cat /tmp/test.txt"

52360d8c0eb74de881df5736ec8068cc.png

 

使用普通用户

要求使用user1用户部署ansible,生效的配置文件为/home/user1/ansible.cfg,清单文件路径为/home/user1/inventory

 

1、查看当前生效的配置文件

ansible --version

b61296dda16a44d9ac4da72608760d95.png

2、修改生效的配置文件

cp /etc/ansible/ansible.cfg .

ls

64f92b49ff4f4223a290efbf17c286a4.png

3、修改清单文件

vim ansible.cfg

inventory      = /home/user1/inventory

inventory      = /etc/ansible/hosts

e400ccd0b4c0427c8e3999a73ae1c175.png

4、修改清单文件内容

vim /home/user1/inventory

[dev]

192.168.23.142

3bdc7609116042ba99fdc7e293a020d8.png

图形化的方式显示 Ansible 库存(inventory)的结构 ansible-inventory --graph

26f4efc716be429db06352472a09e813.png

 

5、使用临时命令做测试(报错)

ansible dev -a "ls"

f6a2783ee7544b6cb746abb86c3d083d.png

这个错误信息表明,Ansible 尝试通过 SSH 连接到目标主机,但被拒绝了。拒绝的原因可能是以下几种情况之一:

  1. SSH 密钥问题:目标主机拒绝了你的 SSH 密钥。这可能是因为你使用的密钥没有被添加到目标主机的 ~/.ssh/authorized_keys 文件中。
  2. 用户名或密码错误:如果你使用的是密码认证方式,那么可能是用户名或密码错误。
  3. SSH 配置问题:目标主机的 SSH 配置可能不允许你使用的认证方式。
  4. 防火墙或网络问题:目标主机的防火墙可能阻止了 SSH 连接,或者存在其他网络问题。

为了进一步排查这个问题,你可以尝试以下步骤:

  1. 检查 SSH 密钥:确保你使用的 SSH 密钥已经被添加到目标主机的 ~/.ssh/authorized_keys 文件中。
  2. 检查用户名和密码:如果你使用的是密码认证方式,确保你输入的用户名和密码是正确的。
  3. 检查 SSH 配置:查看目标主机的 SSH 配置文件(通常是 /etc/ssh/sshd_config),确保配置允许你使用的认证方式。
  4. 检查防火墙和网络配置:确保目标主机的防火墙没有阻止 SSH 连接,并且网络配置正确。

 

ansible dev -a "ls" -k

SSH password: 被控节点的密码

23b6aab6640c459cae6a840329401254.png

ansible dev -a "touch 1.txt" -k

SSH password: 被控节点的密码

c9a7070b077c4491938f4f1f4e6893d3.png

ansible dev -a "ls" -k

SSH password: 被控节点的密码

230720a3954344488a1899ac3b963723.png

 

6、免密

vim ansible.cfg

#取消指纹验证

 72 host_key_checking = False

 73 #host_key_checking = False

2b424a70f9174121b609be3961ad5788.png

#远程用户使用root身份执行

109 remote_user = root

110 #remote_user = root

7f078b7500fb43baa3634d00c206ac2b.png

 

设置密码 vim inventory

  1 [all:vars]

  2 ansible_password=123456

  3 [dev]

  4 192.168.23.142

3889f0e63bbf49c480d8289659a2cdb5.png

测试验证实验结果

ansible dev  -a "useradd stu1"

ansible dev  -a "id stu1"

df75ef449b91472b862fc0d33419610f.png

 

7,loop循环-未 vim loop.yml

---
- name: loop
  hosts: dev
  tasks:
  - name: Add the user
    user:
      name: student1
  - name: Add the user
    user:
      name: student2

验证实验效果

ansible-playbook loop.yml

f17d67cdd03a4bebaca1d466db30c3e4.png

ansible dev -a "tail -n 2 /etc/passwd"

11df721c3b434836a746f003088ab1c0.png

 

8,loop循环

vim loop.yml

---
- name: loop
  hosts: dev
  tasks:
  - name: Add the user
    user:
      name: "{{ item }}"
    loop:
    - stu10
    - stu11
    - stu12

 

ansible-playbook loop.yml

e2586c724824415bb2ebbc9356901d93.png

ansible dev -a "tail -n 3 /etc/passwd"

189ae8f5f41642a6afb001b87fb9eaf0.png

 

9,创建组 vim group.yml

---
- name: groupadd
  hosts: dev
  tasks:
  - name: Ensure group "somegroup" exists
    group:
      name: "{{ item }}"
      state: present
    loop:
    - group10
    - group20
    - group30

 

ansible-playbook group.yml

79ca01ed33cd420a8a05c439b52642d2.png

ansible dev -a "tail -n 3 /etc/group"

e5f9fbb189dd4d0fb2cba10498576d5b.png

 

10,item.name、item.uid、item.groups

vim loop.yml

---
- name: loop
  hosts: dev
  tasks:
  - name: Add the user
    user:
      name: "{{ item.name  }}"
      uid: "{{ item.uid  }}"
      group: "{{ item.group  }}"
    loop:
    - name: userq1
      uid: 1050
      group: group10
    - name: userq2
      uid: 1040
      group: group20
    - name: userq3
      uid: 1030
      group: group30

 

ansible-playbook loop.yml

7caf97fb97a444479eb83f06a2a3c1f1.png

ansible dev -a "tail -n 3 /etc/passwd"

e89204c1db264e7196fe98d6f71e959a.png

ansible dev -a "id userq1"

ansible dev -a "id userq2"

ansible dev -a "id userq3"

464654ab6abd45ee9b6ac8efeece3b56.png

 

相关文章:

linux部署ansible自动化运维

ansible自动化运维 1,编写ansible的仓库(比赛已经安装,无需关注) 1、虚拟机右击---设置---添加---CD/DVD驱动器---完成---确定 2、将ansible.iso的光盘连接上(右下角呈绿色状态) 3、查看光盘挂载信息 df -h…...

springboot421社区医疗服务可视化系统(论文+源码)_kaic

摘 要 传统办法管理信息首先需要花费的时间比较多,其次数据出错率比较高,而且对错误的数据进行更改也比较困难,最后,检索数据费事费力。因此,在计算机上安装社区医疗服务可视化系统软件来发挥其高效地信息处理的作用…...

vue渲染时闪光白屏问题怎么解决(笔记)

Vue渲染时出现闪光白屏问题,可能是因为页面内容需要较长时间才能加载完成,而在加载期间,页面会显示白屏或者空白内容,给用户体验带来负面影响。 解决方法: 为标签绑定 v-cloak 在样式中写 v-clock {displa&#xff…...

duxapp 2024-12-09 更新 PullView可以弹出到中间,优化CLI使用体验

UI库 修复 Button 禁用状态失效的问题Modal 组件即将停用,请使用 PullView 基础库 PullView side 新增 center 指定弹出到屏幕中间PullView 新增 duration 属性,指定动画时长新增 useBackHandler hook 用来阻止安卓端点击返回键 RN端 修复 windows …...

vue调试插件vue Devtools下载安装

Vue.js Devtools_6.6.3_Chrome插件下载_极简插件 进图官网点击推荐下载下载该调试工具 解压缩找到扩展程序开启开发者模式 将解压缩的文件拖拽到该页面空白处,点击添加扩展程序 点击详情允许访问文件网址 页面右键检查可以发现已经成功添加该页面调试插件...

.net core使用AutoMapper

AutoMapper 是一个用于 .NET 平台的对象映射工具,它简化了不同对象类型之间的转换过程。在软件开发中,尤其是在分层架构的应用程序里,常常需要在不同的对象模型之间进行数据传递,例如从数据库实体到视图模型、DTO(数据…...

HTTP头注入

注入类漏洞经久不衰,多年保持在owasp Top 10的首位。今天就聊聊那些被人遗忘的http头注入。用简单的实际代码进行演示,让每个人更深刻的去认识该漏洞。 3|0HOST注入 在以往http1.0中并没有host字段,但是在http1.1中增加了host字段&#xff…...

110.【C语言】编写命令行程序(1)

目录 1.前置知识 "命令"的含义 运行C语言程序 2.介绍 main函数的参数 实验1 执行结果 实验2 执行结果 修改代码 实验3 分析 方法:遍历数组argv[]中的所有参数 执行结果 修改代码 执行结果 1.前置知识 "命令"的含义 WINR输入cmd,在cmd窗口下…...

k8s 之 StatefulSet

深入理解StatefulSet(一):拓扑状态 k8s有状态与无状态的区别 无状态服务:deployment Deployment被设计用来管理无状态服务的pod,每个pod完全一致.什么意思呢? 无状态服务内的多个Pod创建的顺序是没有顺序的. 无状态服务内的多…...

PTA 7-2 从身份证号码中提取出出生年月

分数 12 作者 崔孝凤 单位 山东理工大学 输入一个18位的身份证号码,提取出年份和月份并输出,请判断输入的号码是否是18位,如果不是请提示"Invalid data,input again!",并重新输入新的号码。 输入格式: 输入一个18位…...

Plugin - 插件开发04_Spring Boot中的SPI机制与Spring Factories实现

文章目录 Pre方案概览使用插件的好处Spring Boot中的SPI机制与Spring Factories实现1. Spring Boot中的SPI机制Spring Factories文件 2. Spring Factories实现原理3. Code3.1 定义一个服务接口3.2 定义 实现类3.3 配置 spring.factories 文件3.4 创建一个Controller来加载插件3…...

GUNS搭建

一、准备工作 源码下载: 链接: https://pan.baidu.com/s/1bJZzAzGJRt-NxtIQ82KlBw 提取码: criq 官方文档 二、导入代码 1、导入后端IDE 导入完成需要,需要修改yml文件中的数据库配置,改成自己的。 2、导入前端IDE 我是用npm安装的yarn npm…...

路径规划之启发式算法之十四:蜘蛛蜂优化算法(Spider Wasp Optimizer, SWO)

蜘蛛蜂优化算法(Spider Wasp Optimizer, SWO)是一种受自然界中蜘蛛蜂行为启发的元启发式智能优化算法。由Mohamed Abdel-Basset等人于2023年提出,算法模拟了雌性蜘蛛蜂的狩猎、筑巢和交配行为,具有独特的更新策略,适用于具有不同探索和开发需求的广泛优化问题。 一、算法背…...

OpenGL ES详解——多个纹理实现混叠显示

目录 一、获取图片纹理数据 二、着色器编写 1. 顶点着色器 2. 片元着色器 三、绑定和绘制纹理 1. 绑定纹理 2. 绘制纹理 四、源码下载 一、获取图片纹理数据 获取图片纹理数据代码如下: //获取图片1纹理数据 mTextureId loadTexture(mContext, R.mipmap.…...

Java多线程与线程池技术详解(八)

《星游记》 “如果只有傻瓜才相信梦想,那么就叫我大傻瓜吧!” 《一人之下》 “想走的路不好走,想做人不好做,都说是身不由己,不是废话么。己不由心,身又岂能由己!” 目录 上一篇博客习题讲解 编…...

2024年12月11日Github流行趋势

项目名称:maigret 项目维护者:soxoj, kustermariocoding, dependabot, fen0s, cyb3rk0tik项目介绍:通过用户名从数千个站点收集个人档案信息的工具。项目star数:12,055项目fork数:870 项目名称:uv 项目维护…...

ThinkPHP 6.0 PHP新手教程

1、系统配置文件 下面系统自带的配置文件列表及其作用: 配置文件名描述app.php应用配置cache.php缓存配置console.php控制台配置cookie.phpCookie配置database.php数据库配置filesystem.php磁盘配置lang.php多语言配置log.php日志配置middleware.php中间件配置rou…...

【Excel学习记录】02-单元格格式设置

1.单元格格式工具美化表格 单元格格式位置 选中单元格,右键→设置单元格格式 合并居中 跨越合并 字体类型、大小、颜色、填充底纹、边框 斜线 软回车:alt enter 格式刷 2.单元格数字格式 格式不影响数值,只是展示形式 日期本质也是数…...

Paimon Tag和Branch创建文件存储过程

结论: 如果data-file被引用则不会被压缩,压缩仅针对未被引用的文件,创建tag时候根据当前快照进行创建 1、实际表和Manifest的内容 查看tag的内容 select * from table$tags;或者直接查看tag ossutil cat oss://test-dataware/warehouse/te…...

HCIA笔记8--DHCP、Telnet协议

1. DHCP介绍 对于主机的网络进行手动配置,在小规模的网络中还是可以运作的,但大规模网络是无力应对的。因此就有了DHCP协议来自动管理主机网络的配置。 DHCP(Dynamic Host Configuration Protocol): 动态主机配置协议,主要需要配置的参数有…...

Tableau数据可视化与仪表盘搭建

1.Tableau介绍 可视化功能 数据赋能 数据赋能就是将我们的数据看板发布到我们的线上去 这里的IP地址是业务部门可以通过账号密码登入的 我们也可以根据需要下载,选中并点击下载即可 下载下来之后,自己就能根据数据进行自定义的分析 也可以下载图片 还有…...

Django结合websocket实现分组的多人聊天

其他地方和上一篇大致相同,上一篇地址点击进入, 改动点1:在setting.py中最后再添加如下配置: # 多人聊天 CHANNEL_LAYERS {"default":{"BACKEND": "channels.layers.InMemoryChannelLayer"} }因此完整的se…...

自动驾驶控制与规划——Project 1: 车辆纵向控制

目录 零、任务介绍一、环境配置1.1 CARLA的配置1.2 Docker Ubuntu 20.04 ROS2 Foxy的配置 二、算法2.1 定速巡航2.2 自适应巡航2.3 离散PID控制 三、代码实现3.1 代码补全3.2仿真验证 零、任务介绍 课程主页 配置Carla仿真器配置carla-ros-bridge补全src\ros-bridge\carla_s…...

基于python实现自动化的验证码识别:探索与实践

基于python实现自动化的验证码识别:探索与实践 一、验证码的类型及特点(一)图像验证码(二)短信验证码(三)语音验证码 二、验证码识别的方法*(一)传统图像处理方法&#x…...

如何保证消息队列的高可用?(RabbitMQ)

RabbitMQ 是基于主从(非分布式)做高可用性的,RabbitMQ 有三种模式:单机模式、普通集群模式、镜像集群模式 1、单机模式:一般没人生产用单机模式 2、普通集群模式: 普通集群模式用于提高系统的吞吐量&…...

es的join是什么数据类型

在 Elasticsearch 中,parent 并不是一个独立的数据类型,而是与 join 数据类型一起使用的一个概念。join 数据类型用于在同一个索引中建立父子文档之间的关系,允许你在一个索引内表示层级结构或关联关系。通过 join 字段,你可以定义不同类型的文档(如父文档和子文档),并指…...

爬虫基础之代理的基本原理

在做爬虫的过程中经常会遇到一种情况,就是爬虫最初是正常运行、正常抓取数据的,一切看起来都是那么美好,然而一杯茶的工夫就出现了错误,例如 403 Forbidden,这时打开网页一看,可能会看到“您的IP访问频率太…...

golang实现简单的reids服务2

golang实现redis兼容的redis服务实现redis兼容的redis服务思路 golang实现redis兼容的redis服务 之前做的redis服务是通过tcp封装的自定义协议 原版项目地址:https://github.com/dengjiayue/my-redis.git 那么能不能实现一个redis兼容的redis服务,这样一般的redis包也可以调…...

CSS常用的尺寸单位

像素px 以屏幕上的一个点为单位&#xff0c;比较稳定和精确用的最多 em 以字体大小为参考&#xff0c;&#xff08;是自身字体大小的倍数&#xff09;当自身的字体大小改变时&#xff0c;em也会随着改变em * font-size px rem 以根元素 < html > 作为参考&#xff…...

计算机网络 备查

OSI 七层模型 七层模型协议各层实现的功能 简要 详细 TCP/IP协议 组成 1.传输层协议 TCP 2.网络层协议 IP 协议数据单元&#xff08;PDU&#xff09;和 封装 数据收发过程 数据发送过程 1. 2.终端用户生成数据 3.数据被分段&#xff0c;并加上TCP头 4.网络层添加IP地址信息…...

JavaEE 【知识改变命运】05 多线程(4)

文章目录 单例模式什么是单例模式饿汉模式懒汉模式多线程- 懒汉模式分析多线程问题第一种添加sychronized的方式第二种添加sychronized的方式改进第二种添加sychronized的方式&#xff08;DCL检查锁&#xff09; 阻塞队列什么是阻塞队列什么是消费生产者模型标准库中的阻塞队列…...

迭代器和生成器

一、迭代器&#xff08;Iterator&#xff09; 1. 什么是迭代器&#xff1f; 迭代器是一个可以在某一集合&#xff08;如列表、元组等&#xff09;中逐个访问元素的对象。它提供了一个方法&#xff0c;可以记住遍历的位置&#xff0c;每次取出一个元素&#xff0c;直到所有元素…...

小发现,如何高级的顺序输出,逆序输出整数的每一位(栈,队列)

当我还是初学者的时候&#xff0c;我经常思考有没有比慢慢求每一位数字然后考虑正序&#xff0c;逆序输出要快的办法...长期琢磨&#xff0c;必有所获&#xff01; 我刚学数据结构的时候还没意识到栈&#xff0c;队列还能这样用&#xff0c;虽然说有点杀鸡用牛刀的感觉&#x…...

前端换行、空格的多种表现形式

换行 1、<br> 标签 这是最直接的方式&#xff0c;用于在文本中插入一个简单的换行。<br> 标签是一个空元素&#xff0c;意味着它不需要结束标签。 示例&#xff1a; <p>这是第一行。<br>这是第二行。</p>2、CSS white-space 属性 通过CSS的w…...

自己总结:selenium高阶知识

全篇大概10000字&#xff08;含代码&#xff09;&#xff0c;建议阅读时间30min 一、等待机制 如果有一些内容是通过Ajax加载的内容&#xff0c;那就需要等待内容加载完毕才能进行下一步操作。 为了避免人为操作等待&#xff0c;会遇到的问题&#xff0c; selenium将等待转换…...

无线遥控红外通信

无线遥控红外通信 红外发射装置一般是指红外遥控器由 键盘电路 &#xff0c;红外编码电路 电源电路 和红外发射 电路组成 一般的红外线波长为940nm左右&#xff0c;外形与普通发光二极管相同 红外遥控为了提高抗干扰性能和降低电源消耗&#xff0c;红外遥控器常用载波的方式传送…...

第一个C++程序--(蓝桥杯备考版)

第一个C程序 基础程序 #include <iostream>//头⽂件 using namespace std;//使⽤std的名字空间 int main()//main函数 {cout << "hello world!" << endl; //输出&#xff1a;在屏幕打印"hello world!" return 0;}main函数 main 函数是…...

Rust包管理和构建工具

Cargo 是 Rust 语言的包管理和构建工具。它提供了一套完整的工具链&#xff0c;用于管理 Rust 项目的依赖关系、编译代码、运行测试和生成文档。Cargo 极大地简化了 Rust 项目的开发和部署过程&#xff0c;使得开发者可以专注于编写代码&#xff0c;而不是处理构建系统的复杂性…...

STM32输入捕获详解

目录 一、引言 二、输入捕获原理 三、寄存器介绍 四、配置步骤 1.开启时钟 2.GPIO 初始化 3.初始化定时器 4.配置输入捕获模式 5.使能捕获和更新中断 6.设置中断分组并编写中断服务函数 7.使能定时器 五、程序示例 六、总结 一、引言 在嵌入式系统开发中&#xff0…...

利用高德地图API,如何在PHP与vue3中实现地图缩放功能

文章精选推荐 1 JetBrains Ai assistant 编程工具让你的工作效率翻倍 2 Extra Icons&#xff1a;JetBrains IDE的图标增强神器 3 IDEA插件推荐-SequenceDiagram&#xff0c;自动生成时序图 4 BashSupport Pro 这个ides插件主要是用来干嘛的 &#xff1f; 5 IDEA必装的插件&…...

Selenium WebDriver:自动化网页交互的利器

Selenium WebDriver&#xff1a;自动化网页交互的利器 在当今快速发展的Web开发领域&#xff0c;自动化测试已经成为确保应用程序质量和用户体验的重要手段。Selenium WebDriver&#xff0c;作为Selenium工具包中的核心组件&#xff0c;正是这一领域的佼佼者。本文将详细介绍S…...

uniapp -- 实现页面滚动触底加载数据

效果 首选,是在pages.json配置开启下拉刷新 {"path": "pages/my/document/officialDocument","style": {"navigationStyle":</...

用ChatGPT-o1进行论文内容润色效果怎么样?

目录 1.引导问题发现 2.角色设定 3.整理常问修改 4.提供样例 5.小细节 小编在这篇文章中分享如何充分利用ChatGPT-o1-preview来提升论文润色的技巧。小编将持续跟进最新资源和最新的调研尝试结果&#xff0c;为宝子们补充更多实用的写作技巧。这些技巧将有助于您更有效地利…...

6 C/C++输⼊输出(下)(未完续)

1. OJ&#xff08;online judge&#xff09;题⽬输⼊情况汇总 在竞赛的 OJ 题⽬中&#xff0c;⼀般关于输⼊场景总结为下⾯四类&#xff1a; 接下来&#xff0c;我们就结合题⽬&#xff0c;给⼤家分别介绍。 1.1 单组测试⽤例 练习1 B2009 计算 (ab)/c 的值 - 洛谷 | 计算机科…...

题海拾贝:力扣 20、有效的括号

Hello大家好&#xff01;很高兴我们又见面啦&#xff01;给生活添点passion,开始今天的编程之路&#xff01; 我的博客&#xff1a;<但凡.-CSDN博客 我的专栏&#xff1a;《编程之路》、《题海拾贝》、《数据结构与算法之美》 欢迎点赞、关注&#xff01; 1、题目 2、题解 这…...

视频推拉流EasyDSS无人机直播技术巡查焚烧、烟火情况

焚烧作为一种常见的废弃物处理方式&#xff0c;往往会对环境造成严重污染。因此&#xff0c;减少焚烧、推广绿色能源和循环经济成为重要措施。通过加强森林防灭火队伍能力建设与长效机制建立&#xff0c;各地努力减少因焚烧引发的森林火灾&#xff0c;保护生态环境。 巡察烟火…...

基于Hermite多项式的三维反时间波的生成

原创&#xff1a;daode3056(daode1212) 反时间波&#xff0c;也称为时间反演波&#xff0c;是一种在特定条件下能够实现波的聚焦和传播的技术。反时间波的产生基于时间反演技术&#xff0c;其原理和方法通常有&#xff1a; 1. [时间反演信号处理原理]: 时间反演技术并不是指时间…...

数据结构与算法复习AVL树插入过程

环境 $ cat /proc/version Linux version 6.8.0-45-generic (builddlcy02-amd64-115) (x86_64-linux-gnu-gcc-13 (Ubuntu 13.2.0-23ubuntu4) 13.2.0, GNU ld (GNU Binutils for Ubuntu) 2.42) #45-Ubuntu SMP PREEMPT_DYNAMIC Fri Aug 30 12:02:04 UTC 2024 #include <std…...

MetaGPT源码 (Memory 类)

目录 MetaGPT源码&#xff1a;Memory 类例子 MetaGPT源码&#xff1a;Memory 类 这段代码定义了一个名为 Memory 的类&#xff0c;用于存储和管理消息(Message)对象。Memory 提供了多种操作消息的功能&#xff0c;包括添加单条或批量消息、按角色或内容筛选消息、删除最新消息…...

day1数据结构,关键字,内存空间存储与动态分区,释放

小练习 在堆区空间连续申请5个int类型大小空间&#xff0c;用来存放从终端输入的5个学生成绩&#xff0c;然后显示5个学生成绩&#xff0c;再将学生成绩升序排序&#xff0c;排序后&#xff0c;再次显示学生成绩。显示和排序分别用函数完成&#xff08;两种排序方法&#xff0…...