麒麟v10 上部署 TiDB v5.1.2 生产环境优化实践
579
2024-03-09
notice"Rust is a trademark of the Mozilla Foundation in the US and other countries."
最近想看看 rust 如何集成 clickhouse,又犯了好吃懒做的心理(不想自己建环境),刚好京东云发布了兼容ck 的云原生数仓 Starwfit,于是搞了个实例折腾一番。Starwfit 是京东云自主研发的新一代云原生数据仓库,通过存算分离降低了存储成本,同时兼具性能和扩展弹性。其写入和查询速度可达到传统数据仓库的数倍,为用户提供实时数据分析能力。广泛应用于流量分析、精准营销、用户画像、广告实时竞价、BI报表分析、日志分析、促销选品、物联网等业务场景。广告打到这里,言归正传,看看 rust 如何与 starwift 打交道。
登录控制台,直接选配创建即可
创建用户
开启白名单为了保证starwift能够被外部资源访问需要开启白名单,默认情况下新创建的实例只有该实例所在vpc下才能访问为了方便,实验环境直接编辑 default 分组,编辑 ip 列表为 0.0.0.0/0,对所有ip开放。在实际生产环境需要根据实际情况配置白名单避免安全问题。
开启公网连接
为了实验方便,开启公网访问域名便于开发和测试
安装客户端
macos 客户端安装
curl -O https://builds.clickhouse.com/master/macos/clickhouse && chmod a +x ./clickhouse其他客户端安装 参见 clickhosue 官方文档
测试连通性
clickhouse client --host service-terrabase-9s29mdlsb7.terrabase-9s29mdlsb7-hb-public.jvessel2.jdcloud.com \ --port 9000 \ --user sample \ --password xxxxxxclickhouse:) show databasesstarwift 支持 tcp 和 http 两种协议连接server。下面我们分别给出两种方式的示例代码
tcp 连接
依赖 crate
# clickhouse tcp tokio = { version = "1.21.2", features = ["full"] } clickhouse-rs = { git = "https://github.com/suharev7/clickhouse-rs", features = ["default"]}示例代码
use clickhouse_rs::Pool; #[tokio::main] async fn main() { let database_url="tcp://username:password@service-terrabase-9s29mdlsb7.terrabase-9s2mdsb-hhttp 连接
依赖 crate
# clickhouse http clickhouse = {git = "https://github.com/loyd/clickhouse.rs", features = ["test-util"]}示例代码
use clickhouse::Client; use clickhouse::Row; use serde::{Deserialize, Serialize}; #[derive(Debug, Row, Serialize, Deserialize)] struct Database { name: String, } #[tokio::main] async fn main() { let client = Client::default() .with_url("https://service-terrabase-9s29mdlsb7.terrabase-9sdlb7-hb-public.jvessel2.jdcloud.com:8123") }测试过程中,遇到了依赖冲突问题,clickhouse-rs 和 clickhouse.rs 同时依赖了 clickhouse-rs-cityhash-sys 但依赖方式不同,导致编译不通过,下一期详细聊聊踩坑及爬坑过程。再次感谢京东云数据库团队提供的 starwift 测试实例。下期见。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。