技术好文:scyllaDB基本使用

简介: 技术好文:scyllaDB基本使用

目录


1.scylla部署docker单机部署docker集群部署2.在cqlsh中操作scyllaDB3.scyllaDB的操作创建keysapce创建表插入数据到scylla表查看scylla集群状态查看表状态增加字段删除scylla表 //代码效果参考:http://www.lyjsj.net.cn/wx/art_23881.html

4.spark和scyllaDB集成使用spark读写scyllaDB

回到顶部1.scylla部署


docker单机部署


可以使用docker镜像来启动scyllaDB


docker集群部署


也可以使用docker镜像来部署scyllaDB集群


?1234567docker run --name scylla -p 9042:9042 -p 9160:9160 -p 10000:10000 -p 9180:9180 -v /var/lib/scylla:/var/lib/scylla -d scylladb/scylla docker run --name scylla-node2 -p 8042:9042 -p 8160:9160 -p 1000:10000 -p 8180:9180 -v /var/lib/scylladb2:/var/lib/scylla -d scylladb/scylla --seeds="$(docker inspect --format='{ { .NetworkSettings.IPAddress }}' scylla)" docker run --name scylla-node3 -p 10042:9042 -p 10160:9160 -p 1100:10000 -p 10180:9180 -v /var/lib/scylladb3:/var/lib/scylla -d scylladb/scylla --seeds="$(docker inspect --format='{ { .NetworkSettings.IPAddress }}' scylla)" docker run --name scylla-node4 -p 11042:9042 -p 11160:9160 -p 1200:10000 -p 11180:9180 -v /var/lib/scylladb4:/var/lib/scylla -d scylladb/scylla --seeds="$(docker inspect --format='{ { .NetworkSettings.IPAddress }}' scylla)"


回到顶部2.在cqlsh中操作scyllaDB


在cqlsh中可以使用CQL (the Cassandra Query Language) 来对scyllaDB做一些基本操作


?12345sh-4.2# cqlshConnected to at 172.17.0.3:9042.【cqlsh 5.0.1 | Cassandra 3.0.8 | CQL spec 3.3.1 | Native protocol v4】Use HELP for help.cqlsh>


参考:CQLSh: the CQL shell


回到顶部3.scyllaDB的操作


scylla数据存储于table当中,而table由keyspace分组


创建keysapce


名字叫做test


?1234cqlsh> CREATE KEYSPACE IF NOT EXISTS test WITH REPLICATION = {'class': 'SimpleStrategy','replication_factor':1};cqlsh> describe keyspaces; system_schema system_auth system system_distributed test system_traces


REPLICATION参数指定了备份策略,使用了REPLICATION后必须指定class,其中class有SimpleStrategy,NetworkTopologyStrategy,在这里由于是单机测试,所以我指定副本数量是1


创建表


?123456789101112131415cqlsh> use test;cqlsh:test

PRIMARY KEY参数指定了主键,会按照user_id,mtime的顺序来排列key


CLUSTERING参数指定了mtime按照降序排列


插入数据到scylla表


?12345INSERT INTO demo (user_id,str,mtime) VALUES (6,'test','2021-10-09 07:00:00') using TTL 86400;


可以看到相同的key user_id会聚合到一起,相同的user_id中mtime按照降序排列


?123456789101112cqlsh:test

class="bash plain"] select * from demo; user_id | mtime | str---------+---------------------------------+------- 5 | 2021-10-09 02:00:00.000000+0000 | Panda 1 | 2021-10-09 04:00:00.000000+0000 | Kay 1 | 2021-10-01 02:00:00.000000+0000 | Kay 2 | 2021-10-09 03:00:00.000000+0000 | Snail 2 | 2021-10-01 02:00:00.000000+0000 | Snail 6 | 2021-10-09 07:00:00.000000+0000 | test (6 rows)

参考:Data Definition 


查看scylla集群状态


?12345678910111213【root@6a30e1b8fc71 /】# nodetool statusUsing /etc/scylla/scylla.yaml as the config fileDatacenter: datacenter1=======================Status=Up/Down|/ State=Normal/Leaving/Joining/Moving-- Address Load Tokens Owns Host ID RackUN 172.17.0.2 1.49 MB 256 ? //代码效果参考:http://www.lyjsj.net.cn/wz/art_23877.html

eaee8765-450d-4d4e-a7b5-2ed4c6b20df3 rack1UN 172.17.0.5 1.04 MB 256 ? 17153bb7-f4f1-4436-bc49-f1eca3409040 rack1UN 172.17.0.4 1.03 MB 256 ? 25fd6224-7edc-4161-bf49-ba6fe51c9f73 rack1UN 172.17.0.6 1.04 MB 256 ? 3d5757d2-dc5f-4ba4-8d90-e02eb9d4c255 rack1 Note: Non-system keyspaces don't have the same replication settings, effective ownership information is meaningless  

查看表状态


?1nodetool tablestats my_ks.my_tb


增加字段


?1ALTER TABLE xx.xx ADD col_name col_type;


删除scylla表


?1drop table xx.xx;


回到顶部4.spark和scyllaDB集成


使用spark读写scyllaDB


由于scyllaDB兼容cassandra API,所以可以参考:


?1


或者可以参考我的文章:Spark学习笔记——读写ScyllaDB


其他:sizing-your-scylla-cluster


MySQL 亿级数据迁移 之 Cassandra概述

相关文章
|
23天前
|
算法 开发工具 数据安全/隐私保护
练手必备!Python编程实战—23个有趣的实战项目带你快速进阶
Python的练手项目有哪些值得推荐? 已经有6.4W关注,700W次浏览,回答都有450条了,本来遇到这种问题我是不会回答的,毕竟已经有太多人给出了答案,我再去回答就没什么意义了。 但想了想确实有很多刚学Python的并不清楚从哪里去找项目来练手,于是就有了这篇文章,基于这个目的,我也是找了好久,最后还是选择了分享这份手册,毕竟里面有细致的讲解,确实更适合练手一些。
|
3天前
技术经验分享:GMU简单使用一
技术经验分享:GMU简单使用一
|
1月前
|
算法 机器人 C++
C++零基础全面教程(开篇介绍)
C++零基础全面教程(开篇介绍)
47 0
|
7月前
|
移动开发 开发框架 前端开发
进阶攻略|前端最全的框架总结
进阶攻略|前端最全的框架总结
45 1
|
10月前
|
XML IDE 编译器
【C++】C++ 基础进阶【二】开发技巧
C++基础进阶,关于开发环境开发工具的一些便捷使用方式,提高生产力
124 0
【C++】C++ 基础进阶【二】开发技巧
|
11月前
|
前端开发 C# 数据库管理
(3) MasaFramework 入门第三篇,使用MasaFramework
(3) MasaFramework 入门第三篇,使用MasaFramework
74 0
(3) MasaFramework 入门第三篇,使用MasaFramework
|
移动开发 JavaScript 前端开发
手把手教你如何使用NodeJs和JavaScript开发微信公众号(一)
手把手教你如何使用NodeJs和JavaScript开发微信公众号
327 0
手把手教你如何使用NodeJs和JavaScript开发微信公众号(一)
|
前端开发 JavaScript API
手把手教你如何使用NodeJs和JavaScript开发微信公众号(三)
手把手教你如何使用NodeJs和JavaScript开发微信公众号
177 0
手把手教你如何使用NodeJs和JavaScript开发微信公众号(三)
|
JavaScript NoSQL 前端开发
手把手教你如何使用NodeJs和JavaScript开发微信公众号(二)
手把手教你如何使用NodeJs和JavaScript开发微信公众号
342 0
手把手教你如何使用NodeJs和JavaScript开发微信公众号(二)
|
JSON 小程序 JavaScript
全栈工程师之路-中级篇之小程序开发-第一章第三节阅读官方demo
全栈工程师之路-中级篇之小程序开发-第一章第三节阅读官方demo
158 0
全栈工程师之路-中级篇之小程序开发-第一章第三节阅读官方demo