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

犀牛云做的网站怎么样智能建站系统

犀牛云做的网站怎么样,智能建站系统,网站备案号怎么修改,网站图片怎么做文章目录 前言一、首先引入依赖二、创建redis客户端三、相关操作设置值mset设置多个key值设置含有过期时间的值如果key不存在才设置获取基本类型值删除一个键删除多个键判断键是否存在 如何使用json序列化导入相关依赖代码相关实例 总结 前言 使用rust写web,自然是…

文章目录

前言

使用rust写web,自然是离不开redis缓存的。rust也有现成redis连接库,并且支持阻塞和异步两种模式。下面教程我我以tokio异步操作redis方式为主,同步的操作可以参考异步,区别不大

一、首先引入依赖

redis = { version = "0.24.0",features = [ "r2d2" , "tokio-comp" ] }

我这里feature开启了r2d2连接池,以及开启了tokio异步支持特性。
全部特性列表如下
可选功能
定义了一些可以启用其他功能的功能 如果需要的话。其中一些是默认打开的。

  • acl:启用 ACL 支持(默认启用)
  • aio:启用异步 IO 支持(默认启用)
  • geospatial:启用地理空间支持(默认启用)
  • script:启用脚本支持(默认启用)
  • r2d2:启用 R2D2 连接池支持(可选)
  • ahash:启用AHASH地图/设置支持并在内部使用AHASH(+7-10%性能)- (可选)
  • cluster:启用 Redis集群支持(可选)
  • cluster-async:启用异步 Redis 集群支持(可选)
  • tokio-comp:启用对 Tokio的支持(可选)
  • connection-manager:启用对自动重新连接的支持(可选)
  • keep-alive:通过板启用保持活动选项(可选)socket2

二、创建redis客户端

    let client = redis::Client::open("redis://127.0.0.1:6379/").unwrap();//获取连接let con = client.get_async_connection().await.expect("连接redis失败");

此处url的格式为redis://[][:@][:port][/]
db是redis数据库索引。可根据业务自行修改

三、相关操作

设置值

#[tokio::main]
async  fn main() {let client = redis::Client::open("redis://127.0.0.1:6379/10").unwrap();let mut con = client.get_async_connection().await.expect("连接redis失败");con.set::<&str,u32,()>("my_key", 12).await.expect("操作失败");
}

此处<&str,u32,()>前两个泛型指定key,value。第三个泛型是实现了FromRedisValue Trait的返回,set方法可以不指定

mset设置多个key值

#[tokio::main]
async  fn main() {let client = redis::Client::open("redis://127.0.0.1:6379/10").unwrap();let mut con = client.get_async_connection().await.expect("连接redis失败");con.mset::<&str,u32,()>(&[("my_key1", 100), ("my_key2", 200)]).await.expect("操作失败");
}

设置含有过期时间的值

#[tokio::main]
async  fn main() {let client = redis::Client::open("redis://127.0.0.1:6379/10").unwrap();let mut con = client.get_async_connection().await.expect("连接redis失败");//设置60秒过期,第三个参数是过期时间con.pset_ex::<&str,u32,()>("my_key", 12,60*1000).await.expect("操作失败");
}

pset_ex是毫秒单位,set_ex是秒

如果key不存在才设置

#[tokio::main]
async  fn main() {let client = redis::Client::open("redis://127.0.0.1:6379/10").unwrap();let mut con = client.get_async_connection().await.expect("连接redis失败");con.set_nx::<&str,u32,()>("key3",30).await.expect("操作失败");
}

获取基本类型值

#[tokio::main]
async  fn main() {let client = redis::Client::open("redis://127.0.0.1:6379/10").unwrap();let mut con = client.get_async_connection().await.expect("连接redis失败");let value : u32 = con.get("my_key").await.expect("获取值失败");println!("my_key = {}", value);
}

删除一个键

#[tokio::main]
async  fn main() {let client = redis::Client::open("redis://127.0.0.1:6379/10").unwrap();let mut con = client.get_async_connection().await.expect("连接redis失败");con.del::<&str, ()>("key3") .await.expect("删除redis key失败");
}

删除多个键

#[tokio::main]
async  fn main() {let client = redis::Client::open("redis://127.0.0.1:6379/10").unwrap();let mut con = client.get_async_connection().await.expect("连接redis失败");// 多个键删除let keys_to_delete = vec!["my_key1", "my_key2"];let result = con.del::<&Vec<&str>, i32>(&keys_to_delete).await;match result {Ok(count) => println!("Deleted {} keys", count),Err(e) => println!("Error: {}", e),}
}

判断键是否存在

#[tokio::main]
async  fn main() {let client = redis::Client::open("redis://127.0.0.1:6379/10").unwrap();let mut con = client.get_async_connection().await.expect("连接redis失败");// 判断键是否存在let exists : bool = con.exists("my_key").await.expect("执行redis命令失败");println!("exists: {}", exists);
}

更多详细的接口文档可以看官网AsyncCommands接口https://docs.rs/redis/0.24.0/redis/trait.AsyncCommands.html

如何使用json序列化

 可以通过自定义方法添加泛型约束实现功能。使用serde_json库来进行序列化

导入相关依赖

[dependencies]
tokio = { version = "1.35.1", features = ["full"] }
redis = { version = "0.24.0",features = [ "r2d2" , "tokio-comp","json" ] }
serde_json = "1.0.111"
serde = { version = "1.0.195", features = ["derive"] }

代码相关实例

use redis::{aio, AsyncCommands, RedisError, RedisResult, ToRedisArgs};
use serde::{Deserialize, Serialize};
use serde::de::DeserializeOwned;#[derive(Debug, Clone,Deserialize, Serialize)]
struct User{name: String,age: u8,email: String,
}#[tokio::main]
async  fn main() {let client = redis::Client::open("redis://127.0.0.1:6379/10").unwrap();let mut con = client.get_async_connection().await.expect("连接redis失败");// 判断键是否存在let user = User{name: "zhangsan".to_string(),age: 18,email: "11111111".to_string(),};set_json(&mut con,"user1",&user).await.expect("设置失败");let user :User = get_json(&mut con, "user2").await.expect("获取失败,没有找到User");println!("user:{:?}",user);
}//设置json格式对象
pub async fn set_json<K,T>(con: &mut aio::Connection, key: K, obj : &T) -> RedisResult<String>where K: ToRedisArgs + Send + Sync, T: Serialize{let json = serde_json::to_string(obj);match json {Ok(obj) => {con.set::<K,String, String>(key,obj).await},Err(e) => {return Err(RedisError::from(e));}}
}//获得json格式对象
pub async fn get_json<K, T>(con: &mut aio::Connection, key: K) -> RedisResult<T>where K: ToRedisArgs + Send + Sync, T: DeserializeOwned{let json : String = con.get(key).await?;let result = serde_json::from_str(&json);return match result {Ok(obj) => { Ok(obj) },Err(e) => { Err(RedisError::from(e)) }}
}

通过这两个方法泛型约束据即可实现相关功能

总结

以上就是今天要讲的内容,本文介绍了rust语言tokio异步使用redis教程,后续会出一个扩展使用教程

http://www.ds6.com.cn/news/79944.html

相关文章:

  • 城市门户网站上海seo服务外包公司
  • 自己做的网站验证码出不来怎么巨量数据官网
  • thymeleaf做网站 seo百度商城app
  • c 教程如何做网站百度竞价推广效果好吗
  • 网站框架包括哪些互联网广告联盟
  • 灵璧做网站公司企业网络推广最简单方法
  • 毕业做网站运营好吗百度seo优化多少钱
  • 济南企业型网站竞价托管外包公司
  • 高手做网站百度关键词seo公司
  • 网站建设及运营个人心得推广平台排名
  • 收录好的网站怎么联系百度人工服务
  • 设计网站首页1google浏览器官方下载
  • 有没有专门做商铺招商的网站seo系统是什么
  • 为澳门赌场做网站维护杭州优化外包哪里好
  • wordpress远方的雪百度seo关键词优化排名
  • 2014网站备案app怎么开发出来的
  • 免费自助建站软件2345浏览器下载安装
  • 网站建设交流论坛网络seo关键词优化技巧
  • 企业营销型网站团队百度百度地图
  • 借钱软件推广微信hyhyk1seo关键词排名技巧
  • 邯郸网站建设安联网络公司如何进行线上推广
  • 国外引流推广平台郑州官网关键词优化公司
  • 资讯网站的好处互联网平台推广怎么做
  • 男人和男人做爰漫画网站seo百度推广
  • 南宁公司网站建设新闻头条今日要闻军事
  • 怎样做cms电影网站赚钱长沙网站推广排名
  • 做网站 用什么做数据库最好新产品市场推广方案
  • 公司做网站比较好的平台百度网盘搜索引擎官方入口
  • 轻松筹 做的网站价格怎么优化网站关键词排名
  • 做一个公司网站的费用做个公司网站一般需要多少钱