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

2024年8月16日(运维自动化 ansible)

一、回顾

1、mysql和python
        (1)mysql5.7

        1.1不需要执行mysql_ssl_rsa_setup

        1.2change_master_to 不需要get public key

(2)可以使用pymysql非交互的管理mysql

        2.1pymysql.connect(host,user,password,database,port)

        2.2 cursor=conn.cursor()

        2.3 cursor.execute("create user....")

        2.4 cursor.execute("grant 权限 on 库名.表名 to 用户")

        2.5 conn.commit()

        2.6 cursor.fetchall()

2、mycat中间件
        (1)独属于mysql主从负载均衡策略
        (2)配置写主读从
        (3)步骤
        3.1 安装jdk mycat
tar -xf jdk_8u192.tar.gz
cp jdk/ /usr/local/jdksed -i '$aexport $JAVA_HOME=/usr/local/jdk' /etc/profile
sed -i '$aexport $PATH=$PATH:$JAVA_HOME/bin'  /etc/profilejava -version
javac -versiontar -xf Mycat.tar.gz
cp mycat/ /usr/local/#测试启动
/usr/local/mycat/bin/mycat console
        3.2 配置
        1. server.xml
[root@localhost ~]# vim /usr/local/mycat/conf/server.xml93         <user name="lxe" defaultAccount="true">94                 <property name="password">lxe</property>95                 <property name="schemas">test</property>
        2. schema.xml
[root@localhost ~]# vim /usr/local/mycat/conf/schema.xml 5         <schema name="test" dataNode="dn1" checkSQLschema="false" sqlMaxLimit="100">6         </schema>7         <dataNode name="dn1" dataHost="localhost1" database="test" />18                 <writeHost host="hostM1" url="192.168.8.176:3306" user="lxe"19                                    password="lxe">20                         <!-- can have multi read hosts -->21                         <readHost host="hostS2" url="192.168.8.177:3306" user="lxe" password="lxe" /> 22                 </writeHost>
        (4)启动和调试

        4.1. /usr/local/mycat/bin/mycat start

        4.2. Netstat -Input|grep 8066

        4.3. mysql-hmycat的ip或者域名-P8066-userver.xml中填入账号-p在service.xml中填入的密码

        4.4. cat /usr/local/mysql/logs/wrapper.log

                1. cause by.....

二、运维自动化(ansible)

1、任务背景

公司的服务器越来越多,维护一些简单的事情都会变得很繁琐。用shell
脚本来管理少量服务器效率还行,服务器多了之后,shell脚本无法实现
高效率运维。这种情况下,我们需要引入自动化运维工具,对多台服务
器实现高效运维。

2、任务要求

通过管理服务器能够按照需求灵活高效地管理所有应用服务器的运维操作

3、任务拆解

1. 需要r-台服务器做管理端,来连接管理所有的应用服务器

2. 考虑如果只针对一部分应用服务器进行运维操作如何实现(服务器分组)

3. 学会将平台烂熟于心的linux操作命令转化为自动化运维的方式(常见模块的学习)

4. 如果操作非常的冗长,学会使用playbook和role的方式来管理

4、学习目标

能够安装ansible服务器和客户端

能够定义ansible主机清单进行服务器分组

能够使用hostname模块修改主机名

能够使用file模块做基本的文件操作

能够使用copy模块把文件拷贝到远程机器

能够使用fetch模块把文件从远程拷贝到本地

能够使用user模块管理用户

能够使用group模块管理用户组

能够使用cron模块管理时间任务

能够使用yum_repository模块配置yum

能够使用yum模块安装软件包

能够使用service模块控制服务的启动,关闭,开机自启动

能够使用script模块在远程机器上执行本地脚本

能够使用command与shell模块远程执行命令

能够编写playbook实现httpd

能够使用roles实现lamp

三、认识自动化运维

假设我要去1000台服务上做一个操作(如nginx服务器修改配置文件里的某一个参数),下面两种方法缺点明显:

1. 按传统的方法,一台连着一台服务器的ssh上去手动操作

缺点:效率太低。

2. 写个shell脚本来做

缺点:

管理的机器平台不一致,脚本可能不具备通用性。

传密码麻烦(在非免密登录的环境下,需要expect来传密码)

效率较低,循环1000次也需要一个一个的完成,如果用&符放到后台执行,则会产生1000个进程。

自动化运维:将日常IT运维中大量的重复性工作,小到简单的日常检查、配置变更和软件安装,大到整个变更流程的组织调度,由过去的手工执行转为自动化操作,从而减少乃至消除运维中的延迟,实“零延时”的IT运维。

3、自动化运维主要关注的方面

假如管理很多台服务器,主要关注以下几个方面:

1. 管理机与被管理机的连接(管理机如何将管理指令发送给被管理机)

2. 服务器信息收集(如果被管理的服务器有centos7.5外还有其它linux发行版,如suse,ubuntu等。当你要做的事情在不同OS上有所不同,你需要收集信息,并将其分开处理)

3. 服务器分组(因为有些时候我要做的事情不是针对所有服务器,可能只针对某一个分组)|I

4. 管理内容的主要分类

■ 文件目录管理(包括文件的创建,删除,修改,查看状态,远程拷贝等)

■ 用户和组管理

■ cron时间任务管理

■ yum源配置与通过yum管理软件包

■ 服务管理

■ 远程执行脚本

■ 远程执行命令

4、常见的开源自动化运维工具比较
1. puppet(拓展)

基于ruby语言,成熟稳定。适合于大型架构,相对于ansible和saltstack会复杂些。

2. saltstack(拓展)

基于python语言。相对简单,大并发能力比ansible要好,需要维护被管理端的服务。如果服务断开,连接就会出问题。

3. ansible

基于python语言。简单快捷,被管理端不需要启服务。直接走ssh协议,需要验证所以机器多的话速度会较慢。

四、ansible

ansible是一种由Python开发的自动化运维工具,集合了众多运维工具(puppet、cfengine、chef、func、fabric)的优点,实现了批量系统配置、批量程序部署、批量运行命令等功能。

1、特点:

■ 部署简单

■ 默认使用ssh进行管理,基于python里的paramiko模块开发

■ 管理端和被管理端不需要启动服务

■ 配置简单,功能强大,扩展性强

■能过playbook(剧本)进行多个任务的编排

2、安装ansible(配置四台主机 m0 s0 s1 s2)
(1)在m0主机安装ansible

[root@m0 ~]# yum -y install epel-release

[root@m0 ~]# yum -y install ansible

[root@m0 ~]# ansible --version

[root@m0 ~]# rpm -ql ansible
[root@m0 ~]# find /etc/ -name "*ansible*"
/etc/ansible
/etc/ansible/ansible.cfg

(2)实现master对agent的免密登录,只在master上做。(如果这一步不做,则在后面操作agent时都要加-k参数传密码;或者在主机清单里传密码)

[root@m0 ~]# ssh-keygen

[root@m0 ~]# ls ./.ssh/
id_rsa  id_rsa.pub
[root@m0 ~]# cat ./.ssh/id_rsa.pub 

[root@m0 ~]# ssh-copy-id -i 192.168.8.181
[root@m0 ~]# ssh-copy-id -i 192.168.8.182

(3)在master上定义主机组,并测试连接

[root@m0 ~]# vim /etc/ansible/hosts 

[group01]
192.168.8.181
192.168.8.182[group02]
192.168.8.181
192.168.8.182
192.168.8.183

[root@m0 ~]# ansible 192.168.8.181 -m ping 

192.168.8.181 | SUCCESS => {"ansible_facts": {"discovered_interpreter_python": "/usr/bin/python"}, "changed": false, "ping": "pong"
}

[root@m0 ~]# ansible group01 -m ping 

192.168.8.181 | SUCCESS => {"ansible_facts": {"discovered_interpreter_python": "/usr/bin/python"}, "changed": false, "ping": "pong"
}
192.168.8.182 | SUCCESS => {"ansible_facts": {"discovered_interpreter_python": "/usr/bin/python"}, "changed": false, "ping": "pong"
}

[root@m0 ~]# ansible group02 -m ping   #192.168.8.183没有免密,报错

[root@m0 ~]# vim /etc/ansible/hosts   #重新修改文件

[group01]
192.168.8.181
192.168.8.182other ansible_ssh_host=192.168.8.183 ansible_ssh_port=22 ans
ible_ssh_user=root ansible_ssh_pass=1[group02]
192.168.8.181
192.168.8.182
other

[root@m0 ~]# ansible group02 -m ping   #不报错了

[root@m0 ~]# ansible other -m ping  #单独也是成功的

other | SUCCESS => {"ansible_facts": {"discovered_interpreter_python": "/usr/bin/python"}, "changed": false, "ping": "pong"
}

主机清单的作用:服务器分组。

主机清单的常见功能:

1. 可以通过IP范围来分,主机名名字的范围来分

2. 如果ssh端口不是22的,可以传入新的端口。

3. 没有做免密登录,可以传密码。

练习:不论你用哪种环境(免密或不免密,端口是否22),请最终将两台被管理机器加入到group1组即可

vim /etc/ansible/hostsweb01 ansible_ssh_host=192.168.8.X
ansible_ssh_user=root ansible_ssh_pass=1 ansible_ssh_port=22web01 ansible_ssh_host=192.168.8.X
ansible_ssh_user=root ansible_ssh_pass=1 ansible_ssh_port=22[group01]
web01
web02
ansible 主机IP|域名|组名|别名 -m ping|copy|... '参数'
3、ansible模块

ansible是基于模块工作的,本身没有批量部署的能力。真正具有批量部署的是ansible所运行的模块,ansible只是提供一种框架。

ansible支持的模块非常的多,我们并不需要把每个模块都记住,而只需要熟悉一些常见的模块,其它的模块在需要用到时再查询即可。

(1)查看所有支持的模块

[root@m0 ~]# ansible-doc -l

(2)hostname 模块

用于修改主机名称

[root@m0 ~]# ansible group02 -m hostname -a 'name=ab.lxe.er'  #将group02组中的主机名称分别改为ab lxe er

 (3)file模块(重点)

file模块用于对文件相关的操作(创建,删除,软硬钟接等)

3.1 创建文件

[root@m0 ~]# ansible group01 -m file -a 'path=/tmp/abc state=directory'   #在group01组中的主机中创建目录abc 

[root@s0 ~]# ls /tmp/
abc
[root@s1 ~]# ls /tmp/
abc
[root@s2 ~]# ls /tmp
abc

[root@m0 ~]# ansible group02 -m file -a 'path=/tmp/abc/def state=touch'
[root@s0 ~]# ls /tmp/abc/
def

3.2 递归修改

[root@m0 ~]# ansible group02 -m file -a'path=/tmp/abc recurse=yes owner=bin group=daemon mode=1777'  #777是权限

[root@s0 ~]# ll /tmp/abc/def 
-rwxrwxrwt 1 bin daemon 0 8月  16 14:08 /tmp/abc/def 

3.3 删除目录(连同目录里的所有文件)

[root@m0 ~]# ansible group02 -m file -a 'path=/tmp/abc state=absent'    #ansent 删除

3.4 创建文件 (指定group mode owner...)

[root@m0 ~]# ansible group02 -m file -a 'path=/tmp/aaaa state=touch owner=bin group=daemon mode=1777'
[root@s0 ~]# ll /tmp/
-rwxrwxrwt 1 bin  daemon  0 8月  16 14:21 aaaa

3.5 删除

[root@m0 ~]# ansible group02 -m file -a 'path=/tmp/aaaa state=absent'

3.6 创建软链接文件

[root@m0 ~]# ansible group02 -m file -a 'src=/etc/fstab path=/tmp/xxx state=link'

[root@s0 ~]# ll /tmp/
lrwxrwxrwx 1 root root 10 8月  16 14:28 xxx -> /etc/fstab

3.7 创建硬链接文件     #硬链接指向文件,软链接指向硬链接

[root@m0 ~]# ansible group02 -m file -a 'src=/etc/fstab path=/tmp/xxx2 state=hard'
[root@s0 ~]# ll /tmp/

-rw-r--r--. 2 root root 502 7月  23 09:12 xxx2

#path 文件的地址

#state 方法

        #directory 创建目录

        #touch 创建文件

        #absent 删除文件

        #link 创建软链接

        #hard 创建硬链接

#recurse 是否允许递归操作

#src 文件源

 (4)stat模块

[root@m0 ~]# ansible group02 -m stat -a 'path=/etc/fstab'

(5)copy模块(重点)

copy模块用于对文件的远程拷贝操作(如把本地的文件拷贝到远程的机器上)

[root@m0 ~]# mv mysql-5.7.44-linux-glibc2.12-x86_64.tar.gz my57.tar.gz

[root@m0 ~]# ansible group02 -m copy -a 'src=./my57.tar.gz dest=~'
[root@s0 ~]# ls
my57.tar.gz

 [root@m0 ~]# dd if=/dev/zero of=./test bs=100M count=1 

5.1 使用content直接向远程主机文件写入内容(会覆盖原内容)

[root@m0 ~]# ansible group02 -m copy -a 'content="wo ha ha" dest=~/test'
[root@s0 ~]# cat test 
wo ha ha

5.2 使用backup 备份 copy 拷贝加/是整个目录,不加只同步目录中内容

[root@m0 ~]# ansible group02 -m copy -a 'src=./test dest=~ backup=yes owner=bin group=daemon mode=1777'

[root@s0 ~]# ls -lh

-rwxrwxrwt  1 bin  daemon 100M 8月  16 15:26 test
-rw-r--r--  1 root root      8 8月  16 15:20 test.12559.2024-08-16@15:26:07~

[root@m0 ~]# ansible group02 -m file -a 'path=/tmp/a.txt state=touch'

[root@m0 ~]# ansible group02 -m copy -a 'src=/etc/fstab desc=/tmp/a.txt backup=yes owner=bin group=daemon mode=1777'
[root@s0 ~]# ls /tmp/
a.txt
a.txt.12737.2024-08-16@15:30:53~

5.3 连同目录一起复制

[root@m0 ~]# ansible group02 -m copy -a 'src=/etc/yum.repos.d dest=/etc/yum.repos.d/ backup=yes'

[root@s0 ~]# ls /etc/yum.repos.d
CentOS-Base.repo  dd.repo  yum.repos.d

5.4 复制目录下文件

[root@m0 ~]# ansible group02 -m copy -a 'src=/etc/yum.repos.d/ dest=/etc/yum.repos.d/ backup=yes'

[root@s0 ~]# ls /etc/yum.repos.d/
CentOS-Base.repo  epel.repo          
yum.repos.d
dd.repo           epel-testing.repo

(6)fetch模块

fetch模块与copy模块类似,但作⽤相反。⽤于把远程机器的⽂件拷 ⻉到本地

[root@m0 ~]# ansible group02 -m fetch -a 'src=/etc/sysconfig/network-scripts/ifcfg-ens33 dest=/tmp'

[root@m0 ~]# ls /tmp/
192.168.8.181
192.168.8.182
other

(7)user模块

user模块⽤于管理⽤户账号和⽤户属性。

7.1 创建aaa⽤户,默认为普通⽤户,创建家⽬录

[root@m0 ~]# ansible group02 -m user -a 'name=aaa state=present'
[root@s0 ~]# grep aaa /etc/passwd
aaa:x:1000:1000::/home/aaa:/bin/bash

7.2 创建mysql系统⽤户,并且登录shell环境为/sbin/nologin

[root@m0 ~]# ansible group02 -m user -a 'name=mysql state=present system=yes shell="/sbin/nologin"'

[root@s0 ~]# grep mysql /etc/passwd
mysql:x:997:995::/home/mysql:/sbin/nologin

7.3 创建文件 指定属主 组 权限

[root@m0 ~]# ansible group02 -m file -a 'path=/usr/local/mysql/mysql-files state=directory owner=mysql group=mysql mode=750'

[root@s0 ~]# ll /usr/local/mysql/
drwxr-x--- 2 mysql mysql 6 8月  16 16:10 mysql-files

7.4 创建abc⽤户, 使⽤uid参数指定uid, 使⽤password参数传密码

[root@m0 ~]# ansible group02 -m user -a 'name=abc state=present uid=1999 password=abc'
[root@s0 ~]# grep abc /etc/passwd
abc:x:1999:1999::/home/abc:/bin/bash

7.5 创建⼀个普通⽤户叫hadoop,并产⽣空密码密钥对

[root@m0 ~]# ansible group02 -m user -a 'name=hadoop generate_ssh_key=yes'

[root@s0 ~]# ls ./.ssh/
authorized_keys
[root@s0 ~]# cat ./.ssh/authorized_keys

7.6 删除⽤户,但家⽬录默认没有删除

[root@m0 ~]# ansible group02 -m user -a 'name=hadoop state=absent'

[root@m0 ~]# ansible group02 -m user -a 'name=abc state=absent'

[root@s0 ~]# ll /home/
drwx------ 2 aaa   aaa   62 8月  16 16:03 aaa
drwx------ 2  1999  1999 62 8月  16 16:16 abc
drwx------ 3  2000  2000 74 8月  16 16:20 hadoop
drwx------ 2 mysql mysql 62 8月  16 16:06 mysql

7.7 删除bbb⽤户,使⽤remove=yes参数让其删除⽤户的同时也删除家⽬ 录

[root@m0 ~]# ansible group02 -m user -a 'name=mysql state=absent remove=yes'

[root@s0 ~]# ll /home/
drwx------ 2 aaa   aaa   62 8月  16 16:03 aaa
drwx------ 2  1999  1999 62 8月  16 16:16 abc
drwx------ 3  2000  2000 74 8月  16 16:20 hadoop

(8)cron模块

cron模块⽤于管理周期性时间任务

[root@m0 ~]# crontab -e

*/1 * * * * echo $( date ) >>~/data.txt

[root@m0 ~]# ansible group02 -m cron -a 'name="abc" user=root job="/usr/sbin/ntpdate cn.ntp.org.cn" hour=2'
[root@s0 ~]# crontab -l
#Ansible: abc
* 2 * * * /usr/sbin/ntpdate cn.ntp.org.cn

(9)yum模块(重点)

yum模块⽤于使⽤yum命令来实现软件包的安装与卸载。

[root@m0 ~]# ansible group02 -m yum -a 'name=ntpdate state=present'

[root@m0 ~]# ansible group02 -m yum -a 'name=tree state=present'

[root@s0 ~]# ntpdate cn.ntp.org.cn
16 Aug 16:36:33 ntpdate[14239]: adjust time server 120.197.116.202 offset 0.019423 sec
 

(10)service模块(重点)

service模块⽤于控制服务的启动,关闭,开机⾃启动等。

[root@m0 ~]# ansible group02 -m service -a 'name=firewalld state=stopped enabled=false'

关机

[root@m0 ~]# ansible group02 -m command -a 'shutdown -h 0' 

相关文章:

2024年8月16日(运维自动化 ansible)

一、回顾 1、mysql和python (1)mysql5.7 1.1不需要执行mysql_ssl_rsa_setup 1.2change_master_to 不需要get public key (2)可以使用pymysql非交互的管理mysql 2.1pymysql.connect(host,user,password,database,port) 2.2 cursorconn.cursor() 2.3 cursor.execute("creat…...

荣耀Magicbook x14 扩容1TB固态

版权归作者所有&#xff0c;如有转发&#xff0c;请注明文章出处&#xff1a;https://cyrus-studio.github.io/blog/ 固态硬盘规格 在官网查看加装固态硬盘的接口规格 https://www.honor.com/cn/laptops/honor-magicbook-x14-2023/ https://club.honor.com/cn/thread-2847379…...

Springboot整合全文检索引擎Lucene

文章目录 前言Lucene的介绍springboot项目中如何整合Lucene简单用法1. 引入依赖2. 其它用到的类2. 创建索引3. 简单搜索4. 更新索引5. 删除索引6. 删除全部索引 Springboot整合Lucene复杂搜索1. 同时标题和内容中查找关键词2. 搜索结果高亮显示关键词3. 分页搜索4. 多关键词联合…...

【深度学习】【语音】TTS, 如何使用Python分析WAV的采样率、比特深度、通道数

文章目录 使用Python分析WAV文件的属性与可视化简介所需环境代码解析可视化音频数据结论使用Python分析WAV文件的属性与可视化 WAV文件录音要求 为了确保录制的音频文件符合TTS模型训练的质量标准,请遵循以下录音要求: 采样率要求:44.1 kHz说明:采样率44.1 kHz(即每秒采样…...

Linux的安装和使用

Linux 第一节 Linux 优势 1. 开源 为什么这么多的的设备都选择使用 Linux&#xff1f;因为它是开源软件&#xff08;open source software&#xff09;&#xff0c;具有不同的含义。使用一个安全的操作系统工作变得必不可少的事&#xff0c;而 Linux 恰好满足了这个需求。因…...

查看一个exe\dll文件的依赖项

方法 使用一个Dependencies工具&#xff0c;检测exe文件的所有依赖项 工具使用 下载压缩包之后解压&#xff0c;解压后如下图所示 在命令行中运行Dependencies.exe程序会得到帮助菜单 查询某exe的所有依赖项&#xff0c;使用命令 Dependencies.exe -chain <查询文件> …...

高校科研信息管理系统pf

TOC springboot364高校科研信息管理系统pf 第1章 绪论 1.1 研究背景 互联网概念的产生到如今的蓬勃发展&#xff0c;用了短短的几十年时间就风靡全球&#xff0c;使得全球各个行业都进行了互联网的改造升级&#xff0c;标志着互联网浪潮的来临。在这个新的时代&#xff0c;…...

Linux 开机自动挂载共享文件设置

选择一个要共享的文件 点击确定 -> 确定 启动虚拟机 执行下面的命令 /YumSource 是我选择的共享文件夹&#xff0c;自行替换自已选择的文件夹 mkdir -p /mnt/hgfs cat >> /etc/fstab << EOF .host:/YumSource /mnt/hgfs fuse.vmhgfs-fuse allow_other defaul…...

c_cpp_properties.json、launch.json、 tasks.json

在 Visual Studio Code 中&#xff0c;c_cpp_properties.json、launch.json 和 tasks.json 是三个重要的配置文件&#xff0c;它们的作用如下&#xff1a; c_cpp_properties.json&#xff1a; 这个文件用于配置 C/C 扩展的 IntelliSense、编译器路径和包括路径等。它帮助 VS Co…...

mysql 一些知识点 面试用

mysql 1、4个隔离级别与3个现象2、快照读与当前读2.1 可重复读的情况下出现幻读问题的两种情况 3 数据库 常用引擎4、InnoDB存储引擎对MVCC的实现5、索引(重点)5.1 什么是索引5.2 索引的创建与删除5.2.1 查看表中有哪些索引5.2.2 添加索引5.2.3 删除索引 5.3 索引的分类5.4 树数…...

STM32之点亮LED灯

使用固件库实现LED点灯 LED灯&#xff1a; LED灯&#xff0c;是一种能够将电能转化为可见光的半导体器件 控制LED灯&#xff1a; LED灯的正极接到了3.3V&#xff0c;LED灯的负极接到了PA1&#xff0c;也就是GPIOA1引脚 只需要控制PA1为相对应的低电平&#xff0c;即可点亮对…...

Java 多线程练习2 (抽奖比较Runnable写法)

MultiProcessingExercise2 package MultiProcessingExercise120240814;import java.util.ArrayList; import java.util.Collections;public class MultiProcessingExercise1 {public static void main(String[] args) {// 需求&#xff1a;// 在此次抽奖过程中&#xff0c;抽奖…...

使用fastboot更新部分系统

使用fastboot更新部分系统 获取分区信息 > part list sunxi_flash 0Partition Map for UNKNOWN device 0 -- Partition Type: EFIPart Start LBA End LBA NameAttributesType GUIDPartition GUID1 0x00008000 0x000097c5 "boot-r…...

windows 加载portch遇到的错误

import torch 遇到如下错误 File "<stdin>", line 1, in <module> File "C:\Users\Administrator\AppData\Local\Programs\Python\Python311\Lib\site-packages\torch\__init__.py", line 148, in <module> raise err OSError: [W…...

如何将 CICD 模版重构为 CICD component?

极狐GitLab 是 GitLab 在中国的发行版&#xff0c;专门面向中国程序员和企业提供企业级一体化 DevOps 平台&#xff0c;用来帮助用户实现需求管理、源代码托管、CI/CD、安全合规&#xff0c;而且所有的操作都是在一个平台上进行&#xff0c;省事省心省钱。可以一键安装极狐GitL…...

数学建模——评价决策类算法(层次分析法、Topsis)

一、层次分析法 概念原理 通过相互比较确定各准则对于目标的权重, 及各方案对于每一准则的权重&#xff0c;这些权重在人的思维过程中通常是定性的, 而在层次分析法中则要给出得到权重的定量方法. 将方案层对准则层的权重及准则层对目标层的权重进行综合, 最终确定方案层对目标…...

KEEPALIVED 全csdn最详细----理论+实验(干货扎实,包教会的)

环境准备 主机名IP虚拟IP&#xff08;VIP&#xff09;功能ka1172.25.254.10172.25.254.100keepalived服务ka2172.25.254.20172.25.254.100keepalived服务realserver1172.25.254.110web服务realserver2172.25.254.120web服务 注意一定要关闭selinux,和防火墙&#xff0c;不然在…...

微信云开发云存储全部下载

一、安装 首先按照这个按照好依赖 安装 | 云开发 CloudBase - 一站式后端云服务 npm i -g cloudbase/cli 二、登录 tcb login 下载 首先在你要下载到的本地文件内创建一个名为&#xff1a;cloudbaserc.json 的json文件。 填入你的id {"envId":"你的云开发环…...

vos3000怎样对接voip落地语音网关呢?卡机和O口网关的配置技巧有哪些?

很多朋友没有接触过vos系统的使用&#xff0c;那么vos3000如何对接voip落地网关呢&#xff1f;卡机的配置技巧有哪些&#xff1f; VOS3000系统是针对中小等规模VoIP运营业务提供的支撑系统。 语音网关 落地网关分O口网关&#xff0c;S口网关&#xff0c;和全网通GOIP语音网关。…...

MySQL数据库专栏(四)数据库操作

1、创建数据库 create database if not exists [数据库名称] character set [字符集] COLLATE [排序规则]; 例如&#xff1a;create database if not exists db_demo character set utf8mb4 COLLATE utf8mb4_general_ci; if not exists&#xff1a;判断数据库是否存在&#x…...

论文解读:交大港大上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架(二)

HoST框架核心实现方法详解 - 论文深度解读(第二部分) 《Learning Humanoid Standing-up Control across Diverse Postures》 系列文章: 论文深度解读 + 算法与代码分析(二) 作者机构: 上海AI Lab, 上海交通大学, 香港大学, 浙江大学, 香港中文大学 论文主题: 人形机器人…...

RocketMQ延迟消息机制

两种延迟消息 RocketMQ中提供了两种延迟消息机制 指定固定的延迟级别 通过在Message中设定一个MessageDelayLevel参数&#xff0c;对应18个预设的延迟级别指定时间点的延迟级别 通过在Message中设定一个DeliverTimeMS指定一个Long类型表示的具体时间点。到了时间点后&#xf…...

51c自动驾驶~合集58

我自己的原文哦~ https://blog.51cto.com/whaosoft/13967107 #CCA-Attention 全局池化局部保留&#xff0c;CCA-Attention为LLM长文本建模带来突破性进展 琶洲实验室、华南理工大学联合推出关键上下文感知注意力机制&#xff08;CCA-Attention&#xff09;&#xff0c;…...

java 实现excel文件转pdf | 无水印 | 无限制

文章目录 目录 文章目录 前言 1.项目远程仓库配置 2.pom文件引入相关依赖 3.代码破解 二、Excel转PDF 1.代码实现 2.Aspose.License.xml 授权文件 总结 前言 java处理excel转pdf一直没找到什么好用的免费jar包工具,自己手写的难度,恐怕高级程序员花费一年的事件,也…...

《从零掌握MIPI CSI-2: 协议精解与FPGA摄像头开发实战》-- CSI-2 协议详细解析 (一)

CSI-2 协议详细解析 (一&#xff09; 1. CSI-2层定义&#xff08;CSI-2 Layer Definitions&#xff09; 分层结构 &#xff1a;CSI-2协议分为6层&#xff1a; 物理层&#xff08;PHY Layer&#xff09; &#xff1a; 定义电气特性、时钟机制和传输介质&#xff08;导线&#…...

多模态商品数据接口:融合图像、语音与文字的下一代商品详情体验

一、多模态商品数据接口的技术架构 &#xff08;一&#xff09;多模态数据融合引擎 跨模态语义对齐 通过Transformer架构实现图像、语音、文字的语义关联。例如&#xff0c;当用户上传一张“蓝色连衣裙”的图片时&#xff0c;接口可自动提取图像中的颜色&#xff08;RGB值&…...

Java数值运算常见陷阱与规避方法

整数除法中的舍入问题 问题现象 当开发者预期进行浮点除法却误用整数除法时,会出现小数部分被截断的情况。典型错误模式如下: void process(int value) {double half = value / 2; // 整数除法导致截断// 使用half变量 }此时...

Linux系统部署KES

1、安装准备 1.版本说明V008R006C009B0014 V008&#xff1a;是version产品的大版本。 R006&#xff1a;是release产品特性版本。 C009&#xff1a;是通用版 B0014&#xff1a;是build开发过程中的构建版本2.硬件要求 #安全版和企业版 内存&#xff1a;1GB 以上 硬盘&#xf…...

Kafka主题运维全指南:从基础配置到故障处理

#作者&#xff1a;张桐瑞 文章目录 主题日常管理1. 修改主题分区。2. 修改主题级别参数。3. 变更副本数。4. 修改主题限速。5.主题分区迁移。6. 常见主题错误处理常见错误1&#xff1a;主题删除失败。常见错误2&#xff1a;__consumer_offsets占用太多的磁盘。 主题日常管理 …...

Modbus RTU与Modbus TCP详解指南

目录 1. Modbus协议基础 1.1 什么是Modbus? 1.2 Modbus协议历史 1.3 Modbus协议族 1.4 Modbus通信模型 🎭 主从架构 🔄 请求响应模式 2. Modbus RTU详解 2.1 RTU是什么? 2.2 RTU物理层 🔌 连接方式 ⚡ 通信参数 2.3 RTU数据帧格式 📦 帧结构详解 🔍…...