Kingbase数据库体系结构和日常运维监控

news2025/1/24 17:13:14

1. 数据库架构

1.1. 内存

1.1.1. Share Memory

共享内存是服务器服务器为数据库缓存和事务日志缓存预留的内存缓存空间,其中最重要的组成部分是Shared Buffer和WAL Buffer:

1. Shared Buffer:

减少磁盘IO

2. WAL Buffer:

用来临时存储数据库变化的缓存区域。存储在WAL Buffer中的内容会根据提前定义好的时间点参数要求写入到磁盘的WAL文件中。

全局信息比如进程、锁、全局统计等信息也保存在共享内存中。

参数名称

描述

shared_buffers

(1)从磁盘读入的数据(主要包括表和索引)都缓存在这里。

(2)主要目的是最大限度的减少磁盘I0。

(3)推荐内存的1/4大小,不超过内存的1/2,如果不使用huge page建议不要超过32GB。

wal_buffers

(1)Write--Ahead Logging buffer是一个临时存储数据更改的缓冲区。存储在WAL buffer中的内容将在预定的时间点写入WAL文件。

(2)默认为-1,即shared_buffer的1/32。最小不少于64k,最大不大于一个wal_segment_size(默认16M大小)。

(3)保持默认即可,因为过了wal_writer_.delay(默认200ms)会刷新清空此缓存。

1.1.2. 本地内存

非全局存储的数据都存在本地内存中,主要包括:

1. 临时缓冲区:

用于访问临时表的缓冲区

2. work_mem:

内部排序操作和Hash表在使用临时操作文件之前使用的存储缓冲区。

3. manintance_work_mem:

在维护操作比如:VACUUM、CREATE INDEX、ALTER TABLE ADD FOREIGN

参数名称

描述

work_mem

(1)旧名sort_mem,声明每个后端进程内部排序和哈希操作可用的工作内存大小。

(2)典型的涉及排序的操作有group by/order by/distinct。

(3)KESV8支持并行查询,每个正在运行的进程都可能使用多个数量的work_mem。

(4)默认值为4M,不能太大,否则连接数较多时会产生内存资源紧张。

(5)若太小、sort/hash计算慢,内存不够时可降级用磁盘(temp_file_limit)。

maintenance work mem

(1)指定在维护性操作(例如VACUUM、CREATE INDEX和ALTER TABLE ADD FOREIGN KEY)中使用的最大的内存量。

(2)默认值为64M,可以比work_mem大一点。

temp_Buffers

(1)临时表缓冲区存放在每个进程专用的私有内存中(非共享内存中)。它决定存放临时表的数据缓冲区中的数据块的个数,每个数据块的大小是8kB。

(2)默认值为8M,最小值800kB。

1.2. 数据库进程

1、kingbase Process(主后台驻留进程)--主进程

主后台驻留进程是kingbase启动时第一个启动的进程。启动时,他会执行恢复、初始化共享内存和运行后台进程操作。正常运行期间,当有客户端发起链接请求时,它还负责创建后端进程。

2、Background Process(后台进程) --辅助进程

进程名称

功能描述

主进程(KingbaseDaemon)

(1)Kingbase主进程是KES启动的第一个进程。

(2)它负责启动和关闭数据库实例,初始化共享内存,并启动后台子进程。

(3)当客户端进程有连接请求时,负责创建后端进程。 --主进程的第一个作用就是监听,第二大作用就会恢复数据库,前滚和回滚。第三大作用派生出辅助进程

后台进程(BackgroundProcess)或称为辅助子进程

启动数据库服务后自动启动多个后台进程:

(1)logger(系统日志进程,将错误信息写入到日志文件中)。

(2)checkpointer(检查点进程,发送检查点操作)。

(3)BgWriter(后台写进程,将share buffer中的脏数据写入到数据文件中)。

(4)wal writer(预写日志进程,将wal buffer中的脏块写入到WAL文件中)。

(5)Autovacuum launcher(自动清理进程,dead rows垃圾回收)。--清理死亡元组信息,当update超过(row*0.2+50)行数是,就会触发清理。分析统计信息。

(6)archiver(归档进程,拷贝WAL文件到指定的目录)。

(7)stats collector(统计信息收集进程,收集会话执行信息

/sys_stat_activity和表的使用信息/sys_stat_all_tables信息)。

(8)kwr collector(性能分析数据采集进程,定期采集实例运行过程中产生的I0、内存命中等统计数据,存储到kwr快照里面,用于性能问题分析和诊断)。--oracle中的awr报告很相似

3、Backend Process(后端进程)

最大后台链接数通过max_connections参数设定,默认值为100。后端进程用于处理前端用户请求并返回结果

4、Client Process(客户端进程)

客户端进程需要和后端进程配合使用,处理每一个客户链接

客户端进程Process)

(Client在服务器上启动客户程序就产生对应的客户端进程,比如:

(1)ksql --执行sql的命令行工具。

(2)sys_isready --检查一个KES服务状态。

(3)sys_config --获取已安装的KES的信息。

后端进程(BackendProcess)或称为会话服务进程

(1)客户端进程连接到数据库,主进程fork出对应后端进程。

(2)后端进程的最大数量取决于max_connections参数的设置,默认值是100。

(3)后端进程执行用户的请求,然后传输结果。

5、 集群进程:

1、kbha:用于监控repmgrd进程是否存活

2、repmgrd:用于监控集群运行状态

3、node_exporter、postgres_exporter:与监控相关的进程,为deploy部署工具监控页面提供数据

1.3. 数据文件

表中数据实际落盘的位置,在data/base目录下

每个表有三个数据文件:

1、一个文件用于存储数据,文件名是表的OID。

2、一个文件用于管理表的空闲空间,文件名是OID_fsm。

3、一个文件用于管理表的块是否可见,文件名是OID_vm

2. 数据库配置

2.1. 数据库数据目录结构

  • kingbase.conf:数据库实例的主配置文件,基本上包含所有配置
  • sys_hba.conf:客户端认证配置文件
  • sys_ident.conf:“ident”认证方式的用户映射文件
  • base目录:默认表空间的目录
  • global目录:一些共享系统表的目录
  • sys_clog目录:commit log的目录
  • sys_log:数据库系统日志目录,在查询一些系统错误时,查看此目录下的日志文件
  • sys_stat_tmp:统计信息的存储目录
  • sys_tblspc:存储了指向各个用户自建表空间实际目录的链接文件
  • sys_twophase:使用两阶段提交功能时分布式事务的存储目录
  • sys_xlog:WAL日志的目录

目录

描述

/data/sys_xact

是事务提交日志(Commit Log)的存储位置。这个目录在系统初始化后从0000开始递增至FFFF,文件名形如XXXX,默认大小为256KB。此外,事务提交日志主要记录了数据库运行中的事件,例如用户执行的SQL操作等,这些信息可以帮助用户了解和分析数据库当前状态,并有助于分析可能产生的异常。如果某个事务已经被冻结,那么与它相关的文件可以被vacuum清理以回收空间。

/data/sys_notify

存储通知信息的目录。当数据库中的某个事件(如WAL归档、表空间扩展等)发生时,系统会向所有连接到该数据库的客户端发送通知消息。这些通知消息会被写入到sys_notify目录中,以供客户端读取和处理。

/data/global

SYS_GLOBAL表空间的目录。

/data/sys_csnlog

包含事务提交序列号和子事务状态数据的目录。

/data/sys_bulkload

包含LISTEN/NOTIFY状态数据的子目录。

/data/sys_commit_ts

事务提交时间戳数据目录。

/data/sys_dynshmem

动态共享内存子系统所使用的文件的子目录。

/data/sys_serial

已提交的可序列化事务信息的子目录。

/data/sys_snapshots

导出的快照的子目录。

/data/sys_tblspc

保存指向自建表空间实际目录的链接文件。

/data/sys_twophase

用于预备事务状态文件的子目录。

/data/sys_stat

用于统计子系统的永久文件的子目录。

/data/sys_stat_tmp

表、索引统计信息临时文件目录。

/data/sys_aud

存储kingbase审计相关信息。

/data/sys_wal

WAL日志的目录。

/data/sys_multixact

多事务multi-transaction状态数据的子目录(用于共享的行锁)。

/data/sys_logical

用于逻辑复制的状态数据的子目录。

/data/base

SYS_DEFAULT表空间的目录。

/data/sys_log

数据库系统日志目录,用于查询一些系统错误。

2.2. 参数配置

配置文件位置:数据库数据目录中kingbase.conf

查看方法:

  • 图形:通过数据库对象管理工具查看
  • SQL:通过show 参数名称或者查询sys_settings系统表

参数级别:

  • 固定级(cluster)

数据库初始化时设置,一旦固定,不能再修改;初始化数据库时设置。

  • 系统级(system)

通过直接编辑参数文件 kingbase.conf 或者通过 ALTER SYSTEM SET 语句来设置系统级参数的值。这些参数被设置后不会立即生效,必须重新启动服务器才可生效,而且是对所有数据库及连接均有效。

  • 全局级(global)

通过直接编辑参数文件 kingbase.conf 或者通过 ALTER SYSTEM SET 语句来设置全局级参数的值。这些参数被设置后,不用重启服务器,就会对所有数据库及连接立即生效。

  • 会话级(session)

使用SET 或者 ALTER DATABASE SET 语句进行设置。

通过 SET 语句设置只对当前连接有效,而通过ALTER DATABASE SET语句设置会对该数据库上启动的每个新会话生效,而不会对该数据库上的本次连接和其它数据库上的连接生效。

2.2.1. 连接配置

listen_addresses (string)

指定服务器在哪些 TCP/IP 地址上监听客户端连接。值的形式是一个逗号分隔的主机名和/或数字 IP 地址列表。特殊项*对应所有可用 IP 接口。

port (integer)

服务器监听的 TCP 端口;默认是 54321。

max_connections (integer)

决定数据库的最大并发连接数。默认值通常是 100 个连接。

Superuser_reserved_connections

决定为KingbaseES超级用户连接而保留的连接“槽”数。 同时活跃的并发连接最多max_connections个。任何时候,活跃的并发连接数最多为max_connections减去 superuser_reserved_connections,新连接就只能由超级用户发起。

Tcp_keepalives_idle

指定不活动多少秒之后通过 TCP 向客户端发送一个 keepalive 消息。 0 值表示使用默认值。

Tcp_keepalives_interval

指定在多少秒之后重发一个还没有被客户端告知已收到的 TCP keepalive 消息。0 值表示使用系统默认值。

Tcp_keepalives_count

指定与客户端的服务器连接被认为死掉之前允许丢失的 TCP keepalive 数量。0 值表示使用系统默认值。

2.2.2. 资源消耗

Shared_buffers

设置数据库服务器将使用的共享内存缓冲区量。默认通常是 128 兆字节(128MB)。

Work_mem

声明内部排序和哈希操作可使用的工作内存大小。

Maintenance_work_mem

指定在维护性操作(例如VACUUM、CREATE INDEX和ALTER TABLE ADD FOREIGN KEY)中使用的 最大的内存量。其默认值是 64 兆字节(64MB)。

effective_cache_size

是kingbase能够使用的最大缓存,这个数字对于独立的kingbase服务器而言应该足够大。

2.2.3. 错误报告及日志

logging_collector

日志收集器开关

Log_destination

KingbaseES支持多种方法来记录服务器消息,包括stderr、csvlog和syslog。默认值是只记录到stderr。

Log_directory

这个参数决定日志文件目录,它可以被指定为一个绝对路径,也可以被指定为一个相对于数据目录的相对路径,默认sys_log

Log_filename

日志文件的文件名,默认是kingbase-%Y-%m-%d_%H%M%S.log

Log_rotation_age

日志超过多长时间,就生成一个新的文件

Log_rotation_size

日志超过多大时,就生成一个新的文件

Log_truncate_on_rotation

是否覆盖已有的同名日志

Log_line_prefix

每个日志行的开头输出

log_duration = off

记录每条SQL语句执行完成消耗的时间,将此配置设置为on,用于统计哪些SQL语句耗时较长。

log_min_duration_statement

-1表示不记录,0将记录所有SQL语句和它们的耗时,>0只记录那些耗时超过(或等于)这个值(ms)的SQL语句。

log_statement = 'none'

none, ddl, mod, all ---- 控制记录哪些SQL语句。none不记录,ddl记录所有数据定义命令,mod记录所有ddl语句,all记录所有执行的语句,将此配置设置为all可跟踪整个数据库执行的SQL语句。

比如,保留一周的日志,到了新的一周,就会把之前一周的日志覆盖掉

Log_filename='kingbase-%Y%m%d-%H.log'

Log_rotation_age=1440

Log_truncate_on_rotation=on

2.2.4. 参数建议设置

max_connections=1000
shared_buffers=RAM(free -g)*0.4GB
work_mem =10MB
maintenance_work_mem=1GB
effective_cache_size=RAM(free -g)*0.5GB
logging_collector=on
log_destination='stderr'
log_directory='sys_log'
log_filename='kingbase-%Y%m%d-%H.log'
log_truncate_on_rotation=on
log_rotation_age=1440
log_rotation_size=100MB
log_connections=on
log_disconnections=on
log_statement='none'
log_checkpoints=on
log_lock_waits=on
log_autovacuum_min_duration=0
lc_messages='C'
log_temp_files=0
log_min_duration_statement=1000
log_line_prefix='%t [%p]: [%l-1] user=%u,db=%d,app=%a,client=%h'
char_default_type='char'
max_locks_per_transaction=1024
#ora_date_style=on
#ora_format_style=on
#ora_func_style=on
#ora_input_emptystr_isnull=on
#ora_numop_style=on

3. 数据库监控运维

3.1. 数据库日志位置

  1. 数据库日志:

数据目录下的sys_log目录

此目录下存放的是数据库日志文件,数据库运行信息,sql执行情况都存放此目录下的日志文件中。

  1. 集群日志:

集群目录下

集群的日志文件存放在此目录下

hamgr.log 集群运行状态日志

kbha.log 监控repmgrd进程日志

3.2. 集群状态查看

启停集群:

集群目录/bin下手动启动停止 sh sys_monitor.sh start/stop

3.2.1. 集群状态查看:

repmgr cluster show

要点:status是*ruuning或running状态;upstrean如果不是级联复制,都是指向primary node。

repmgr cluster event

要点:可以看到事件及事件发生时间。该信息对于定位问题很重要。

3.2.2. 查看流复制情况:

select * from sys_stat_replication;

要点:几个lsn之减值差异,代表复制延迟。sync_stat表示复制状态,可以是quorum,sync,async

3.2.3. 查看复制槽情况:

select * from sys_replication_slots;

要点:关键值是active值。如果active='f',表示该replication slot对应的数据库没启动或者流复制有问题。

3.2.4. 流复制监控:

流复制监控是根据视图sys_stat_replication判断日志传输及日志应用延迟情况。该视图右击重要的值:

sent_lsn master传送WAL的位置

write_lsn slave接收WAL的位置(写入到OS写队列)

flush_lsn slave同步到磁盘的WAL位置(刷入到磁盘)

replay_lsn slave同步到数据库的WAL位置(应用到数据库)

具体监控脚本如下:

select client_addr,
	sys_wal_lsn_diff(sys_current_wal_insert_lsn(),sys_current_wal_lsn()) as local_noflush_delay,
	sys_wal_lsn_diff(sys_current_wal_lsn(),sent_lsn) as local_sent_delay,
	sys_wal_lsn_diff(sent_lsn,write_lsn) as stream_write_delay,
	sys_wal_lsn_diff(sent_lsn,flush_lsn) as stream_flush_delay,
	sys_wal_lsn_diff(sent_lsn,replay_lsn) as stream_replay_dela
from sys_stat_replication;

3.3. 连接监控

sys_stat_activity:实例维护的一个进程相关的视图,是实时变化的。

样例:

1、查看总连接数:

select count(*) from sys_stat_activity where backend_xid <> sys_backend_pid();

2、查看正在执行的查询数:

select datname,count(*) as open,count(*) filter (where state = 'active' ) as active,count(*) filter (where state = 'idle' ) as idle,count(*) filter (where state = 'idle in transaction' ) as idle_in_trans from sys_stat_activity group by rollup(1);

3、查看连接数:

select datname,usename,client_addr,count(*) from sys_stat_activity where backend_xid<>sys_backend_pid() group by 1,2,3 order by 1,2,4 desc;

4、查看大于1s的sql:

select * from sys_stat_activity where state<>'idle' and now()-query_start > interval '1 s' order by query_start ;

5、查看大于5分钟的长事务:

select query,state from sys_stat_activity where state<>'idle' and (backend_xid is not null or backend_xmin is not null) and now()-xact_start > interval '5 min' order by xact_start;

6、查询活动会话:

select pid,usename,datname,query,client_addr from sys_stat_activity where backend_xid<>sys_backend_pid() and state='active' order by query;

3.4. 查看对象大小

查看数据库/表/索引的大小

SELECT datname,sys_size_pretty(sys_database_size(datname)) FROM sys_database;
SELECT relname,sys_size_pretty(sys_relation_size(oid)) FROM sys_class WHERE relname = 'test0';
SELECT relname,sys_size_pretty(sys_total_relation_size(oid)) FROM sys_class WHERE relname = 'test0';
SELECT relname,sys_size_pretty(sys_indexes_size(oid)) FROM sys_class WHERE relname = 'test0';

3.5. 回收空间

  • 目的

回收或重用dead tuples占用的磁盘空间

“冻结”数据,防止事务ID回卷导致数据不可见

  • 方法

内置autovacuum(基本免维护)

vacuumdb [OPTION]... [DBNAME]

VACUUM [ FULL | FREEZE | ANALYZE | DISABLE_PAGE_SKIPPING ] [table_name[(column_name[, ...])]]

FULL:完全清理(彻底,但是慢)

FREEZE:快速清理并冻结元组(效果较好,较慢)

ANALYZE:快速清理并更新统计信息(效果较好,较快)

3.6. 长事务清理

  • 长事务的弊端

阻止垃圾回收,导致表和索引膨胀

频繁唤醒autovacuum进程,浪费I/O

  • 查找长事务
SELECT pid,state,query FROM sys_stat_activity WHERE state <> 'idle' AND now()-xact_start > interval '10s';

  • 终止长事务、长连接
SELECT sys_terminate_backend(pid);

3.7. 故障处理

出现上图类似的报错,一般是由于系统资源不足导致,修改系统limit限制(open files,max user processes,core file size),systemd的DefaultTasksMax的设置,此参数会限制服务可创建的最大进程数。

  • CPU使用率过高

CPU使用率过高,导致应用系统系统运行较慢。

先通过系统视图sys_stat_activity,定位执行时间较长的sql,数据库中单独执行,确定执行时间确实较慢,通过优化将sql执行时间缩短,达到降低 CPU使用率的问题

  • sys_locks视图用于查看锁信息

锁冲突数量监控

select * from sys_locks where granted='f';

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

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

相关文章

【Prometheus】Prometheus如何监控Haproxy

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…

【0x0012】HCI_Delete_Stored_Link_Key命令详解

目录 一、命令参数 二、命令格式及参数 2.1. HCI_Delete_Stored_Link_Key 命令格式 2.2. BD_ADDR 2.3. Delete_All 三、生成事件及参数 3.1. HCI_Command_Complete事件 3.2. Status 3.3. Num_Keys_Deleted 四、命令执行流程 4.1. 命令发送阶段 4.2. 控制器处理阶段…

github汉化

本文主要讲述了github如何汉化的方法。 目录 问题描述汉化步骤1.打开github&#xff0c;搜索github-chinese2.打开项目&#xff0c;打开README.md3.下载安装脚本管理器3.1 在README.md中往下滑动&#xff0c;找到浏览器与脚本管理器3.2 选择浏览器对应的脚本管理器3.2.1 点击去…

机器学习-K近邻算法

文章目录 一. 数据集介绍Iris plants dataset 二. 代码三. k值的选择 一. 数据集介绍 鸢尾花数据集 鸢尾花Iris Dataset数据集是机器学习领域经典数据集&#xff0c;鸢尾花数据集包含了150条鸢尾花信息&#xff0c;每50条取自三个鸢尾花中之一&#xff1a;Versicolour、Setosa…

C++函数——fill

在C中&#xff0c;std::fill 是标准库提供的一个算法适用于几乎所有类型的容器&#xff0c;只要这些容器支持迭代器操作。具体来说&#xff0c;std::fill 的适用性取决于容器是否提供了满足其要求的迭代器类型&#xff0c;用于将指定范围内的所有元素设置为某个特定值。它是一个…

如何打造高效同城O2O平台?外卖跑腿系统源码选型与开发指南

打造一个高效的同城O2O平台&#xff0c;选择合适的外卖跑腿系统源码并制定科学的开发方案至关重要。本篇文章&#xff0c;笔者将从源码选型、核心功能、开发架构及运营策略等方面&#xff0c;全面解析O2O平台的搭建思路。 一、外卖跑腿系统源码的选型要点 在搭建O2O平台时&…

Flutter_学习记录_基本组件的使用记录

1.TextWidge的常用属性 1.1TextAlign: 文本对齐属性 常用的样式有&#xff1a; TextAlign.center 居中TextAlign.left 左对齐TextAlign.right 有对齐 使用案例&#xff1a; body: Center(child: Text(开启 TextWidget 的旅程吧&#xff0c;珠珠, 开启 TextWidget 的旅程吧&a…

Qt实践:一个简单的丝滑侧滑栏实现

Qt实践&#xff1a;一个简单的丝滑侧滑栏实现 笔者前段时间突然看到了侧滑栏&#xff0c;觉得这个抽屉式的侧滑栏非常的有趣&#xff0c;打算这里首先尝试实现一个简单的丝滑侧滑栏。 首先是上效果图 &#xff08;C&#xff0c;GIF帧率砍到毛都不剩了&#xff09; QProperty…

10. SpringCloud Alibaba Sentinel 规则持久化部署详细剖析

10. SpringCloud Alibaba Sentinel 规则持久化部署详细剖析 文章目录 10. SpringCloud Alibaba Sentinel 规则持久化部署详细剖析1. 规则持久化1.1 Nacos Server 配置中心-规则持久化实例 2. 最后&#xff1a; 1. 规则持久化 规则没有持久化的问题 如果 sentinel 流控规则没有…

SpringCloud微服务Gateway网关简单集成Sentinel

Sentinel是阿里巴巴开源的一款面向分布式服务架构的轻量级流量控制、熔断降级组件。Sentinel以流量为切入点&#xff0c;从流量控制、熔断降级、系统负载保护等多个维度来帮助保护服务的稳定性。 官方文档&#xff1a;https://sentinelguard.io/zh-cn/docs/introduction.html …

正则表达式以及Qt中的使用

目录 一、正则表达式 1、基本匹配&#xff1a; 2、元字符&#xff1a; 2.1 .运算符&#xff1a; 2.2 字符集&#xff1a; 2.3 重复次数&#xff1a; 2.4 量词{} 2.5 特征标群() 2.6 或运算符 2.7 \反斜线转码特殊字符 2.8 锚点 3、简写字符 4、零宽度断言 4.1 正…

【STM32HAL-----GPIO】

1. 什么是GPIO&#xff1f;&#xff08;了解&#xff09; 2. STM32 GPIO简介 2.1. GPIO特点 2.2. GPIO电气特性 2.3. GPIO引脚分布图 IO引脚分布特点&#xff1a;按组存在、组数视芯片而定、每组最多16个IO引脚。 3. IO端口基本结构介绍 4. GPIO八种工作模式 4.1. 输入浮空 特…

亲测有效!解决PyCharm下PyEMD安装报错 ModuleNotFoundError: No module named ‘PyEMD‘

解决PyCharm下PyEMD安装报错 PyEMD安装报错解决方案 PyEMD安装报错 PyCharm下通过右键自动安装PyEMD后运行报错ModuleNotFoundError: No module named ‘PyEMD’ 解决方案 通过PyCharm IDE python package搜索EMD-signal&#xff0c;选择版本后点击“install”执行安装

低代码系统-产品架构案例介绍、简道云(七)

今天分析另外一个零代码、低代码产品-简道云&#xff0c;跟所有低代码产品的架构图一样&#xff0c;高、大、炫、美。 依然是从下至上&#xff0c;从左到右的顺序。 开发层 搭建中心 表单、流程、报表、用户中心&#xff0c;还是这些内容&#xff0c;自定义打印很多平台都有&am…

Chrome 132 版本新特性

Chrome 132 版本新特性 一、Chrome 132 版本浏览器更新 1. 在 iOS 上使用 Google Lens 搜索 在 Chrome 132 版本中&#xff0c;开始在所有平台上推出这一功能。 1.1. 更新版本&#xff1a; Chrome 126 在 ChromeOS、Linux、Mac、Windows 上&#xff1a;在 1% 的稳定版用户…

计算机网络三张表(ARP表、MAC表、路由表)总结

参考&#xff1a; 网络三张表&#xff1a;ARP表, MAC表, 路由表&#xff0c;实现你的网络自由&#xff01;&#xff01;_mac表、arp表、路由表-CSDN博客 网络中的三张表&#xff1a;ARP表、MAC表、路由表 首先要明确一件事&#xff0c;如果一个主机要发送数据&#xff0c;那么必…

cursor重构谷粒商城04——vagrant技术快速部署虚拟机

前言&#xff1a;这个系列将使用最前沿的cursor作为辅助编程工具&#xff0c;来快速开发一些基础的编程项目。目的是为了在真实项目中&#xff0c;帮助初级程序员快速进阶&#xff0c;以最快的速度&#xff0c;效率&#xff0c;快速进阶到中高阶程序员。 本项目将基于谷粒商城…

【玩转全栈】----Django连接MySQL

阅前先赞&#xff0c;养好习惯&#xff01; 目录 1、ORM框架介绍 选择建议 2、安装mysqlclient 3、创建数据库 4、修改settings&#xff0c;连接数据库 5、对数据库进行操作 创建表 删除表 添加数据 删除数据 修改&#xff08;更新&#xff09;数据&#xff1a; 获取数据 1、OR…

Jmeter使用Request URL请求接口

简介 在Jmeter调试接口时&#xff0c;有时不清楚后端服务接口的具体路径&#xff0c;可以使用Request URL和cookie来实现接口请求。以下内容以使用cookie鉴权的接口举例。 步骤 ① 登录网站后获取具体的Request URL和cookie信息 通过浏览器获取到Request URL和cookie&#…

mock可视化生成前端代码

介绍&#xff1a;mock是我们前后端分离的必要一环、ts、axios编写起来也很麻烦。我们就可以使用以下插件&#xff0c;来解决我们的问题。目前支持vite和webpack。&#xff08;配置超级简单&#xff01;&#xff09; 欢迎小伙伴们提issues、我们共建。提升我们的开发体验。 vi…