HBase Cassandra的部署和操作
目录
一.数据库的部署与配置
二.使用命令访问数据库
三.数据库的设计
四.编程实现数据库的访问
一.数据库的部署与配置
1.在单个节点上对进行数据库的单机部署
(1)下载apache-cassandra-4.1.7-bin.tar.gz,上传到hadoop1 的/export/software目录
(2)使用解压缩命令:tar -xzf /export/software/apache-cassandra-4.1.7-bin.tar.gz -C /export/servers/ 进行解压缩到/export/servers目录
(3)使用cd /export/servers命令进入/export/servers目录
(4)将Cassandra目录进行重命名:mv apache-cassandra-4.1.7 apache-cassandra-4.1.7-standalone
(5)启动Cassandra:bin/cassandra -R
(6)查看Cassandra启动信息:tail -f logs/system.log
(7)检查状态:bin/nodetool status
(8)连接数据库:bin/cqlsh
(9)关闭Cassandra:bin/nodetool stopdaemon
2.在多个节点上实现数据库的分布式部署
(1)在Hadoop1、Hadoop2和Hadoop3上分别执行systemctl stop firewalld和systemctldisable firewalld命令关闭防火墙;
(2)在Hadoop1、Hadoop2、Hadoop3上分别执行ssh-keygen,ssh-copy-id hadoop1,ssh-copy-id hadoop2,ssh-copy-id hadoop3,使各个节点可以免密登录
注:在Hadoop2和Hadoop3上的执行结果与Hadoop1几乎相同,故不再展示。
(3)进行免密登录测试,在Hadoop1、Hadoop2和Hadoop3上分别执行ssh hadoop1,ssh hadoop2,ssh hadoop3,可以免密登录即可
注:在Hadoop2和Hadoop3上的执行结果与Hadoop1几乎相同,故不再展示。
(4)在Hadoop1、Hadoop2和Hadoop3上分别上传压缩安装包
(5)在Hadoop1、Hadoop2和Hadoop3上分别解压缩apache-cassandra-4.1.7-bin.tar.gz:tar -xzf /export/software/apache-cassandra-4.1.7-bin.tar.gz -C /export/servers/
(6)分别修改Hadoop1、Hadoop2和Hadoop3的cassandra.yaml文件中的seeds、listen_address和rpc_address,具体修改如下:
Hadoop1:seeds=192.168.121.160,listen_address=192.168.121.160,rpc_address=192.168.121.160;
Hadoop1:seeds=192.168.121.160,listen_address=192.168.121.161,rpc_address=192.168.121.161;
Hadoop1:seeds=192.168.121.160,listen_address=192.168.121.162,rpc_address=192.168.121.162
注:因修改过程类似,此处只展示Hadoop1节点上的修改结果。
(7)在Hadoop1、Hadoop2和Hadoop3上使用命令分别启动Cassandra:
bin/cassandra -R
(8)查看运行状态:bin/nodetool status
(9)连接任一服务器均可:bin/cqlsh hadoop1,bin/cqlsh hadoop2,bin/cqlsh hadoop3
二.使用命令访问数据库
练习Cassandra的相关命令。
1.键空间:创建、删除和查看键空间
(1)创建并查看键空间
CREATE KEYSPACE IF NOT EXISTS library_system
WITH REPLICATION = {
'class' : 'SimpleStrategy',
'replication_factor' : 1
};
DESCRIBE KEYSPACES;
(2)删除并再次查看键空间
DROP KEYSPACE IF EXISTS library_system;
DESCRIBE KEYSPACES;
2.表:创建表、设置复合型主键、修改表结构(要求:复合主键要包括分区键和分簇键,数据类型要包含两种以上的集合类型和一种以上的自定义类型)
以图书管理系统为例进行如下操作:
(1)创建表(包含复合型主键)
在图书管理系统中,我们设计一个图书借阅记录表,复合主键由 book_id 和 borrower_id 组成,分区键使用 book_id,集群键使用 borrower_id。还使用了集合类型(SET)存储借阅的日期,以及自定义类型(user_info)来存储借阅人的信息。
语句如下:
CREATE TYPE IF NOT EXISTS library_system.user_info (
name TEXT,
email TEXT,
phone_number TEXT
);
CREATE TABLE IF NOT EXISTS library_system.book_borrowing (
book_id UUID, -- 分区键
borrower_id UUID, -- 集群键
borrow_date DATE, -- 借阅日期
return_date DATE, -- 归还日期
status TEXT, -- 状态(如 已借出、已归还)
tags SET<TEXT>, -- 标签(如 热门、推荐等)
borrower_info FROZEN<user_info>, -- 自定义类型,借阅人信息
PRIMARY KEY (book_id, borrower_id) -- 复合主键
);
其中,book_id是分区键,borrower_id 是集群键,tags 是集合类型,用来存储书籍标签,borrower_info 是自定义类型 user_info,用于存储借阅人的信息。
(2)修改表结构
添加一个新列来记录图书的借阅次数。
语句如下:
ALTER TABLE library_system.book_borrowing ADD borrow_count INT;
3.数据查询
(1)查询所有数据
SELECT * FROM library_system.book_borrowing;
(2)根据分区键查询
SELECT * FROM library_system.book_borrowing WHERE book_id = 3796171a-9a3d-45e6-8886-42601fed5c04;
(3)根据分区键和集群键查询
SELECT * FROM library_system.book_borrowing WHERE book_id = b8cdcddb-4b1e-4937-83cd-dbfbf5288671 AND borrower_id = b36f25ca-082c-4ded-afc9-6675eda47cd4;
(4)查询特定列
SELECT book_id, borrow_date, return_date FROM library_system.book_borrowing WHERE book_id = b8cdcddb-4b1e-4937-83cd-dbfbf5288671 AND borrower_id = b36f25ca-082c-4ded-afc9-6675eda47cd4;
(5)查询集合类型数据
SELECT tags FROM library_system.book_borrowing WHERE book_id = b8cdcddb-4b1e-4937-83cd-dbfbf5288671 AND borrower_id = b36f25ca-082c-4ded-afc9-6675eda47cd4;
(6)查询自定义类型数据
SELECT borrower_info FROM library_system.book_borrowing WHERE book_id = b8cdcddb-4b1e-4937-83cd-dbfbf5288671 AND borrower_id = b36f25ca-082c-4ded-afc9-6675eda47cd4;
4.数据更新:数据插入、数据更新、数据删除
(1)数据插入
INSERT INTO library_system.book_borrowing (book_id, borrower_id, borrow_date, return_date, status, tags, borrower_info)
VALUES (uuid(), uuid(), '2024-01-01', '2024-01-15', 'Borrowed', {'Popular', 'New Release'},
{name: 'John Doe', email: 'johndoe@example.com', phone_number: '1234567890'});
(2)数据更新
UPDATE library_system.book_borrowing
SET return_date = '2024-01-20', status = 'Returned'
WHERE book_id = b8cdcddb-4b1e-4937-83cd-dbfbf5288671 AND borrower_id = b36f25ca-082c-4ded-afc9-6675eda47cd4;
(3)数据删除
①删除单条数据
DELETE FROM library_system.book_borrowing
WHERE book_id = b8cdcddb-4b1e-4937-83cd-dbfbf5288671 AND borrower_id = b36f25ca-082c-4ded-afc9-6675eda47cd4;
②删除整张表
TRUNCATE library_system.book_borrowing;
三.数据库的设计
图书管理系统包含三个主要实体:图书、读者和借阅记录。它们之间通过一个关系来进行联系,借阅记录表示图书与读者之间的借阅关系,本系统共设计三张表,分别是图书表(存储图书的相关信息)、借阅记录表(存储借阅的记录)和读者表(存储读者的基本信息)。
1.数据库设计
(1)图书表
表名:Books
列族(Column Families):
info:存储图书的基本信息
author:存储作者的详细信息
publisher:存储出版商的信息
行键设计:
行键:book_id(唯一标识每本图书)
列名与存储内容:
在info列族下:
title:书名
category:类别(如科幻、文学等)
published_date:出版日期
在author列族下:
name:作者名称
birth_date:作者出生日期
在publisher列族下:
publisher_name:出版商名称
publisher_address:出版商地址
(2)读者表
表名:Readers
列族(Column Families):
info:存储读者的基本信息
contact:存储读者的联系信息(例如地址、电话)
行键设计:
行键:reader_id(唯一标识每个读者)
列名与存储内容:
在info列族下:
reader_name:读者姓名
dob:出生日期
在contact列族下:
email:电子邮件地址
phone_number:电话号
address:家庭住址
(3)借阅记录表
表名:BorrowRecords
列族(Column Families):
info:存储借阅信息
reader:存储读者信息
行键设计:
行键:borrow_id(唯一标识每次借阅记录)
列名与存储内容:
在info列族下:
book_id:借阅的图书ID
borrow_date:借阅日期
return_date:归还日期
在reader列族下:
reader_name:读者姓名
reader_id:读者ID
(4)实体和关系的增删改查
①新增操作
新增图书:向Books表中插入新的行,包含图书ID(行键)及其对应的列族和列名。
新增借阅记录:向BorrowRecords表中插入新的行,包含借阅记录ID(行键)、借阅图书ID、借阅日期、归还日期、读者信息等。
新增读者:向Readers表中插入新的行,包含读者ID(行键)、姓名、出生日期、联系信息等。
②删除操作
删除图书:通过图书ID删除Books表中的记录。
删除借阅记录:通过借阅记录ID删除BorrowRecords表中的记录。
删除读者:通过读者ID删除Readers表中的记录。
③更新操作
更新图书信息:可以根据图书ID(行键)来更新Books表中的某些列,比如更新书名、作者或出版日期等。
更新借阅记录:可以根据借阅记录ID(行键)来更新借阅日期或归还日期等。
更新读者信息:可以根据读者ID(行键)来更新Readers表中的读者姓名、地址、电话等。
④查询操作
查询某本图书的详细信息:通过book_id查询Books表中的详细信息。
查询某本图书的借阅记录:通过book_id在BorrowRecords表中查找所有借阅记录。
查询某位读者的借阅记录:通过reader_id在BorrowRecords表中查找该读者的所有借阅记录。
查询某位读者的详细信息:通过reader_id查询Readers表中的详细信息。
2.表设计与填充数据
(1)图书表
行键(book_id) | 列族 | 列名 | 列值 |
B001 | info | title | 《活着》 |
category | 文学 | ||
published_date | 1993-06-01 | ||
author | name | 余华 | |
birth_date | 1960-04-03 | ||
publisher | publisher_name | 作家出版社 | |
publisher_address | 北京市朝阳区 | ||
B002 | info | title | 《百年孤独》 |
category | 小说 | ||
published_date | 1967-06-05 | ||
author | name | 加西亚·马尔克斯 | |
birth_date | 1927-03-06 | ||
publisher | publisher_name | 南海出版公司 | |
publisher_address | 上海市徐汇区 |
(2)读者表
行键(reader_id) | 列族 | 列名 | 列值 |
R001 | info | reader_name | 张三 |
dob | 1990-05-15 | ||
contract | | zhsan@email.com | |
phone_number | 123-4567-8901 | ||
address | 北京市海淀区 | ||
R002 | info | reader_name | 李四 |
dob | 2005-02-28 | ||
contract | | lisi@email.com | |
phone_number | 987-6543-2100 | ||
address | 上海市浦东新区 |
(3)借阅记录表
行键(borrow_id) | 列族 | 列名 | 列值 |
BR001 | info | Book_id | B001 |
Borrow_date | 2024-11-01 | ||
Return_date | 2024-11-15 | ||
reader | Reader_name | 张三 | |
Reader_id | R001 | ||
BR001 | info | Book_id | B002 |
Borrow_date | 2024-11-02 | ||
Return_date | 2024-11-20 | ||
reader | Reader_name | 李四 | |
Reader_id | R002 |
四.编程实现数据库的访问
使用Python访问实现设计的图书管理系统的列式数据库,步骤如下:
(1)数据库连接:连接到Cassandra集群,并创建数据库library和数据表Books、Readers和BorrowRecords,具体代码如下:
from cassandra.cluster import Cluster
# 连接到 Cassandra 集群
cluster = Cluster(['192.168.121.160']) 虚拟机的 IP 地址
session = cluster.connect()
# 创建 Keyspace:library
session.execute("""
CREATE KEYSPACE IF NOT EXISTS library WITH replication = {'class': 'SimpleStrategy', 'replication_factor': 1}
""")
# 使用创建的 Keyspace
session.execute("USE library")
# 创建表结构
# 创建 Books 表
session.execute("""
CREATE TABLE IF NOT EXISTS Books (
book_id TEXT PRIMARY KEY,
title TEXT,
category TEXT,
published_date TEXT,
author_name TEXT,
author_birth_date TEXT,
publisher_name TEXT,
publisher_address TEXT
)
""")
# 创建 Readers 表
session.execute("""
CREATE TABLE IF NOT EXISTS Readers (
reader_id TEXT PRIMARY KEY,
reader_name TEXT,
dob TEXT,
email TEXT,
phone_number TEXT,
address TEXT
)
""")
# 创建 BorrowRecords 表
session.execute("""
CREATE TABLE IF NOT EXISTS BorrowRecords (
borrow_id TEXT PRIMARY KEY,
book_id TEXT,
borrow_date TEXT,
return_date TEXT,
reader_name TEXT,
reader_id TEXT
)
""")
print("Keyspace and tables created.")
结果如下图所示:
(2)数据增加
分别给三张表插入数据,具体代码如下:
①插入图书记录
session.execute("""
INSERT INTO Books (book_id, title, category, published_date, author_name, author_birth_date, publisher_name, publisher_address)
VALUES (%s, %s, %s, %s, %s, %s, %s, %s)
""", ('B001', '《活着》', '文学', '1993-06-01', '余华', '1960-04-03', '作家出版社', '北京市朝阳区'))
结果如下图所示:
②插入读者信息
session.execute("""
INSERT INTO Readers (reader_id, reader_name, dob, email, phone_number, address)
VALUES (%s, %s, %s, %s, %s, %s)
""", ('R001', '张三', '1990-05-15', 'zhangsan@email.com', '123-4567-8901', '北京市海淀区'))
结果如下图所示:
③插入借阅记录
session.execute("""
INSERT INTO BorrowRecords (borrow_id, book_id, borrow_date, return_date, reader_name, reader_id)
VALUES (%s, %s, %s, %s, %s, %s)
""", ('BR001', 'B001', '2024-11-01', '2024-11-15', '张三', 'R001'))
结果如下图所示:
(3)数据更新
更新读者的联系方式,具体代码如下:
session.execute("""
UPDATE Readers SET email = %s WHERE reader_id = %s
""", ('newemail@email.com', 'R001'))
结果如下图所示:
(4)数据查询
查询book_id为B001图书的详细信息,具体代码如下:
# 查询某本图书的详细信息
rows = session.execute("""
SELECT * FROM Books WHERE book_id = %s
""", ('B001',))
for row in rows:
print(row)
结果如下图所示:
(5)数据删除
删除book_id为B001图书的记录
session.execute("""
DELETE FROM Books WHERE book_id = %s
""", ('B001',))
执行结果如下图所示:
相关文章:
HBase Cassandra的部署和操作
目录 一.数据库的部署与配置 二.使用命令访问数据库 三.数据库的设计 四.编程实现数据库的访问 一.数据库的部署与配置 1.在单个节点上对进行数据库的单机部署 (1)下载apache-cassandra-4.1.7-…...

用户界面软件01
Jens Coldewey 著,Tom.X 译 本文中的模式语言逐步深入地探讨用户界面架构的设计,它基于人机工程学,足以形成一套完整的体系。如果你对这方面有兴趣,请参考[Tog92],[Coo95]和[Col95]。 本文不讨论用户界面的布局&…...
【云原生】Docker Compose 从入门到实战使用详解
目录 一、前言 二、Docker Compose 介绍 2.1 Docker Compose概述 2.2 Docker Compose特点 2.3 Docker Compose使用场景 三、Docker Compose 安装 3.1 安装docker环境 3.2 Docker Compose安装方式一 3.2.1 下载最新版 3.2.2 设置权限 3.2.3 设置软链接 3.2.4 查看版本…...
【ShuQiHere】使用 SCP 进行安全文件传输
【ShuQiHere】🚀 在日常的开发和运维工作中,文件传输是一个常见的任务。scp(Secure Copy)是一个基于 SSH 协议的文件传输工具,能够在本地和远程主机之间安全地复制文件和目录。本文将详细介绍 scp 的使用方法…...

海康威视H5player问题汇总大全
由于除了要支持Windows平台,还要支持国产系统的平台,这时就用到了H5player,但是这个在使用调试的时候会遇到各种各样的问题,便在此分享一下,供大家分享!!! 问题一:Unexp…...
力扣23.合并K个升序链表
文章目录 一、前言二、最小堆解法三、分治解法 一、前言 23. 合并 K 个升序链表 本题的要求是把K个链表进行合并,合并后的链表必须是从小到大的。 并且这K个链表也是从小到大的升序链表。 二、最小堆解法 既然每个链表都是升序的,也就是从小到大的。 …...

【C 语言指针篇】指针的灵动舞步与内存的神秘疆域:于 C 编程世界中领略指针艺术的奇幻华章
文章目录 【C 语言篇】指针的灵动舞步与内存的神秘疆域:于 C 编程世界中领略指针艺术的奇幻华章前言一 、指针的介绍与使用1. 指针的介绍1.1指针表示1.2指针变量1.3空指针 2. 使用指针2.1交换两个变量的值2.2计算输出最小值和最大值 二、野指针的介绍与使用1. 野指针…...

游戏关卡设计的常用模式
游戏关卡分为很多种,但常用的有固定套路,分为若干种类型。 关卡是主角与怪物、敌方战斗的场所,包括装饰物、通道。 单人游戏的关卡较小,偏线性; 联机/MMO的关卡较大,通道多,自由度高…...
在一台服务器上使用docker运行kafka集群
1.拉取镜像 docker pull wurstmeister/kafka docker pull wurstmeister/zookeeper 2.创建集群之间通信的网络 docker network create kafka-cluster-net docker network inspect kafka-cluster-net 3.将zookeeper加入到网络中 docker network connect kafka-cluster-net zooke…...

Apache Celeborn 在B站的生产实践
背景介绍 Shuffle 演进 随着B站业务的飞速发展,数据规模呈指数级增长,计算集群也逐步从单机房扩展到多机房部署模式。多个业务线依托大数据平台驱动核心业务,大数据系统的高效性与稳定性成为公司业务发展的重要基石。如图1,目前在大数据基础架构下,我们主要采用 Spark、Fl…...
JOIN 和 OUTER JOIN,SQL中常见的连接方式
1. INNER JOIN(简称 JOIN) INNER JOIN 是 SQL 中最常用的一种连接方式,默认的 JOIN 就是 INNER JOIN。它返回两个表中满足连接条件的匹配记录。 作用:返回两个表中所有满足 ON 条件的记录。特性:如果表中的某些行在连…...

Vue2: table加载树形数据的踩坑记录
table中需要加载树形数据,如图: 官网给了两个例子,且每个例子中的tree-props都是这么写的: :tree-props="{children: children, hasChildren: hasChildren}" 给我一种错觉,以为数据结构中要同时指定children和hasChildren字段,然而,在非懒加载模式下,数据结…...
电子信息硕士面试经验
回顾2024年秋招一些面试常见的问题,主要涉及软件开发和嵌入式部分内容。 1. 浅拷贝深拷贝 深拷贝和浅拷贝是两种不同的拷贝方式,用于复制对象。它们主要区别在于对嵌套对象的处理方式。 浅拷贝:只复制对象的顶层,嵌套对象仍然是共享引用。 深拷贝:递归复制所有对象及其嵌…...
dns网址和ip是一一对应的吗?
DNS网址和IP地址是一一对应的吗?我们在上网时,为什么总是使用网址而不是一串数字?这些问题其实涉及到互联网的基本运作原理。DNS(域名系统)是我们日常上网过程中一个不可或缺的部分,它帮助我们将人类易于记…...
springboot3 redis 常用操作工具类
在 Spring Boot 3 中,操作 Redis 通常使用 Spring Data Redis 提供的工具类,如 RedisTemplate 和 StringRedisTemplate。以下是一个详细的 Redis 操作工具类的实现,涵盖了常用功能。 完整的 Redis 工具类 以下工具类可以实现基本的 Redis 操…...

Java工程师实现视频文件上传minio文件系统存储及网页实现分批加载视频播放
Java工程师实现minio存储大型视频文件网页实现分批加载视频播放 一、需求说明 老板给我出个题目,让我把的电影文件上传到minio文件系统,再通过WEB端分配加载视频播放,类似于我们普通的电影网站。小编把Java代码共享出来。是真正的能拿过来直…...

Redis(二)value 的五种常见数据类型简述
目录 一、string(字符串) 1、raw 2、int 3、embstr 二、hash(哈希表) 1、hashtable 2、ziplist 三、list(列表) 编辑 1、linkedlist 2、ziplist 3、quicklist(redis 3.2后的列表内…...

Docker 环境中搭建 Redis 哨兵模式集群的步骤与问题解决
在 Docker 环境中搭建 Redis 哨兵模式集群的步骤与问题解决 在 Redis 高可用架构中,哨兵模式(Sentinel)是确保 Redis 集群在出现故障时自动切换主节点的一种机制。通过使用 Redis 哨兵,我们可以实现 Redis 集群的监控、故障检测和…...

【网页自动化】篡改猴入门教程
安装篡改猴 打开浏览器扩展商店(Edge、Chrome、Firefox 等)。搜索 Tampermonkey 并安装。 如图安装后,浏览器右上角会显示一个带有猴子图标的按钮。 创建用户脚本 已进入篡改猴管理面板点击创建 脚本注释说明 name:脚本名称。…...

【顶刊TPAMI 2025】多头编码(MHE)之极限分类 Part 4:MHE表示能力
目录 1 MHE的表示能力2 基于Frobenius-范数的低秩逼近3 基于CE的低秩近似 论文:Multi-Head Encoding for Extreme Label Classification 作者:Daojun Liang, Haixia Zhang, Dongfeng Yuan and Minggao Zhang 单位:山东大学 代码:h…...
[特殊字符] 智能合约中的数据是如何在区块链中保持一致的?
🧠 智能合约中的数据是如何在区块链中保持一致的? 为什么所有区块链节点都能得出相同结果?合约调用这么复杂,状态真能保持一致吗?本篇带你从底层视角理解“状态一致性”的真相。 一、智能合约的数据存储在哪里…...

AI-调查研究-01-正念冥想有用吗?对健康的影响及科学指南
点一下关注吧!!!非常感谢!!持续更新!!! 🚀 AI篇持续更新中!(长期更新) 目前2025年06月05日更新到: AI炼丹日志-28 - Aud…...
模型参数、模型存储精度、参数与显存
模型参数量衡量单位 M:百万(Million) B:十亿(Billion) 1 B 1000 M 1B 1000M 1B1000M 参数存储精度 模型参数是固定的,但是一个参数所表示多少字节不一定,需要看这个参数以什么…...
在鸿蒙HarmonyOS 5中实现抖音风格的点赞功能
下面我将详细介绍如何使用HarmonyOS SDK在HarmonyOS 5中实现类似抖音的点赞功能,包括动画效果、数据同步和交互优化。 1. 基础点赞功能实现 1.1 创建数据模型 // VideoModel.ets export class VideoModel {id: string "";title: string ""…...

SCAU期末笔记 - 数据分析与数据挖掘题库解析
这门怎么题库答案不全啊日 来简单学一下子来 一、选择题(可多选) 将原始数据进行集成、变换、维度规约、数值规约是在以下哪个步骤的任务?(C) A. 频繁模式挖掘 B.分类和预测 C.数据预处理 D.数据流挖掘 A. 频繁模式挖掘:专注于发现数据中…...

UE5 学习系列(三)创建和移动物体
这篇博客是该系列的第三篇,是在之前两篇博客的基础上展开,主要介绍如何在操作界面中创建和拖动物体,这篇博客跟随的视频链接如下: B 站视频:s03-创建和移动物体 如果你不打算开之前的博客并且对UE5 比较熟的话按照以…...
rnn判断string中第一次出现a的下标
# coding:utf8 import torch import torch.nn as nn import numpy as np import random import json""" 基于pytorch的网络编写 实现一个RNN网络完成多分类任务 判断字符 a 第一次出现在字符串中的位置 """class TorchModel(nn.Module):def __in…...
Hive 存储格式深度解析:从 TextFile 到 ORC,如何选对数据存储方案?
在大数据处理领域,Hive 作为 Hadoop 生态中重要的数据仓库工具,其存储格式的选择直接影响数据存储成本、查询效率和计算资源消耗。面对 TextFile、SequenceFile、Parquet、RCFile、ORC 等多种存储格式,很多开发者常常陷入选择困境。本文将从底…...

基于TurtleBot3在Gazebo地图实现机器人远程控制
1. TurtleBot3环境配置 # 下载TurtleBot3核心包 mkdir -p ~/catkin_ws/src cd ~/catkin_ws/src git clone -b noetic-devel https://github.com/ROBOTIS-GIT/turtlebot3.git git clone -b noetic https://github.com/ROBOTIS-GIT/turtlebot3_msgs.git git clone -b noetic-dev…...
CRMEB 中 PHP 短信扩展开发:涵盖一号通、阿里云、腾讯云、创蓝
目前已有一号通短信、阿里云短信、腾讯云短信扩展 扩展入口文件 文件目录 crmeb\services\sms\Sms.php 默认驱动类型为:一号通 namespace crmeb\services\sms;use crmeb\basic\BaseManager; use crmeb\services\AccessTokenServeService; use crmeb\services\sms\…...