| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474 |
- using StackExchange.Redis;
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Threading.Tasks;
- namespace CommonObj.common
- {
- public class redisConnection
- {
- public int DB_INDEX_PARAM_CAMPAIGN { get; }
- public int DB_INDEX_TOKEN { get; }
- public int DB_INDEX_BLACKLIST { get; }
- public int DB_INDEX_DATA_USER { get; }
- public int DB_INDEX_DATA_TICKET_UNIQUE_BUY { get; }
- public int DB_INDEX_DATA_TICKET_UNIQUE_FREE { get; }
- public int DB_INDEX_DATA_TICKET_SEARCH { get; }
- public int TOKEN_TIMEOUT_DEFAULT { get; }
- public string ip { get; set; }
- public string port { get; set; }
- public string pass { get; set; }
- public ConnectionMultiplexer redis { get; set; }
- public IDatabase database { get; set; }
- public string REDIS_SYN_TICKET_STATUS { get; }
- public string REDIS_IS_RUNNING { get; }
- public string REDIS_IS_CHECK_TICKET_DB { get; }
- public redisConnection(string _ip,string _port,string _pass)
- {
- DB_INDEX_PARAM_CAMPAIGN = 0;
- DB_INDEX_TOKEN = 1;
- DB_INDEX_BLACKLIST = 2;
- DB_INDEX_DATA_USER = 3; //Khi mua ve se khoa tam thoi x phut. Se bi xoa neu ko confirm sau x phut
- DB_INDEX_DATA_TICKET_UNIQUE_BUY = 4; //Luu lai cac ve so da duoc mua roi,
- DB_INDEX_DATA_TICKET_UNIQUE_FREE= 5; //Luu lai cac ve free, chua ai mua
- DB_INDEX_DATA_TICKET_SEARCH = 6;//Luu ket qua seach, co phan trang
- TOKEN_TIMEOUT_DEFAULT = 600000000;
- REDIS_SYN_TICKET_STATUS = "REDIS_SYN_TICKET_STATUS"; //0= la ko dang syn (chop phep mua ve),1=Yeu cau syn ticket,2=dang syn
- REDIS_IS_RUNNING = "REDIS_IS_RUNNING"; //1= dang chay binh thuong,0= khong chay binh thuong
- REDIS_IS_CHECK_TICKET_DB = "REDIS_IS_CHECK_TICKET_DB"; //0= khong check DB(chi check redis),1= ngoai check redis con check ca DB
- this.ip = _ip;
- this.port = _port;
- this.pass = _pass;
- //ConnectionMultiplexer redis = ConnectionMultiplexer.Connect("192.168.1.5:6379,password=mypassword");
-
- }
- public bool connet()
- {
- bool _reuslt = true;
- try
- {
- redis = ConnectionMultiplexer.Connect(this.ip + ":" + this.port + ",password=" + this.pass+ ",allowAdmin=true");
-
- }
- catch (Exception)
- {
- _reuslt = false;
- }
- return _reuslt;
- }
- public void close()
- {
-
- try
- {
- redis.Close();
- }
- catch (Exception)
- {
-
- }
-
- }
- public bool isConnet()
- {
-
- try
- {
- if (redis == null)
- return false;
- if (redis.IsConnected)
- return true;
- else
- return false;
- }
- catch (Exception)
- {
- return false;
- }
-
- }
- public bool Ping(int dbIndex)
- {
-
- try
- {
- database = redis.GetDatabase(dbIndex);
- if (database.Ping().TotalSeconds > 5)
- {
- return false;
- }
- else
- {
- return true;
- }
- }
- catch (Exception)
- {
- return false;
- }
-
- }
- public bool existsByKey(int dbIndex, string key)
- {
- try
- {
- database = redis.GetDatabase(dbIndex);
- return database.KeyExists(key);
- }
- catch (Exception)
- {
- return false;
- }
- }
- public string getByKey(int dbIndex,string key)
- {
- try
- {
- database = redis.GetDatabase(dbIndex);
-
- return database.StringGet(key);
-
- }
- catch (Exception)
- {
- return null;
- }
- }
-
- public void setByKey(int dbIndex, string key,string values)
- {
- try
- {
- database = redis.GetDatabase(dbIndex);
-
- database.StringSet(key,values);
- }
- catch (Exception)
- {
-
- }
- }
- public void setByKeyAsync(int dbIndex, string key, string values)
- {
- try
- {
- database = redis.GetDatabase(dbIndex);
- database.StringSetAsync(key, values);
- }
- catch (Exception)
- {
- }
- }
- public void setByKey(int dbIndex, string key, string values,TimeSpan t)
- {
- try
- {
- database = redis.GetDatabase(dbIndex);
- database.StringSet(key, values,t);
-
- }
- catch (Exception)
- {
- }
- }
- public void setKeyTimeOut(int dbIndex, string key, TimeSpan t)
- {
- try
- {
- database = redis.GetDatabase(dbIndex);
- database.KeyExpire(key, t);
- }
- catch (Exception)
- {
- }
- }
- public void setTimeOutAllkeyByPattern(int dbIndex, string _pattern, TimeSpan t)
- {
- try
- {
- IServer server = redis.GetServer(this.ip + ":" + this.port);
- database = redis.GetDatabase(dbIndex);
- var keys = server.Keys(dbIndex, pattern: _pattern + "*");
- foreach (var k in keys)
- {
- database.KeyExpire(k, t);
- }
- }
- catch (Exception ex)
- {
- }
- }
- public void delByKey(int dbIndex, string key)
- {
- try
- {
- database = redis.GetDatabase(dbIndex);
-
- database.KeyDelete(key);
- }
- catch (Exception)
- {
- }
- }
- public void delByKeyAsync(int dbIndex, string key)
- {
- try
- {
- database = redis.GetDatabase(dbIndex);
- database.KeyDeleteAsync(key);
- }
- catch (Exception)
- {
- }
- }
- public void delAllkeyByPattern(int dbIndex, string _pattern)
- {
-
- try
- {
- IServer server = redis.GetServer(this.ip + ":" + this.port);
- database = redis.GetDatabase(dbIndex);
- var keys = server.Keys(dbIndex, pattern: _pattern + "*");
- foreach (var k in keys)
- {
- database.KeyDelete(k);
- }
-
- }
- catch (Exception ex)
- {
- }
- }
- /*
- public void getAllkey(int dbIndex, string key)
- {
- try
- {
- database = redis.GetDatabase(dbIndex);
- database.StringSet();
- }
- catch (Exception)
- {
- }
- }
- */
- public List<string> getAllkeyByPattern(int dbIndex,string _pattern)
- {
- List<string> _result = new List<string>() ;
- try
- {
- IServer server = redis.GetServer(this.ip + ":" + this.port);
- var keys = server.Keys(dbIndex,pattern: _pattern+"*");
-
-
- foreach (var k in keys)
- {
- _result.Add(k);
- }
- return _result;
- }
- catch (Exception ex)
- {
- return null;
- }
- }
- public List<string> getAllkeyByPatternRegex(int dbIndex, string _pattern)
- {
- List<string> _result = new List<string>();
- try
- {
- IServer server = redis.GetServer(this.ip + ":" + this.port);
- var keys = server.Keys(dbIndex, pattern: _pattern);
-
- foreach (var k in keys)
- {
- _result.Add(k);
- }
- return _result;
- }
- catch (Exception ex)
- {
- return null;
- }
- }
- public long getSizeDatabase(int dbIndex)
- {
- long result= 0;
- try
- {
- IServer server = redis.GetServer(this.ip + ":" + this.port);
- result=server.DatabaseSize(dbIndex);
-
- }
- catch (Exception ex)
- {
- int a = 0;
- }
- return result;
- }
- public void clearAllDatabase()
- {
- try
- {
- IServer server = redis.GetServer(this.ip + ":" + this.port);
- server.FlushAllDatabases();
- }
- catch (Exception ex)
- {
- int a = 0;
- }
- }
- public void clearIdxDatabase(int dbIndex)
- {
- try
- {
- IServer server = redis.GetServer(this.ip + ":" + this.port);
- server.FlushDatabase(dbIndex);
-
- }
- catch (Exception ex)
- {
- int a = 0;
- }
- }
- }
- }
|