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

【KWDB创作者计划】_KaiwuDB 2.1.0 单节点裸机部署

大家好,这里是 DBA学习之路,专注于提升数据库运维效率。

目录

  • 前言
  • KWDB 介绍
  • 安装准备
    • 环境信息
    • 配置要求
    • 操作系统
    • 软件依赖
    • 端口要求
    • 安装包下载
  • 部署 KWDB
  • 简单实用
    • 连接数据库
    • 创建数据库
    • 创建用户
    • 创建时序表

前言

今天无意间在墨天轮看到一个征文活动 征文大赛 |「码」上数据库—— KWDB 2025 创作者计划启动,想着参与一下支持开源,顺便了解一下新的开源时序数据库 KWDB。

写了一篇时序数据库 KWDB 的简单安装和使用,分享给大家一起看看~

KWDB 介绍

KWDB(KaiwuDB)是一款开源的时序数据库,是浪潮集团控股的数据库企业,以多模数据库为核心,主要面向工业物联网、数字能源、交通车联网、智慧城市、数字政务等多种场景。

早在 2023.01.10 KWDB 1.0 就已经正式发布,经过一年多的孵化,目前最新版已经来到 2.1.0,可以说已经是一款比较成熟的数据库了。

KWDB 为不同角色开发者提供以下支持(包括但不限于):

  • 为开发者提供通用连接接口,具备高速写入、极速查询、SQL 支持、随需压缩、数据生命周期管理、集群部署等特性,与第三方工具无缝集成,降低开发及学习难度,提升开发使用效率。
  • 为运维管理人员提供快速安装部署、升级、迁移、监控等能力,降低数据库运维管理成本。

KWDB 官方资源参考

  • KWDB 开源地址:https://gitee.com/kwdb/kwdb
  • 部署操作文档:https://www.kaiwudb.com/kaiwudb_docs/#/oss_v2.1.0/quickstart/overview.html
  • KWDB 最新发行版 2.1.0 下载地址:https://gitee.com/kwdb/kwdb/releases/tag/V2.1.0

KWDB 支持用户根据需求选择二进制安装包、容器和源码安装与试用 KWDB 数据库:

  • 二进制安装包:支持单机和集群以及安全和非安全部署模式。
  • 源码安装:源码编译目前支持单节点非安全模式部署。
  • 容器镜像:KWDB 暂未提供可供下载的容器镜像,如需以容器方式部署 KWDB,需要联系 KWDB 技术支持人员。

可以看到二进制安装包的方式支持的架构比较多,所以本文选择用二进制安装的方式进行部署。

安装准备

本文介绍如何使用 KWDB 二进制安装包在单个节点上安装部署 KWDB。

环境信息

这里本着国产数据库用国产系统,所以选择麒麟 V10 系统进行测试:

主机名版本CPU内存硬盘
kwdb银河麒麟V10x868G100G

配置要求

参考官方手册给出的部署 KWDB 所需的硬件规格:

项目要求
CPU 和内存单节点配置建议不低于 4 核 8G。对于数据量大、复杂的工作负载、高并发和高性能场景,建议配置更高的 CPU 和内存资源以确保系统的高效运行。
磁盘1、推荐使用 SSD 或者 NVMe 设备,尽量避免使用 NFS、CIFS、CEPH 等共享存储。
2、磁盘必须能够实现 500 IOPS 和 30 MB/s 处理效率。
文件系统建议使用 ext4 文件系统。

实际部署时,用户可以根据实际的业务规模和性能要求规划硬件资源。

操作系统

KWDB 官方已经认证的服务器操作系统:

操作系统版本架构
Anolis8.6ARM_64
Anolis8.6x86_64
KylinOSV10 SP3 2403
V10 SP3 2303
ARM_64
KylinOSV10 SP3 2403
V10 SP3 2303
x86_64
UbuntuV20.04ARM_64
UbuntuV20.04x86_64
UbuntuV22.04ARM_64
UbuntuV22.04x86_64
UbuntuV24.04ARM_64
UbuntuV24.04x86_64
UOS1060ex86_64
UOS1060eARM_64

软件依赖

KWDB 在安装时会对依赖进行检查,如果缺少依赖会退出安装并提示依赖缺失。不同操作系统及安装包的依赖略有不同,需要根据实际安装包类型及操作系统,在部署前安装好相应的依赖。

下表列出需要在目标机器安装的依赖:

依赖版本说明
OpenSSLv1.1.1+N/A
Protobufv3.5.0+N/A
GEOSv3.3.8+可选依赖
xz-libsv5.2.0+N/A
squashfs-toolsanyN/A
libgccv7.3.0+N/A
mountanyN/A
squashfuseany可选依赖

配置本地软件源:

## 挂载本地镜像源
[root@kwdb ~]# mount /dev/cdrom /mnt/
mount: /mnt: WARNING: source write-protected, mounted read-only.
## 备份系统初始配置文件
[root@kwdb ~]# mkdir -p /etc/yum.repos.d/bak
[root@kwdb ~]# mv /etc/yum.repos.d/* /etc/yum.repos.d/bak
## 一键配置软件源,默认 ISO 安装镜像挂载在 /mnt 目录下
[root@kwdb ~]# cat<<-EOF>/etc/yum.repos.d/local.repo
[server]
name=server
baseurl=file:///mnt
enabled=1
gpgcheck=0
EOF

手动安装依赖:

yum install -y protobuf
## 手动下载上传
rpm -ivh geos-3.6.1-12.ky10.x86_64.rpm

检查操作系统是否已安装对应依赖:

[root@kwdb soft]# rpm -q openssl protobuf geos xz-libs squashfs-tools libgcc util-linux
openssl-1.1.1f-31.p23.ky10.x86_64
protobuf-3.14.0-7.ky10.x86_64
geos-3.6.1-12.ky10.x86_64
xz-libs-5.2.5-3.ky10.x86_64
squashfs-tools-4.5-4.ky10.x86_64
libgcc-7.3.0-2020033101.58.p01.ky10.x86_64
util-linux-2.35.2-14.p03.ky10.x86_64

确保所有的依赖都已成功安装。

端口要求

在安装部署前,确保目标机器的以下端口没有被占用且没有被防火墙拦截。在安装部署时,用户可以修改 deploy.cfg 文件中的端口配置参数。

下表列出 KWDB 服务需要映射的端口:

端口号说明
8080数据库 Web 服务端口
26257数据库服务端口、节点监听端口和对外连接端口

建议关闭防火墙:

[root@kwdb ~]# systemctl stop firewalld.service 
[root@kwdb ~]# systemctl disable firewalld.service 
Removed /etc/systemd/system/multi-user.target.wants/firewalld.service.
Removed /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.

安装包下载

在 gitee 上下载对应的二进制安装包:

将安装包复制到待安装 KWDB 的目标机器上,然后解压缩安装包:

[root@kwdb soft]# ll
总用量 27956
-rw-r--r-- 1 root root 28625639  318 13:35 KWDB-2.1.0-kylinV10_2403-x86_64-rpms.tar.gz
[root@kwdb soft]# tar -xf KWDB-2.1.0-kylinV10_2403-x86_64-rpms.tar.gz 
[root@kwdb soft]# cd kwdb_install/

解压后生成的目录包含以下文件:

[root@kwdb kwdb_install]# tree -N
.
├── add_user.sh ## 安装、启动 KWDB 后,为 KWDB 数据库创建用户
├── deploy.cfg ## 安装部署配置文件,用于配置部署节点的 IP 地址、端口等配置信息
├── deploy.sh ## 安装部署脚本,用于安装、卸载、启动、状态获取、关停和重启等操作
├── packages ## 存放 DEB、RPM 和镜像包
│   ├── kwdb-libcommon-2.1.0-kylin.ky10.x86_64.rpm
│   └── kwdb-server-2.1.0-kylin.ky10.x86_64.rpm
└── utils ## 存放工具类脚本├── container_shell.sh├── kaiwudb_cluster.sh├── kaiwudb_common.sh├── kaiwudb_hardware.sh├── kaiwudb_install.sh├── kaiwudb_log.sh├── kaiwudb_operate.sh├── kaiwudb_uninstall.sh├── kaiwudb_upgrade.sh├── process_bar.sh└── utils.sh2 directories, 16 files

至此,环境准备完成,接下来可以开始部署 KWDB。

部署 KWDB

部署 KWDB 时,系统将对配置文件、运行环境、硬件配置和软件依赖进行检查。

  • 如果相应硬件未能满足要求,系统将继续安装,并提示硬件规格不满足要求。
  • 如果软件依赖未能满足要求,系统将中止安装,并提供相应的提示信息。

在部署过程中,系统会自动生成相关日志。如果部署时出现错误,用户可以通过查看终端输出或 KWDB 安装目录中 log 目录里的日志文件,获取详细的错误信息。

部署完成后,系统会将 KWDB 封装成系统服务(名称为 kaiwudb),并生成以下文件:

  • kaiwudb.service:配置 KWDB 的 CPU 资源占用率。
  • kaiwudb_env:配置 KWDB 启动参数。

安装用户为 root 用户或者拥有 sudo 权限的普通用户。

登录待部署节点,编辑安装包目录下的 deploy.cfg 配置文件,设置安全模式、管理用户、服务端口等信息:

## 默认情况下,deploy.cfg 配置文件中包含集群配置参数,需要删除或注释 [cluster] 集群配置项。
[root@kwdb kwdb_install]# cat<<-EOF>/soft/kwdb_install/deploy.cfg
[global]
secure_mode=insecure
management_user=kaiwudb
rest_port=8080
kaiwudb_port=26257
data_root=/var/lib/kaiwudb
cpu=1
[local]
node_addr=192.168.6.79
EOF

参数说明

  • global:全局配置
    • secure_mode:是否开启安全模式,支持以下两种取值:
      • insecure:使用非安全模式。
      • tls:(默认选项)开启 TLS 安全模式。开启安全模式后,KaiwuDB 生成 TLS 证书,作为客户端或应用程序连接数据库的凭证,生成的客户端相关证书存放在 /etc/kaiwudb/certs 目录。
    • management_user:KaiwuDB 的管理用户,默认为 kaiwudb。安装部署后,KaiwuDB 创建相应的管理用户以及和管理用户同名的用户组。
    • rest_port:KaiwuDB Web 服务端口,默认为 8080
    • kaiwudb_port:KaiwuDB 服务端口,默认为 26257
    • data_root:数据目录,默认为 /var/lib/kaiwudb
    • cpu: 可选参数,用于指定 KaiwuDB 服务占用当前节点服务器 CPU 资源的比例,默认无限制。取值范围为 [0,1],最大精度为小数点后两位。
  • local:本地节点配置
    • node_addr:本地节点对外提供服务的 IP 地址,监听地址为 0.0.0.0,端口为 KaiwuDB 服务端口。

为 deploy.sh 脚本添加运行权限:

[root@kwdb kwdb_install]# chmod +x deploy.sh

安装过程中需要输入 kaiwudb 用户密码,复杂度参考操作系统,不符合复杂度会报错退出安装。如果没有密码复杂性要求,不想设置密码太复杂的话,可以取消密码复杂度:

[root@kwdb kwdb_install]# sed -i 's/^password\+[[:space:]]\+requisite[[:space:]]\+pam_pwquality.so/#&/g' /etc/pam.d/system-auth
[root@kwdb kwdb_install]# sed -i 's/use_authtok$//' /etc/pam.d/system-auth

执行单机部署安装命令:

[root@kwdb kwdb_install]# ./deploy.sh install --single
## 这里需要输入 kaiwudb 用户的密码,输完之后记得保留密码

执行成功后,控制台输出以下信息:

[INSTALL COMPLETED]:KaiwuDB has been installed successfully! To start KaiwuDB, please execute the command 'systemctl daemon-reload'. 

根据系统提示重新加载 systemd 守护进程的配置文件:

[root@kwdb kwdb_install]# systemctl daemon-reload

启动 KWDB 节点:

[root@kwdb kwdb_install]# ./deploy.sh start
[START COMPLETED]:KaiwuDB start successfully.

执行成功后,控制台输出以上信息。

查看 KWDB 节点状态:

[root@kwdb kwdb_install]# ./deploy.sh status
[STATUS COMPLETED]:KaiwuDB is runnning now.[root@kwdb kwdb_install]# systemctl status kaiwudb
● kaiwudb.service - KaiwuDB ServiceLoaded: loaded (/etc/systemd/system/kaiwudb.service; disabled; vendor preset: disabled)Active: active (running) since Tue 2025-03-18 14:21:11 CST; 49s agoProcess: 40587 ExecStartPre=/usr/bin/sudo /usr/sbin/sysctl -w vm.max_map_count=10000000 (code=exited, status=0/SUCCESS)Main PID: 40598 (kwbase)Tasks: 41Memory: 477.1MCGroup: /system.slice/kaiwudb.service└─40598 /usr/local/kaiwudb/bin/kwbase start-single-node --insecure --listen-addr=0.0.0.0:26257 --advertise-addr=192.168.6.79:26257 --http-addr=0.0.0.0:8080 --store=/var/lib/kaiwudb318 14:21:13 kwdb kwbase[40598]: sql:                 postgresql://root@192.168.6.79:26257?sslmode=disable
318 14:21:13 kwdb kwbase[40598]: RPC client flags:    /usr/local/kaiwudb/bin/kwbase <client cmd> --host=192.168.6.79:26257 --insecure
318 14:21:13 kwdb kwbase[40598]: logs:                /var/lib/kaiwudb/logs
318 14:21:13 kwdb kwbase[40598]: temp dir:            /var/lib/kaiwudb/kwbase-temp492528165
318 14:21:13 kwdb kwbase[40598]: external I/O path:   /var/lib/kaiwudb/extern
318 14:21:13 kwdb kwbase[40598]: store[0]:            path=/var/lib/kaiwudb
318 14:21:13 kwdb kwbase[40598]: storage engine:      rocksdb
318 14:21:13 kwdb kwbase[40598]: status:              initialized new cluster
318 14:21:13 kwdb kwbase[40598]: clusterID:           532f74b0-03a7-4921-839b-5132f10644cf
318 14:21:13 kwdb kwbase[40598]: nodeID:              1

配置 KWDB 开机自启动:

[root@kwdb kwdb_install]# systemctl enable kaiwudb
Created symlink /etc/systemd/system/multi-user.target.wants/kaiwudb.service → /etc/systemd/system/kaiwudb.service.

配置 KWDB 开机自启动后,如果系统重启,则自动启动 KWDB。

简单实用

连接数据库

[kaiwudb@kwdb ~]$ kwbase sql --insecure --host=192.168.6.79
#
# Welcome to the KWDB SQL shell.
# All statements must be terminated by a semicolon.
# To exit, type: \q.
#
# Server version: KaiwuDB 2.1.0 (x86_64-linux-gnu, built 2024/11/22 12:14:25, go1.16.15, gcc 7.3.0) (same version as client)
# Cluster ID: 532f74b0-03a7-4921-839b-5132f10644cf
#
# Enter \? for a brief introduction.
#
root@192.168.6.79:26257/defaultdb> show database;database
-------------defaultdb
(1 row)Time: 795.282µs

创建数据库

-- 创建一个名称为 tsdb 的时序库,数据保存周期为 90 天
root@192.168.6.79:26257/defaultdb> CREATE TS DATABASE tsdb RETENTIONS 90d;
CREATE TS DATABASETime: 8.576464msroot@192.168.6.79:26257/defaultdb> SHOW DATABASES;database_name | engine_type
----------------+--------------defaultdb     | RELATIONALpostgres      | RELATIONALsystem        | RELATIONALtsdb          | TIME SERIES
(4 rows)Time: 1.913474msroot@192.168.6.79:26257/defaultdb> USE tsdb;SETTime: 1.011287ms

创建用户

-- 创建一个名称为 testu 的用户,授予其 tsdb 数据库的所有权限
CREATE USER testu;
GRANT ALL ON DATABASE tsdb to testu;
SHOW USERS;

创建时序表

在 tsdb 数据库中创建名为 readings 的时序表,存储温度和湿度数据,并使用传感器 ID 和位置作为标签:

root@192.168.6.79:26257/defaultdb> use tsdb;
SETTime: 990.008µsroot@192.168.6.79:26257/tsdb> CREATE TABLE tsdb.readings (ts timestamp NOT NULL,         -- 数据读取时间戳temperature FLOAT,             -- 温度(摄氏度)humidity FLOAT                 -- 湿度(百分比)
) TAGS (sensor_id INT NOT NULL,        -- 传感器 IDlocation CHAR(256) NOT NULL    -- 传感器位置(如 "Room 101")
) PRIMARY TAGS(sensor_id);
CREATE TABLETime: 69.114769ms

向 readings 时序表中写入数据:

root@192.168.6.79:26257/tsdb> INSERT INTO tsdb.readings 
VALUES 
(NOW(), 23.0, 59.5, 101, 'Room 101'),
(NOW(), 23.5, 58.9, 102, 'Room 102'),
(NOW(), 19.8, 65.5, 103, 'Room 103');
INSERT 3Time: 18.171494ms

查询 readings 时序表中的数据:

root@192.168.6.79:26257/tsdb> SELECT * FROM readings;ts              | temperature | humidity | sensor_id | location
-------------------------------+-------------+----------+-----------+-----------2025-03-18 07:13:53.75+00:00 |          23 |     59.5 |       101 | Room 1012025-03-18 07:13:53.75+00:00 |        23.5 |     58.9 |       102 | Room 1022025-03-18 07:13:53.75+00:00 |        19.8 |     65.5 |       103 | Room 103
(3 rows)Time: 2.194378ms

查看已创建的表结构:

root@192.168.6.79:26257/tsdb> SHOW CREATE TABLE readings;table_name |                     create_statement
-------------+------------------------------------------------------------readings   | CREATE TABLE readings (|     ts TIMESTAMPTZ NOT NULL,|     temperature FLOAT8 NULL,|     humidity FLOAT8 NULL| ) TAGS (|     sensor_id INT4 NOT NULL,|     location CHAR(256) NOT NULL ) PRIMARY TAGS(sensor_id)
(1 row)Time: 236.503887ms

到这, KaiwuDB 的单机安装就完成了。

相关文章:

【KWDB创作者计划】_KaiwuDB 2.1.0 单节点裸机部署

大家好&#xff0c;这里是 DBA学习之路&#xff0c;专注于提升数据库运维效率。 目录 前言KWDB 介绍安装准备环境信息配置要求操作系统软件依赖端口要求安装包下载 部署 KWDB简单实用连接数据库创建数据库创建用户创建时序表 前言 今天无意间在墨天轮看到一个征文活动 征文大赛…...

洛谷题单3-P5720 【深基4.例4】一尺之棰-python-流程图重构

题目描述 《庄子》中说到&#xff0c;“一尺之棰&#xff0c;日取其半&#xff0c;万世不竭”。第一天有一根长度为 a a a 的木棍&#xff0c;从第二天开始&#xff0c;每天都要将这根木棍锯掉一半&#xff08;每次除 2 2 2&#xff0c;向下取整&#xff09;。第几天的时候木…...

前端快速入门学习3——CSS介绍与选择器

1.概述 CSS全名是cascading style sheets,中文名层叠样式表。 用于定义网页样式和布局的样式表语言。 通过 CSS&#xff0c;你可以指定页面中各个元素的颜色、字体、大小、间距、边框、背景等样式&#xff0c;从而实现更精确的页面设计。 HTML与CSS的关系&#xff1a;HTML相当…...

Redash:一个开源的数据查询与可视化工具

Redash 是一款免费开源的数据可视化与协作工具&#xff0c;可以帮助用户快速连接数据源、编写查询、生成图表并构建交互式仪表盘。它简化了数据探索和共享的过程&#xff0c;尤其适合需要团队协作的数据分析场景。 数据源 Redash 支持各种 SQL、NoSQL、大数据和 API 数据源&am…...

嵌入式Linux驱动—— 1 GPIO配置

目录 1.GPIO操作 1.1 IO命名 1.2 GPIO 时钟使能&#xff08;CCM&#xff09; 1.3 IO 复用&#xff08;IOMUXC&#xff09; 1.4 IO 配置 1.5 GPIO 配置 1.GPIO操作 GPIO操作主要是以下流程&#xff1a; 使能某组GPIO模块&#xff08;GPIO1、2、...&#xff09;&#…...

[ICLR 2025]Biologically Plausible Brain Graph Transformer

论文网址&#xff1a;Biologically Plausible Brain Graph Transformer 英文是纯手打的&#xff01;论文原文的summarizing and paraphrasing。可能会出现难以避免的拼写错误和语法错误&#xff0c;若有发现欢迎评论指正&#xff01;文章偏向于笔记&#xff0c;谨慎食用 目录 …...

SpringBoot+MyBatis Plus+PageHelper+vue+mysql 实现用户信息增删改查功能

静态资源展示 &#xff08;1&#xff09;静态资源下载 &#xff08;2&#xff09;下载后文件放到resources/static 目录下 (3) main函数启动项目访问对应文件&#xff0c;http://127.0.0.1:8080/user-list.html 数据库添加表和数据 SET FOREIGN_KEY_CHECKS0;-- --------…...

企业常用Linux服务搭建

1.需要两台centos 7服务器&#xff0c;一台部署DNS服务器&#xff0c;另一台部署ftp和Samba服务器。 2. 部署DNS 服务器​ #!/bin/bash# 更新系统 echo "更新系统..." sudo yum update -y# 安装 BIND 和相关工具 echo "安装 BIND 和相关工具..." sudo y…...

Qwen-7B-Chat 本地化部署使用

通义千问 简介 通义千问是阿里云推出的超大规模语言模型&#xff0c;以下是其优缺点&#xff1a; 优点 强大的基础能力&#xff1a;具备语义理解与抽取、闲聊、上下文对话、生成与创作、知识与百科、代码、逻辑与推理、计算、角色扮演等多种能力。可以续写小说、编写邮件、解…...

QGIS获取建筑矢量图-Able Software R2V

1.QGIS截图 说明&#xff1a;加载天地图矢量图层&#xff0c;然后进行截图。 2.Able Software R2V 说明&#xff1a;Able Software R2V 是一款​​将光栅图像&#xff08;如扫描图纸、航拍照片&#xff09;自动转换为矢量图形&#xff08;如DXF格式&#xff09;​​的软件&a…...

CSS:换行与不换行

一、CSS 不允许换行 在 CSS 中&#xff0c;有几种方法可以控制文本不换行&#xff1a; 1. 使用 white-space 属性 .no-wrap {white-space: nowrap; } white-space: nowrap; 会强制文本在一行显示&#xff0c;不换行。 2. 使用 overflow 和 text-overflow 通常与 white-sp…...

【MiniMind】不能全局用 `pip install --upgrade pip`

Q&#xff1a;WARNING: Running pip as the ‘root’ user can result in broken permissions and conflicting behaviour with the system package manager, possibly rendering your system unusable. It is recommended to use a virtual environment instead: https://pip.…...

form实现pdf文件转换成jpg文件

说明&#xff1a; 我希望将pdf文件转换成jpg文件 请去下载并安装 Ghostscript&#xff0c;gs10050w64.exe 配置环境变量&#xff1a;D:\Program Files\gs\gs10.05.0\bin 本地pdf路径&#xff1a;C:\Users\wangrusheng\Documents\name.pdf 输出文件目录&#xff1a;C:\Users\wan…...

STM32单片机入门学习——第13节: [6-1] TIM定时中断

写这个文章是用来学习的,记录一下我的学习过程。希望我能一直坚持下去,我只是一个小白,只是想好好学习,我知道这会很难&#xff0c;但我还是想去做&#xff01; 本文写于&#xff1a;2025.04.04 STM32开发板学习——第13节: [6-1] TIM定时中断 前言开发板说明引用解答和科普一…...

量子纠错码实战:从Shor码到表面码

引言&#xff1a;量子纠错的必要性 量子比特的脆弱性导致其易受退相干和噪声影响&#xff0c;单量子门错误率通常在10⁻~10⁻量级。量子纠错码&#xff08;QEC&#xff09;通过冗余编码测量校正的机制&#xff0c;将逻辑量子比特的错误率降低到可容忍水平。本文从首个量子纠错…...

【2】搭建k8s集群系列(二进制)之安装etcd数据库集群

一、etcd服务架构 Etcd 是一个分布式键值存储系统&#xff0c;Kubernetes 使用 Etcd 进行数据存储&#xff0c;所以先 准备一个 Etcd 数据库&#xff0c;为解决 Etcd 单点故障&#xff0c;应采用集群方式部署&#xff0c;这里使用 3 台组建集群&#xff0c;可容忍 1 台机器故障…...

Linux常用命令详解:从基础到进阶

目录 一、引言 二、文件处理相关命令 &#xff08;一&#xff09;grep指令 &#xff08;二&#xff09;zip/unzip指令 ​编辑 &#xff08;三&#xff09;tar指令 &#xff08;四&#xff09;find指令 三、系统管理相关命令 &#xff08;一&#xff09;shutdown指…...

【Docker】使用Docker快速部署n8n和unclecode/crawl4ai

Docker部署自动化工具n8n和crawl4ai详细教程 前言 本文将详细介绍如何使用 Docker 来部署和运行自动化工作流工具 n8n 以及 crawl4ai。这两个工具对于需要进行自动化工作流程的开发者来说都非常有用。 一、环境准备 在开始之前&#xff0c;请确保您的系统已经安装了&#x…...

数据库权限获取

1. into outfile(手写) 1.1. 利用条件 • web 目录具有写入权限,能够使用单引号 • 知道网站绝对路径(根目录,或则是根目录往下的目录都行) • secure_file_priv 没有具体值(在 mysql/my.ini 中查看) 1.2. secure_file_priv 介绍 secure_file_priv 是用来限制 loa…...

基于spring boot的外卖系统的设计与实现【如何写论文思路与真正写出论文】

目录 系统开发实现链接&#xff1a; 背景与分析&#xff1a; 背景&#xff08;题目&#xff09;&#xff1a; 用户功能 配送员功能 管理员功能 分析&#xff1a; 过程&#xff08;主体展示为主&#xff0c;部分功能不一一展示&#xff09;&#xff1a; 目录 论文前面…...

Kubernetes 存储 Downward API

1.介绍 1.提供容器元数据 比如我们 golang语言 我们说他会根据当前CPU的数量 以此去确认我们的进程 线程 和协程之间的关系 以此去释放我们当前CPU的更大的 这么一个并行任务的能力 但是这里会出现一个问题 容器它是把当前的应用 封装在我们固定的名称空间了 而且给它以特定的…...

使用ctags+nvim自动更新标签文件

ctags是一个强大的语言分析工具&#xff0c;可以分析多种语言并生成语法结构文件&#xff0c;通过这些文件可以快速进行函数跳转&#xff0c;但是这有一个缺点&#xff0c;就是每次在项目里更新了代码之类的比如新增了一个函数&#xff0c;都需要重新使用ctags -R .来重新更新标…...

RK3568 gpio模拟i2c 配置hym8563 RTC时钟

1、使用模拟i2c,确认使用的gpio未被占用,为gpio功能 以GPIO0_C6 GPIO0_C7为例,查看管脚的复用关系。 cat /sys/kernel/debug/pinctrl/pinctrl-rockchip-pinctrl/pinmux-pins2、使用内核模块i2c-gpio.c 内核make menuconfig 开启i2c_gpio支持 Device Drivers->I2C sup…...

HANA如何在存储过程里执行动态SQL

业务场景需求&#xff1a; 在HANA里如何实现动态的SQL控制&#xff0c;比如需要多个单据里&#xff0c;实现某个自定义字段不允许重复 一般的写法是需要在每个业务单据里加对应的存储过程控制&#xff0c;这样的话&#xff0c;需要在每个业务单据里进行控制&#xff0c;SQL维…...

01人工智能基础入门

一、AI应用场景和发展历程 1.1行业应用 1、deepdream图像生成、yolo目标检测 2、知识图谱、画风迁移 3、语音识别、计算机视觉 4、用户画像 5、百度人工智能布局 1.2发展历程 人工智能的发展经历了 3 个阶段&#xff1a; 1980年代是正式成形期&#xff0c;尚不具备影响力。 …...

嵌入式AI的本地化部署的好处

嵌入式AI本地化处理&#xff08;即边缘计算&#xff09;的核心优势在于将AI算力下沉至设备端&#xff0c;直接处理数据而非依赖云端&#xff0c;这种模式在多个维度上展现出显著价值&#xff1a; 一、数据隐私与安全性提升 1. 敏感数据本地存储 金融、医疗等涉及隐私的行业…...

进程和内存管理

目录 一.进程的基本信息 1.1进程的定义 1.2进程的特征 1.3进程的组成 1.4线程产生的背景 1.5线程的定义 1.6进程与线程的区别 1.7进程的类别 1.8进程的优先级 1.8.1进程优先级的概念 1.8.2PRI和NI 1.9僵尸进程 1.9.1僵尸进程的定义 1.9.2僵尸进程产生的原因 1.9…...

001 vue

https://cn.vuejs.org/ 文章目录 v-bindv-modelv-on修饰符条件渲染/控制&#xff1a;v-if v-show列表渲染 M&#xff1a;即Model&#xff0c;模型&#xff0c;包括数据和一些基本操作 V&#xff1a;即View&#xff0c;视图&#xff0c;页面渲染结果 VM&#xff1a;即View-Mode…...

css动态设置div宽高,calc函数

在css中使用calc函数 calc() 是 CSS 中的一种函数&#xff0c;用于动态计算长度值。它允许你在 CSS 属性中进行数学运算&#xff0c;结合不同的单位&#xff08;如 px、%、em 等&#xff09;&#xff0c;从而创建更加灵活和响应式的布局 表达式规则 运算符&#xff1a;支持加…...

MySQL篇(四)事务相关知识详解

MySQL篇(四&#xff09;事务相关知识详解 MySQL篇(四&#xff09;事务相关知识详解一、事务的特性&#xff08;ACID&#xff09;原子性&#xff08;Atomicity&#xff09;一致性&#xff08;Consistency&#xff09;隔离性&#xff08;Isolation&#xff09;持久性&#xff08;…...