redis基本操作

来源:https://www.cnblogs.com/Selling-fish-bears/archive/2018/07/12/9298570.html
-Advertisement-
Play Games

進入reids ##redis五種數據類型、及操作 string set key value 設置給定 key 的值。如果 key 已經存儲其他值, SET 就覆寫舊值,且無視類型。 set name 'bear' get key 返回key的值,若key不存在則返回nil ​ mset key v ...


進入reids

redis-cli   

#不能進入,就安裝:
sudo apt-get update
sudo apt-get install redis-server

exit        #退出
Select 命令用於切換到指定的資料庫,資料庫索引號 index 用數字值指定,以 0 作為起始索引值。
#預設使用 0 號資料庫   預設開16個庫
SELECT 1     # 使用 1 號資料庫,Redis 現在的命令提示符多了個 [1]

 

##redis五種數據類型、及操作

 

字元串 string
列表 list
哈希 hash
集合 set
有序集合 sorted sets(zset)

 

string

string 類型是 redis 最基本的類型, string 類型,一個 key 對應一個 value,一個 value 最大能存儲512MB的數據。
  • set key value
    • 設置給定 key 的值。如果 key 已經存儲其他值, SET 就覆寫舊值,且無視類型。

    •  set name 'bear' 

  • get key

    • 返回key的值,若key不存在則返回nil

      mset key value [key value..]

    • 為多組key設置值,該操作為原子操作,要麼一組都設置成功,要麼一組都設置失敗;

    • mset username 'root' password '123' name 'bear'

  • mget key [key...]

    • 返回一個或多個key的值,若key不存在返回nil,若key存在但不是字元串返回nil

    • mget username, password, name #有,號會被認為是key的一部分
      mget username password name

       

  • append key value
    • 將指定的值追加到key末尾,若key不存在,則創建並賦值,返回追加後的字元串長度

    •  append name bear 

 

  • ttl key
    • 返回key的剩餘生存時間, -1 表示永久存在, -2表示不存在

 

  • set key value ex seconds
    • 設置 key的同時,設置過期時間(單位:秒) key 過期後將不再可用,會被系統自動刪除。

    • set age 18 ex 20    
      或 setex key seconds value 例: ( setex sex 20 '' )

       

  • persist key

    • 移除指定key的生存時間,成功返回1,若key不存在或不存在生存時間時返回0;


 

###全局key操作

  • rename key newkey 改名
    • 當key和newkey相同或者key不存在時返回一個錯誤,當newkey已存在時則會覆蓋;

    • keys *                  # 查看所有的key
      ​
      del key                 # 刪除    返回成功的個數
      ​
      exists key              # 查看key是否存在  返回存在個個數
      ​
      type key                # 查看key類型
      ​
      expire key seconds      #設置過期時間 
         
      persist key             #移除過期時間
          
      flushdb                 #刪除當前資料庫中的所有key
      ​
      flushall                #刪所有
      
      

 

list

 

列表的元素類型為string,
按照插入順序排序
在列表的頭部或者尾部添加元素
  • lpush key value[value...]

    • 在頭部插入數據

    • lpush  key  value     #例  lpush my_list a b c d
    • 在尾部添加數據

    • rpush  key  value     #例  rpush my_rlist a b c d

 

  • lindex key index

    • 返回列表中元素的值。index從0開始,當index超出索引時返回null

    • lindex my_list 3    #查看第三個

  • lrange key start stop

    • 查看索引範圍內元素的值

    • lrange my_list 0 -1     #查看所有值
  • llen key

    • 返回列表的長度

  • lset key index newvalue

    • 指定索引號進行修改

    •  lset my_list 0 'hello' 

  • 刪除

    • lpop key 刪除左邊第一個

    • rpop my_list

    • rpop key 刪除右邊第一個

    • rpop my_list

    • lrem key count value

      • 刪除指定數量的value值

      • rpush  test_list  c a a b b c  d e a d f m c
        ​
        #count > 0 從左往右 刪除數量為count的value
        例 : lrem test_list 2 a
        lrange test_list 0 -1
        ​
        #count = 0 刪除所有的 value
        例 : lrem test_list 0 d,              
        ​
        #count < 0 從右往左 刪除數量為count的value
        例 : lrem test_list -2 c

hash

 

是一個鍵值(key=>value)對集合。是string 類型的 field 和 value 的映射表,hash 特別適合用於存儲對象
field 域
value 值

設置/修改

  • hset key field value

    • 將field-value設置到hash表中,若key不存在會新建hash表再賦值,已存在則會覆蓋;

    • hset user name bear        #user { name:bear}
  • hmset key field1 value1[field value...]

    • 同時設置多個

    • # user {name:bear , age:18}
      hmset user name bear age 18 

 

查看

  • hget key field

    • 獲取value

    •  hget user name 
  • hmget key field[field...]

    • 獲取多個value

    •  hmget user name age 
  • hvals key

    • 獲取全部value

  • hkeys key

    • 獲取所有的field

  • hgetall key

    • 獲取全部fieldvalue

  • hlen key

    • 查看有幾個鍵值對

  • hexists key field

    • 判斷hash表中指定域是否存在,返回1,若key或field不存在則返回0;

刪除

  • hdel key field

    • hdel user name

 


set​

 

 

元素為string類型
無序集合
元素具有唯一性,不重覆 

 

  • sadd key member [member...] 增加元素

    • 將一個或多個member元素加入到集合key中,若member已存在那麼會忽略此元素,

    •  sadd my_set m n b v c x z b 

  • scard key

    • 返回集合key中元素的個數;

  • smembers key

    • 獲取集合中所有元素

 

  • sismember key member 判斷集合存在某個值

    • 判斷member在key中是否已存在, 返回0或1

    •  sismember my_set b 

 

  • 刪除

    • srem key member [member...]

      • 移除一個或多個元素,不存在的member會被忽略,返回被移除元素個數

      •  srem my_set a b n  
    • spop key 隨機刪除

      • 移除並返回集合中的一個隨機元素,當key不存在時返回NULL

  • 交集

    # sinter key1 key2 ..
    例
    sinter my_set my_set2

    把 key1 key2的交集合併到newkey

    # sinterstore newkey key1 key2
    例
    sinterstore  new_set my_set my_set2
  • 並集

    # sunion key1 key2 ...
    例
    sunion my_set my_set2
     

    把 key1 key2的並集合併到newkey

    # sunionstore newkey key1 key2
    例
    sunionstore new_set2 my_set my_set2

     

  • 差集

    # sdiff key1 key2
    sdiff my_set my_set2

     

    把 key1 key2的差集合併到newkey

    # sdiffstore newkey key1 key2
    例
    sdiffstore new_set3 my_set my_set2

     


 

zset

 

類似於Set,不同的是Sorted中的每個成員都分配了一個分數(Score)用於對其中的成員進行排序(升序)。
zset的成員是唯一的,但分數(score)卻可以重覆。

添加/修改

  • zadd key score member[ [score member] ..]

    • 設置, 存在就更新

    • zadd  my_zset 1 'one'
      zadd  my_zset 2 'tow'
      ​
      zadd  my_zset 10 one 20 two 30 three 40 four 50 'five'

查看

  • zscore key member

    • 查看score值

       zscore my_zset two 

  • zrange key start stop[withscores]

    • 按索引返回key的成員, withscores表示顯示score

    •  zrange my_zset 0 -1 #顯示全部 
  • zrangebyscore key min max

    • 返回集合中 score 在給定區間的元素

    •  zrangebyscore zset 10 30 

刪除

  • zrem key member [member...]

    • 移除有序集合中的一個或多個元素,若member不存在則忽略;

    •  zrem my_zset two  

  • zremrangebyrank min max :

    • 刪除集合中索引在給定區間的元素

    zremrangebyrank my_zset 1 3
  • zremrangebyscore min max :

    • 刪除集合中 score 在給定區間的元素

    zremrangebyscore my_zset 10 30

 

redis配置

 

vim /etc/redis/redis.conf    #配置文件地址

port 6379                     # 預設埠    
logfile /var/log/redis.log      # 日誌文件位置    
dbfilename dump.rdb         # RDB持久化數據文件名 ,  
dir /var/lib/redis            #指定本地資料庫存放目錄
bind 0.0.0.0                # 指定IP進行監聽   

requirepass  yourpassword    #密碼
    
save 900 1                #這三個是持久化,註釋掉就關掉持久化
save 300 10
save 60 10000

啟動/停止/重啟命令

/etc/init.d/redis-server stop
/etc/init.d/redis-server start
/etc/init.d/redis-server restart

設置密碼

config get requirepass        //獲取當前密碼
    #預設情況下 requirepass 參數是空的,這就意味著你無需通過密碼驗證就可以連接到 redis 服務
    
進入配置文件
    vim /etc/redis/redis.conf  
找到requirepass 設置密碼
    vim 查找 /requirepass  按n查找下一個
    requirepass  yourpassword  //此處註意,行前不能有空格
重啟redis
    redis-cli shutdown

進入在添加    auth 123456
登陸的時候加上密碼 redis-cli -a 123456

 

 

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、進入MySQL與退出MySQL 1.進入MySQL步驟:先打開CMD命令行;命令:C:\Users\admin> mysql -h(功能變數名稱,可填或不填) -u(賬號) -p(密碼); 連接成功時會跳出以下命令: Connection id: 9 【這個表示:連接次數】Current databas ...
  • 占座 ...
  • 概念 庫級操作 #集合操作 文檔操作 插入 查詢 更新 刪除 mongodb配置 mongodb許可權 ...
  • 一.概述 在mysql 里不同存儲引擎有不同的鎖,預設情況下,表鎖和行鎖都是自動獲得的,不需要額外的命令, 有的情況下,用戶需要明確地進行鎖表或者進行事務的控制,以便確保整個事務的完整性。這樣就需要使用事務控制和鎖定語句來完成。 特點 myisam innodb memory merge ndb 事 ...
  • Lease(租約): 其實就是一個定時器。首先申請一個TTL=N的lease(定時器),然後創建key的時候傳入該lease,那麼就實現了一個定時的key。 在程式中可以定時為該lease續約,也就是不斷重覆的重置TTL=N。當lease過期的時候,其所關聯的所有key都會自動刪除。 Raft協議: ...
  • 原子性 原子性是資料庫的事務中的特性。在資料庫事務的情景下,原子性指的是:一個事務(transaction)中的所有操作,要麼全部完成,要麼全部不完成,不會結束在中間某個環節。 對於Redis而言,命令的原子性指的是:一個操作的不可以再分,操作要麼執行,要麼不執行。 Redis操作原子性的原因 Re ...
  • 資料庫索引的特點: 避免進行資料庫全表的掃描,大多數情況,只需要掃描較少的索引頁和數據頁,而不是查詢所有數據頁。而且對於非聚集索引,有時不需要訪問數據頁即可得到數據。 聚集索引可以避免數據插入操作,集中於表的最後一個數據頁面。 在某些情況下,索引可以避免排序操作。 資料庫索引與數據結構 上文說過,二 ...
  • 1.查看是否已經安裝了mysql 系統預設裝了一個mysql-libs,我們卸載掉 2.去下載mysql所必須的rpm包 註:紅框里的這個mysql-community-devel 就不裝了,貌似用處暫時用不到 3.進行rpm軟體包安裝 4.初始化資料庫,開啟資料庫 5.設置資料庫密碼 預設的是有密 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...