培训第三十天(ansible模块的使用)
上午
ansible是⼀种由Python开发的⾃动化运维⼯具,集合了众多运维⼯ 具(puppet、cfengine、chef、func、fabric)的优点,实现了批量 系统配置、批量程序部署、批量运⾏命令等功能。
1、学习ansible的使用
ansible 主机ip|域名|组名|别名 -m ping|copy... ‘参数’
(1)下载ansible软件包
[root@1 ~]# yum -y install ansible
(2)创建ansible组
ansible通过⼀个主机清单功能来实现服务器分组。
Ansible的默认主机清单配置⽂件为/etc/ansible/hosts.
[root@1 ~]# vim /etc/ansible/hosts [group01]10.0.0.1210.0.0.1310.0.0.14[group02]10.0.0.1210.0.0.13

(3)执行ansible的ping命令
(测试网络连通性)
主机12和主机13都进行了免密,主机14未进行免密
ssh-keygenssh-copy-id -i 10.0.0.12ssh-copy-id -i 10.0.0.13
[root@1 ~]# ansible 10.0.0.12 -m ping10.0.0.12 | SUCCESS => {"ansible_facts": {"discovered_interpreter_python": "/usr/bin/python"}, "changed": false, "ping": "pong"}[root@1 ~]# ansible group02 -m ping10.0.0.12 | SUCCESS => {"ansible_facts": {"discovered_interpreter_python": "/usr/bin/python"}, "changed": false, "ping": "pong"}10.0.0.13 | SUCCESS => {"ansible_facts": {"discovered_interpreter_python": "/usr/bin/python"}, "changed": false, "ping": "pong"}
# 由于group01中的10.0.0.14主机未做免密操作,所以会产生报错[root@1 ~]# ansible group01 -m pingThe authenticity of host '10.0.0.14 (10.0.0.14)' can't be established.ECDSA key fingerprint is SHA256:/p0PnfBbtW2E/MOWaBziXwCBEnuznb+x1DiNgh1+qJw.ECDSA key fingerprint is MD5:62:73:f0:9f:e3:b5:f1:d2:d4:73:b3:2e:1b:14:16:d0.Are you sure you want to continue connecting (yes/no)? yes10.0.0.14 | UNREACHABLE! => {"changed": false, "msg": "Failed to connect to the host via ssh: Warning: Permanently added '10.0.0.14' (ECDSA) to the list of known hosts.\r\nPermission denied (publickey,gssapi-keyex,gssapi-with-mic,password).", "unreachable": true}
(4)为主机设置ansible别名(携带用户和密码)
没有做免密登录的服务器可以指定⽤户名与密码
[root@1 ~]# vim /etc/ansible/hostsother ansible_ssh_host=10.0.0.14 ansible_ssh_port=22 ansible_ssh_user=root ansible_ssh_pass=1[group01]10.0.0.1210.0.0.13other[root@1 ~]# ansible group01 -m ping10.0.0.13 | SUCCESS => {"ansible_facts": {"discovered_interpreter_python": "/usr/bin/python"}, "changed": false, "ping": "pong"}10.0.0.12 | SUCCESS => {"ansible_facts": {"discovered_interpreter_python": "/usr/bin/python"}, "changed": false, "ping": "pong"}other | SUCCESS => {"ansible_facts": {"discovered_interpreter_python": "/usr/bin/python"}, "changed": false, "ping": "pong"}[root@1 ~]# ansible other -m pingother | SUCCESS => {"ansible_facts": {"discovered_interpreter_python": "/usr/bin/python"}, "changed": false, "ping": "pong"}
(5)查看ansible帮助信息
查看所有⽀持的模块
[root@1 ~]# ansible-doc -l
如果要查看ping模块的⽤法,使⽤下⾯命令(其它模块以此类推)# ansible-doc ping
(6)ansible hostname模块的使用
使用ansible(hostname模块)批量修改主机名
(注意: 它不能修改/etc/hosts⽂件)
基本格式为: ansible 操作的机器名或组名 -m 模块名 -a "参数 1=值1 参数2=值2"
[root@1 ~]# ansible group02 -m hostname -a 'name=ab.li'
(7)练习
不论你用哪种环境(免密或者不免密,端口是否22),请最终将两台被管理机器加入到group1组即可
vim /etc/ansible/hostsweb01 ansible_ssh_host=10.0.0.12 ansible_ssh_user=root ansible_ssh_pass=1 ansible_ssh_port=22 web02 ansible_ssh_host=10.0.0.13 ansible_ssh_user=root ansible_ssh_pass=1 ansible_ssh_port=2222[group1]web01web02
下午
1、ansible介绍
ansible是基于模块⼯作的,本身没有批量部署的能⼒。真正具有批量部署的是ansible所运⾏的模块,ansible只是提供⼀种框架。
2、ansible file模块的使用
file模块⽤于对⽂件相关的操作(创建, 删除, 软硬链接等)
(1)创建目录
创建目录[root@1 ~]# ansible group02 -m file -a 'path=/tmp/abc/def state=directory'
(2)创建文件
[root@1 ~]# ansible group1 -m file -a 'path=/test/111 state=touch'
(3)递归修改owner,group,mode
[root@1 ~]# ansible group02 -m file -a 'path=/tmp/abc recurse=yes owner=bin group=daemon mode=1777'[root@2 ~]# ll /tmp/总用量 0drwxrwxrwt. 3 bin daemon 17 8月 16 14:09 abc[root@2 ~]# ll /tmp/abc/总用量 0drwxrwxrwt. 2 bin daemon 6 8月 16 14:09 def
(4)删除⽬录
(连同⽬录⾥的所有⽂件)
[root@1 ~]# ansible group02 -m file -a 'path=/tmp/abc state=absent'
(5)创建⽂件并指定owner,group,mode等
[root@1 ~]# ansible group02 -m file -a 'path=/tmp/aaa state=touch owner=bin group=daemon mode=1777'
(6)创建软链接⽂件
(软链接指向硬链接,硬链接指向文件)
[root@1 ~]# ansible group02 -m file -a 'src=/etc/fstab path=/tmp/xxx state=link' [root@2 ~]# ll /tmp/lrwxrwxrwx. 1 root root 10 8月 16 14:30 xxx -> /etc/fstab
(7)创建硬链接⽂件
[root@1 ~]# ansible group02 -m file -a 'src=/etc/fstab path=/tmp/xxx2 state=hard'[root@2 ~]# ll /tmp/-rw-r--r--. 2 root root 502 7月 23 03:23 xxx2
3、ansible stat模块的使用
stat模块类似linux的stat命令,⽤于获取⽂件的状态信息。
获取/etc/fstab⽂件的状态信息
[root@1 ~]# ansible group02 -m stat -a 'path=/etc/fstab'
4、ansible copy模块的使用
copy模块⽤于对⽂件的远程拷⻉操作(如把本地的⽂件拷⻉到远程的机器上)
(1)拷贝文件
拷⻉mysql文件到10.0.0.12主机上
[root@1 ~]# ansible 10.0.0.12 -m copy -a 'src=/root/mysql57.tar.gz dest=/root/'[root@1 ~]# ansible group02 -m copy -a 'src=/etc/fstab dest=/tmp/a.txt backup=yes owner=bin group=daemon mode=1777'
(2)远程向文件中写入数据
使⽤content参数(默认会覆盖原内容)
[root@1 ~]# ansible group01 -m copy -a 'content="wo" dest=~/tst'# 注意:ansible中-a后⾯的参数⾥也有引号时,记得要单引双引交叉使⽤,如果都为双引会出现问题
(3)force参数的使用,是否强制覆盖执行命令
如果⽬标⽂件已经存在,则会强制覆盖(force=yes)
如果⽬标⽂件已经存在,则不覆盖(force=no)
[root@1 ~]# touch tst[root@1 ~]# ansible group02 -m copy -a 'src=./tst dest=/root/ force=no'[root@1 ~]# dd if=/dev/zero of=tst1 bs=100M count=1[root@1 ~]# ansible group01 -m copy -a 'src=./tst1 dest=/root/ force=yes'[root@1 ~]# ansible group01 -m copy -a 'content="wo" dest=~/tst force=no'# 不执行写入操作,操作无意义
(4)backup参数控制是否备份⽂件
[root@1 ~]# ansible group01 -m copy -a 'src=./tst dest=~ backup=yes owner=bin group=daemon mode=1777'# backup=yes表示如果拷⻉的⽂件内容与原内容不⼀样,则会备份⼀份(将原来的文件修改文件名变成备份文件)
(5)拷贝目录
copy模块拷⻉时要注意拷⻉⽬录后⾯是否带"/"符号
后⾯不带/符号,则表示把整个⽬录拷⻉过去
后⾯带/符号,则表示把⽬录⾥的所有⽂件拷⻉过去
[root@1 ~]# ansible group01 -m copy -a 'src=/etc/yum.repos.d dest=/etc/yum.repos.d/ backup=yes'[root@2 ~]# ls /etc/yum.repos.d/CentOS-Base.repo epel.repo epel-testing.repo hh.repo repo.tar.gz yum.repos.d
5、ansible template模块的使用
与copy模块功能⼏乎⼀样
template模块⾸先使⽤变量渲染jinja2模板⽂件成普通⽂件,然后再复制过去.⽽copy模块不⽀持.(jinja2是⼀个基于python的模板引擎)
ansible.builtin.template module – Template a file out to a target host — Ansible Community Documentation
ansible -m template group01 -a "src=/etc/hosts dest=/tmp/hosts"
template模块不能拷⻉⽬录
ansible -m template group01 -a "src=/etc/yum.repos.d/ dest=/etc/yum.repos.d/"
6、ansible fatch模块的使用
fetch模块与copy模块类似,但作⽤相反。⽤于把远程机器的⽂件拷⻉到本地(收文件)。
注意: fetch模块不能从远程拷⻉⽬录到本地
[root@1 ~]# ansible group01 -m fetch -a 'src=/etc/sysconfig/network-scripts/ifcfg-ens33 dest=/tmp'# 因为group01⾥有3台机器,为了避免同名⽂件⽂件冲突,它使⽤了不同的⽬录)[root@1 ~]# tree /tmp//tmp/├── 10.0.0.12│ └── etc│ └── sysconfig│ └── network-scripts│ └── ifcfg-ens33├── 10.0.0.13│ └── etc│ └── sysconfig│ └── network-scripts│ └── ifcfg-ens33├── other│ └── etc│ └── sysconfig│ └── network-scripts│ └── ifcfg-ens33
7、ansible user模块的使用
user模块⽤于管理⽤户账号和⽤户属性。
(1)创建普通用户
[root@1 ~]# ansible group02 -m user -a 'name=aaa state=present'
(2)创建系统用户,并设置shell环境为/sbin/nologin
[root@1 ~]# ansible group01 -m user -a 'name=mysql state=present system=yes shell="/sbin/nologin"'
(3)创建mysql账户,并指定uid和密码
# 创建mysql家目录[root@1 ~]# ansible group01 -m file -a 'path=/usr/local/mysql state=directory'# 创建mysql-files目录并修改文件的权限和所属主与组[root@1 ~]# ansible group01 -m file -a 'path=/usr/local/mysql/mysql-files state=directory owner=mysql group=mysql mode=750'
[root@1 ~]# ansible group01 -m user -a 'name=abc state=present uid=1999 password=abc'
生成加密密码
[root@1 ~]# echo 123456 | openssl passwd -1 -stdin$1$YxSnSopH$0t2l5RUA4m9JKlmjVZbta.
(4)创建普通用户,并产⽣空密码密钥对
[root@1 ~]# ansible group01 -m user -a 'name=hadoop generate_ssh_key=yes'
(5)删除用户,默认不删除家目录
[root@1 ~]# ansible group01 -m user -a 'name=hadoop state=absent'[root@2 ~]# ll /home/总用量 0drwx------. 2 aaa aaa 62 8月 16 16:03 aaadrwx------. 2 abc abc 62 8月 16 16:14 abcdrwx------. 3 2000 2000 74 8月 16 16:20 hadoopdrwx------. 2 mysql mysql 62 8月 16 16:06 mysql
(7)删除用户的同时删除家目录
使⽤remove=yes参数
[root@1 ~]# ansible group01 -m user -a 'name=aaa state=absent remove=yes'
8、ansible group模块的使用
group模块⽤于管理⽤户组和⽤户组属性。
(1)创建组
ansible group01 -m group -a 'name=groupa gid=3000 state=present'
(2)删除组
如果有⽤户的gid为此组,则删除不了
ansible group01 -m group -a 'name=groupa state=absent'
9、ansible cron模块的使用
cron模块⽤于管理周期性时间任务
创建⼀个cron任务,不指定user的话,默认就是root(因为这⾥是⽤root用户操作的)。
如果minute,hour,day,month,week不指定的话,默认都为*
(1)添加计划任务
[root@1 ~]# ansible group01 -m cron -a 'name="abc" user=root job="/usr/sbin/ntpdate cn.ntp.org.cn" hour=2'
(2)删除cron任务
[root@1 ~]# ansible group01 -m cron -a 'name="abc" state=absent'
10、ansible yum_repository模块的使用
yum_repository模块⽤于配置yum仓库。
(1)增加⼀个/etc/yum.repos.d/local.repo配置⽂件
注意:此模块只帮助配置yum仓库,但如果仓库⾥没有软件包,安装⼀ 样会失败。
所以可以⼿动去挂载光驱到/mnt⽬录
mount /dev/cdrom /mnt
ansible group01 -m yum_repository -a "name=local description=localyum baseurl=file:///mnt/ enabled=yes gpgcheck=no"
(2)删除/etc/yum.repos.d/local.repo配置⽂件
ansible group01 -m yum_repository -a "name=local state=absent"
11、ansible yum模块的使用
yum模块⽤于使⽤yum命令来实现软件包的安装与卸载。
(1)安装软件
[root@1 ~]# ansible group01 -m yum -a 'name=ntpdate state=present'
state=latest表示安装最新版本
ansible group01 -m yum -a 'name=httpd,httpddevel state=latest'
(2)卸载软件
ansible group1 -m yum -a 'name=httpd,httpddevel state=absent'
12、ansible service模块的使用
service模块⽤于控制服务的启动,关闭,开机⾃启动等。
(1)启动服务
# 启动vsftpd服务,并设为开机⾃动启动ansible group01 -m service -a 'name=vsftpd state=started enabled=on'
(2)关闭服务
# 关闭filewalld服务,并设为开机不⾃动启动[root@1 ~]# ansible group01 -m service -a 'name=firewalld state=stopped enabled=false'
13、ansible script模块的使用
script模块⽤于在远程机器上执⾏本地脚本。
(此脚本不⽤给执⾏权限)
[root@1 ~]# vim /tmp/1.sh[root@1 ~]# ansible group01 -m script -a '/tmp/1.sh'
练习:使⽤shell脚本实现在group01的被管理机⾥的mariadb⾥创建⼀ 个abc库
[root@1 ~]# vim /tmp/2.sh#!/bin/bashyum install mariadb-server -y &> /dev/nullsystemctl start mariadbsystemctl enable mariadbmysql << EOFcreate database abc;quitEOF[root@1 ~]# ansible group01 -m script -a '/tmp/2.sh'
14、ansible command模块与shell模块的使用
两个模块都是⽤于执⾏linux命令的,这对于命令熟悉的⼯程师来说,⽤起来⾮常high。
shell模块与command模块差不多(command模块不能执⾏⼀些类似 $HOME,>,<,|等符号,但shell可以)
(1)使用command模块创建用户
[root@1 ~]# ansible group01 -m command -a 'useradd user1'[root@1 ~]# ansible group01 -m command -a 'id user1'10.0.0.13 | CHANGED | rc=0 >>uid=2000(user1) gid=2000(user1) 组=2000(user1)10.0.0.12 | CHANGED | rc=0 >>uid=2000(user1) gid=2000(user1) 组=2000(user1)other | CHANGED | rc=0 >>uid=2000(user1) gid=2000(user1) 组=2000(user1)
(2)使用shell模块使用管道符进行统计查询信息
[root@1 ~]# ansible group01 -m shell -a 'cat /etc/passwd | wc -l'10.0.0.13 | CHANGED | rc=0 >>2210.0.0.12 | CHANGED | rc=0 >>22other | CHANGED | rc=0 >>22
(3)使用shell模块使用$HOME变量
[root@1 ~]# ansible -m shell group01 -a "cd $HOME;pwd"10.0.0.13 | CHANGED | rc=0 >>/rootother | CHANGED | rc=0 >>/root10.0.0.12 | CHANGED | rc=0 >>/root
(4)使用command模块进行关机
[root@1 ~]# ansible group01 -m command -a 'shutdown -h 0'10.0.0.12 | FAILED | rc=-1 >>Failed to connect to the host via ssh: ssh: connect to host 10.0.0.12 port 22: Connection refusedother | FAILED | rc=-1 >>Failed to connect to the host via ssh: ssh_exchange_identification: read: Connection reset by peer10.0.0.13 | CHANGED | rc=0 >>Shutdown scheduled for 五 2024-08-16 16:49:28 CST, use 'shutdown -c' to cancel.
注意: shell模块并不是百分之百任何命令都可以,⽐如vim或ll别名就不可以。
相关文章:
培训第三十天(ansible模块的使用)
上午 ansible是⼀种由Python开发的⾃动化运维⼯具,集合了众多运维⼯ 具(puppet、cfengine、chef、func、fabric)的优点,实现了批量 系统配置、批量程序部署、批量运⾏命令等功能。 1、学习ansible的使用 ansible 主机ip|域名|组…...
关于Log4net的使用记录——无法生成日志文件输出
关于Log4net的使用记录 前言遇到的问题具体使用总结前言 最近在使用log4net进行日志记录,保存一些需要的数据,以便后期使用需要。在使用的时候出现没有生成日志文件,针对这些问题,发现解决的办法! 遇到的问题 报错,提示没有找到对应的文件。 log4net:ERROR Failed to f…...
golang Kratos 概念
"Kratos"指的是一个开源的微服务框架,它用于构建高性能和可扩展的云原生应用。Kratos框架提供了一套丰富的工具和库,旨在简化微服务的开发和维护。下面是Kratos框架的一些基本概念: 服务构建与注册: gRPC与HTTP服务&…...
入门 MySQL 数据库:基础指南
简介 MySQL 是一个非常流行的开源关系型数据库管理系统(RDBMS),广泛用于 Web 应用、企业应用和数据仓库。本博客将引导你从零开始,学习 MySQL 数据库的基础知识。 什么是 MySQL? MySQL 是一个基于 SQL(Str…...
【Hexo系列】【3】使用GitHub自带的自定义域名解析
上一期我们通过学习【Hexo系列】【2】使用Vercel加速Hexo博客访问使用Vercel进行GitHub同步与加速,有时候Vercel也不太稳定访问不了。本身GitHub也是支持自定义域名的,本次教程将讲解如何使用GitHub自带的自定义域名解析。 1. GitHub设置 1.1 登录GitH…...
智能监控,无忧仓储:EasyCVR视频汇聚+AI智能分享技术为药品仓库安全保驾护航
随着科技的飞速发展,药品仓库的安全管理正迎来前所未有的变革。药品作为直接关系到公众健康的重要物资,其安全存储和监管显得尤为重要。在这个背景下,视频汇聚平台EasyCVR视频智能管理系统的应用,为药品仓库的安全监管提供了强有力…...
本地创建PyPI镜像
背景: 在安装一些库时,经常需要反复下载包(有的体积比较大,所以会比较慢),所以考虑在本地创建一个pypi镜像,把常用的库缓存下来,这样安装就会很省事.比较从本地安装库和从服务器下载会快很多. 安装使用 安装:pip install devpi 初始化: devpi-init --serverdirF:\pypioutput…...
使用 Elasticsearch RestHighLevelClient 进行查询
Elasticsearch 提供了多种客户端库,以方便不同编程语言的用户进行操作。其中,Java 的 RestHighLevelClient 是 Elasticsearch 官方推荐的客户端之一,用于 Java 应用程序中。本文将介绍如何使用 Java 的 RestHighLevelClient 进行 Elasticsear…...
【jvm】符号引用
目录 1. 说明2. 特点3. 组成与格式4. 作用5. 过程 1. 说明 1.在Java虚拟机中,符号引用(Symbolic Reference)是一种重要的引用机制。2.它主要用于在编译阶段和类加载阶段之间建立对类、方法、字段等元素的引用关系。3.符号引用是指用一个符号…...
征服云端:Java微服务与Docker容器化之旅
引言 随着云计算技术的迅猛发展,越来越多的企业开始拥抱云原生技术。在这个过程中,微服务架构以其独特的魅力成为了众多开发者的首选方案。而Docker作为容器化领域的佼佼者,在微服务部署与管理方面扮演着不可或缺的角色。本文将带你深入了解…...
python 如何实现执行selenium自动化测试用例自动录屏?
做自动化测试已经好多年了,随着项目技术的正增长提升,我们也不断完善并提高自己的技术能力, 下面给大家分享一个 selenium 自动化执行测试用例的录屏功能。希望对大家有帮助! 首先,我们为什么要执行自动化录屏功能呢…...
03 网络编程 TCP传输控制协议
目录 1、TCP基本特征 2、TCP通信流程基本原理 (1)基本原理 (2)TCP通信代码实现 (3)核心API解析 1)地址绑定--bind 2)设置监听-listen 3)等待连接请求-accept-产生一个已连接套接字 4&a…...
1. 数据结构——顺序表的主要操作
1. 内容 顺序表的初始化、插入、删除、按值查找、输出以及其时间复杂度的计算。 2.代码 #include<stdio.h> #include<stdlib.h> //函数结果状态代码 #define OK 1 #define OVERFLOW -2 #define ERROR 0 #define MAXSIZE 100typedef int ElemType; //顺序表每个…...
[openSSL]TLS 1.3握手分析
文章目录 前言一、ECDHE密钥交换二、TLS单向身份认证三、TLS双向身份认证 前言 关于TLS握手网上资料很多,但是有一些写的很不清楚,导致学习时对概念和流程出现混淆,以下是我觉得写得比较清晰和准确的供学习参考。 浅析 TLS(ECDHE…...
无人机之螺旋桨的安装与维护
一、安装:正确安装桨叶至关重要。请确保顺时针旋转的桨叶安装在对应的电机上,并使逆时针旋转的桨叶安装在相应的电机上。否则,无人机可能无法正常飞行或失去控制。 二、维护:为了确保无人机的安全及长久使用,请定期检…...
手机设备IP地址切换:方法、应用与注意事项
在当今数字化时代,手机已成为我们日常生活中不可或缺的一部分。无论是工作、学习还是娱乐,手机都扮演着重要角色。然而,随着网络环境的日益复杂,有时我们需要切换手机设备的IP地址以满足特定的需求,如保护隐私、绕过地…...
华为HCIP证书好考吗?详解HCIP证书考试难易程度及备考策略!
华为认证体系主要分为三个层次:HCIA(Huawei Certified ICT Associate),HCIP(Huawei Certified ICT Professional)和HCIE(Huawei Certified Internetwork Expert)。作为中级认证,HCIP证书主要面向具备一定技术基础和项目实践能力的专业人士。在…...
《SPSS零基础入门教程》学习笔记——05.模型入门
文章目录 5.1 回归模型5.2 分类模型5.3 降维和刻度模型5.4 生存分析和时间序列模型 5.1 回归模型 线性回归(分析 -> 回归 -> 线性)曲线估计(分析 -> 回归 -> 曲线估计) 二元Logistic回归(分析 -> 回归…...
如何用不到一分钟的时间将Excel电子表格转换为应用程序
我们大多数人对电子表格又爱又恨。当企业需要分析数据、为决策过程提供信息并可视化信息时,Excel和Google Sheets是首选。这些文档非常容易创建,它们帮助我们以直接的方式构建相关的想法和适用的数据。除此之外,事情可能会变得一团糟。 对于…...
WordPress 中 cURL 请求出现 504 网关超时错误的解决方法
错误原因 504网关超时错误通常发生在服务器作为网关或代理,不能在规定的时间内得到响应时。在WordPress中,这可能是因为目标服务器响应过慢,或请求的队列过长导致的。 解决方案 首先,您应该检查您的cURL请求是否设置了一个合理的…...
Proteus仿真实战:基于STM32的波形发生器设计与实现(附源码与仿真文件)
1. 从零开始:STM32波形发生器的设计思路 第一次接触波形发生器项目时,我也被各种专业术语搞得一头雾水。后来发现,其实可以把STM32想象成一个音乐盒,DAC模块就是它的发声装置,而我们要做的就是教会这个音乐盒演奏不同风…...
电子工程师职业发展路径与技术能力提升指南
电子工程师职业发展全景指南1. 职业发展路径解析1.1 新手工程师常见困境与突破电子行业新入行者普遍面临"三无"困境:无事可做、无人指导、工作缺乏技术含量。这种矛盾心态源于三个关键因素:行业认知不足:缺乏对电子产业链的全局认识…...
混沌加密算法实战指南(一)——从理论到实现的性能评估体系
1. 混沌加密算法性能评估体系概述 第一次接触混沌加密算法时,我被它独特的随机性和确定性并存的特性深深吸引。但真正让我头疼的是,当我按照论文实现了一个加密算法后,却不知道该如何评估它的实际性能。这就像做了一道新菜却不知道该怎么判断…...
微信聊天记录终极保存方案:3步永久备份你的珍贵回忆
微信聊天记录终极保存方案:3步永久备份你的珍贵回忆 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we/WeChatM…...
Linux用户管理全攻略:从创建到权限配置
1. Linux用户管理基础入门 刚接触Linux系统的朋友,经常会遇到这样的困惑:为什么有些命令普通用户不能执行?为什么新建的用户连基本的命令补全都没有?其实这些都是用户管理的问题。作为一个用了10年Linux的老鸟,今天我就…...
Qt加载OBJ或STL模型文件,支持鼠标移动、缩放、旋转Demo
Qt加载模型文件obj或者stl实例,支持鼠标移动缩放旋转demo最近在捣鼓Qt的3D可视化功能,发现用Qt搞个模型查看器比想象中简单。咱们先整点实际的——做个能加载obj/stl模型,支持鼠标拖拽旋转、平移、缩放的demo。废话不多说,直接撸代…...
Async1Wire异步1-Wire驱动库:DS18B20非阻塞温度采集方案
1. Async1Wire 库概述Async1Wire 是一个专为嵌入式系统设计的异步 1-Wire 总线驱动库,其核心目标是解耦 1-Wire 通信时序与主程序执行流,避免传统阻塞式实现中长达数百毫秒的delay()等待(如 DS18B20 温度转换期间的 750ms 全局阻塞࿰…...
5个HTTP请求配置技巧:让你的Dify工作流开发效率提升300%
5个HTTP请求配置技巧:让你的Dify工作流开发效率提升300% 【免费下载链接】Awesome-Dify-Workflow 分享一些好用的 Dify DSL 工作流程,自用、学习两相宜。 Sharing some Dify workflows. 项目地址: https://gitcode.com/GitHub_Trending/aw/Awesome-Dif…...
从OBS源码看WASAPI实战:Windows音频采集的‘静音循环’修复与高精度时间戳处理
从OBS源码剖析WASAPI音频采集:静音循环修复与高精度时间戳的工程实践 在直播软件OBS的音频处理模块中,WASAPI接口的高效运用直接决定了音画同步质量与系统资源占用率。本文将深入OBS源码,揭示其解决Windows音频采集两大核心难题的技术方案&am…...
从零搭建RAG知识库系统:手把手带你玩转检索增强生成,解决大模型三大痛点!
在探索AI落地应用的过程中,RAG知识库系统是一项无法回避的关键技术。近期我开始系统学习这一领域,并决定以笔记形式持续记录和分享学习心得,一方面督促自己深入理解,另一方面也希望能与大家共同探讨、相互启发。 本文整理自我对RA…...
