static async Task Main(string[] args) { CodeTrackFactory.Level = CodeTrackLevel.Code; DefaultRedis.Instance.DataFormater = new JsonFormater(); DefaultRedis.Instance.Host.AddWriteHost("127.0.0.1"); var subscribe = DefaultRedis.Subscribe(); subscribe.Register <Employee>("employees", e => { Console.WriteLine($"Receive employee {e.FirstName} {e.LastName}"); }); subscribe.Listen(); System.Threading.Thread.Sleep(1000); using (CodeTrackFactory.TrackReport("Test", CodeTrackLevel.Bussiness, null)) { await Test(); } Console.WriteLine(CodeTrackFactory.Activity?.GetReport()); Console.Read(); }
public override void ConfigureServices(ServiceConfigurationContext context) { DefaultRedis.Initialization(new CSRedisClient(AppSettings.Redis.ConnectionString)); context.Services.AddSingleton(new DGBlogRedisContext()); }
static async Task Test() { await DefaultRedis.Instance.Flushall(); Write(await DefaultRedis.Get <Employee>("nonexisting")); Write(await DefaultRedis.Set("emp3", GetEmployee(3))); Write(await DefaultRedis.Get <Employee>("emp3")); Line(); Write(await DefaultRedis.GetSet <Employee>("emp1", GetEmployee(1))); Write(await DefaultRedis.Set("emp1", GetEmployee(2))); Write(await DefaultRedis.Get <Employee>("emp1")); Write(await DefaultRedis.GetSet <Employee>("emp1", GetEmployee(1))); Write(await DefaultRedis.Get <Employee>("emp1")); Line(); Write(await DefaultRedis.Set("emp1", GetEmployee(1))); Write(await DefaultRedis.Set("emp2", GetEmployee(2))); Write(await DefaultRedis.Get <Employee, Employee>("emp2", "emp1")); Line(); Write(await DefaultRedis.Set("emp1", GetEmployee(1))); Write(await DefaultRedis.Set("order1", GetOrder(1))); Write(await DefaultRedis.Set("customer1", GetCustomer(1))); Write(await DefaultRedis.Get <Employee, Order, Customer>("emp1", "order1", "customer1")); Line(); Write(await DefaultRedis.Set(("emp1", GetEmployee(1)), ("emp2", GetEmployee(2)))); Write(await DefaultRedis.Get <Employee>("emp1")); Write(await DefaultRedis.Get <Employee>("emp2")); Line(); Write(await DefaultRedis.SetNX(("key1", GetEmployee(1)), ("key2", GetEmployee(2)))); Write(await DefaultRedis.SetNX(("key2", GetEmployee(2)), ("key3", GetEmployee(3)))); var items = await DefaultRedis.Get <Employee, Employee, Employee>("key1", "key2", "key3"); Write(items.Item1); Write(items.Item2); Write(items.Item3); Line(); Write(await DefaultRedis.PSetEX("key1", 1000, GetEmployee(1))); Write(await DefaultRedis.PTtl("key1")); Write(await DefaultRedis.Get <Employee>("key1")); Line(); Write(await DefaultRedis.Set("key1", GetEmployee(4))); Write(await DefaultRedis.Get <Employee>("key1")); Line(); Write(await DefaultRedis.SetEX("key1", 10, GetEmployee(1))); Write(await DefaultRedis.Ttl("key1")); Write(await DefaultRedis.Get <Employee>("key1")); Line(); Write(await DefaultRedis.SetNX("key1", GetEmployee(1))); Write(await DefaultRedis.SetNX("key1", GetEmployee(2))); Write(await DefaultRedis.Get <Employee>("key1")); Line(); Write(await DefaultRedis.Set("aa", "sfsdfsd")); Write(await DefaultRedis.Exists("aa")); Write(await DefaultRedis.Exists("sdfsdf", "aa")); Write(await DefaultRedis.Exists("sdfsdf", "sdfsdfdsaa")); Line(); Write(await DefaultRedis.Set("mykey", "hello")); Write(await DefaultRedis.Expire("mykey", 10)); Write(await DefaultRedis.Ttl("mykey")); Write(await DefaultRedis.Set("mykey", "hello world")); Write(await DefaultRedis.Ttl("mykey")); Line(); var list = DefaultRedis.CreateList <Employee>("employees"); Write(await list.Push(GetEmployee(1))); Write(await list.Push(GetEmployee(2))); Write(await list.Index(0)); Write(await list.Index(-1)); Write(await list.Index(3)); Line(); Write(await list.RPush(GetEmployee(1))); Write(await list.RPush(GetEmployee(2))); Write(await list.Insert(true, GetEmployee(2), GetEmployee(3))); Write(await list.Range(0, -1)); Line(); Write(await list.RPush(GetEmployee(1))); Write(await list.RPush(GetEmployee(2))); Write(await list.Len()); Line(); Write(await list.RPush(GetEmployee(1))); Write(await list.RPush(GetEmployee(2))); Write(await list.RPush(GetEmployee(3))); Write(await list.RPush(GetEmployee(4))); Write(await list.Pop()); Write(await list.Range(0, -1)); Write(await list.Len()); Line(); Write(await list.Push(GetEmployee(1))); Write(await list.Push(GetEmployee(2))); Write(await list.Range(0, -1)); Line(); // await Redis.Default.Flushall(); var table = DefaultRedis.CreateHashTable("myhash"); Write(await table.MSet(("emp1", GetEmployee(1)))); Write(await table.Del("emp1")); Write(await table.Del("emp2")); Write(await table.Len()); Line(); Write(await table.MSet(("emp1", GetEmployee(1)))); Write(await table.Get <Employee>("emp1")); Write(await table.Get <Employee>("emp2")); Line(); Write(await table.MSet(("field1", GetEmployee(1)), ("field2", GetEmployee(2)))); Write(await table.Get <Employee, Employee>("field1", "field2")); Write(await table.Keys()); Line(); Write(await DefaultRedis.Publish("employees", GetEmployee(1))); Write(await DefaultRedis.Publish("employees", GetEmployee(1))); Write(await DefaultRedis.Publish("employees", GetEmployee(1))); }