1. 程式人生 > >redis基本操作命令

redis基本操作命令

1連線操作相關的命令

quit:關閉連線(connection)

auth:簡單密碼認證

2對value操作的命令

exists(key):確認一個key是否存在

del(key):刪除一個key

type(key):返回值的型別

keys(pattern):返回滿足給定pattern的所有key

randomkey:隨機返回key空間的一個key

rename(oldname, newname):將key由oldname重新命名為newname,若newname存在則刪除newname表示的key

dbsize:返回當前資料庫中key的數目

expire:設定一個key的活動時間(s)

ttl:獲得一個key的活動時間

select(index):按索引查詢

move(key, dbindex):將當前資料庫中的key轉移到有dbindex索引的資料庫

flushdb:刪除當前選擇資料庫中的所有key

flushall:刪除所有資料庫中的所有key

3

  對String操作的命令

set(key, value):給資料庫中名稱為key的string賦予值value

get(key):返回資料庫中名稱為key的string的value

getset(key, value):給名稱為key的string賦予上一次的value

mget(key1, key2,…, key N):返回庫中多個string(它們的名稱為key1,key2…)的value

setnx(key, value):如果不存在名稱為key的string,則向庫中新增string,名稱為key,值為value

setex(key, time, value):向庫中新增string(名稱為key,值為value)同時,設定過期時間time

mset(key1, value1, key2, value2,…key N, value N):同時給多個string賦值,名稱為key i的string賦值value i

msetnx(key1, value1, key2, value2,…key N, value N):如果所有名稱為key i的string都不存在,則向庫中新增string,名稱key i賦值為value i

incr(key):名稱為key的string增1操作

incrby(key, integer):名稱為key的string增加integer

decr(key):名稱為key的string減1操作

decrby(key, integer):名稱為key的string減少integer

append(key, value):名稱為key的string的值附加value

substr(key, start, end):返回名稱為key的string的value的子串

4

   對list操作的命令

rpush(key, value):在名稱為key的list尾新增一個值為value的元素

lpush(key, value):在名稱為key的list頭新增一個值為value的 元素

llen(key):返回名稱為key的list的長度

lrange(key, start, end):返回名稱為key的list中start至end之間的元素(下標從0開始,下同)

ltrim(key, start, end):擷取名稱為key的list,保留start至end之間的元素

lindex(key, index):返回名稱為key的list中index位置的元素

lset(key, index, value):給名稱為key的list中index位置的元素賦值為value

lrem(key, count, value):刪除count個名稱為key的list中值為value的元素。count為0,刪除所有值為value的元素,count>0從頭至尾刪除count個值為value的元素,count<0從尾到頭刪除|count|個值為value的元素。 lpop(key):返回並刪除名稱為key的list中的首元素 rpop(key):返回並刪除名稱為key的list中的尾元素 blpop(key1, key2,… key N, timeout):lpop命令的block版本。即當timeout為0時,若遇到名稱為key i的list不存在或該list為空,則命令結束。如果timeout>0,則遇到上述情況時,等待timeout秒,如果問題沒有解決,則對keyi+1開始的list執行pop操作。

brpop(key1, key2,… key N, timeout):rpop的block版本。參考上一命令。

rpoplpush(srckey, dstkey):返回並刪除名稱為srckey的list的尾元素,並將該元素新增到名稱為dstkey的list的頭部

5對set操作的命令

sadd(key, member):向名稱為key的set中新增元素member

srem(key, member) :刪除名稱為key的set中的元素member

spop(key) :隨機返回並刪除名稱為key的set中一個元素

smove(srckey, dstkey, member) :將member元素從名稱為srckey的集合移到名稱為dstkey的集合

scard(key) :返回名稱為key的set的基數

sismember(key, member) :測試member是否是名稱為key的set的元素

sinter(key1, key2,…key N) :求交集

sinterstore(dstkey, key1, key2,…key N) :求交集並將交集儲存到dstkey的集合

sunion(key1, key2,…key N) :求並集

sunionstore(dstkey, key1, key2,…key N) :求並集並將並集儲存到dstkey的集合

sdiff(key1, key2,…key N) :求差集

sdiffstore(dstkey, key1, key2,…key N) :求差集並將差集儲存到dstkey的集合

smembers(key) :返回名稱為key的set的所有元素

srandmember(key) :隨機返回名稱為key的set的一個元素

6對zset(sorted set)操作的命令

zadd(key, score, member):向名稱為key的zset中新增元素member,score用於排序。如果該元素已經存在,則根據score更新該元素的順序。

zrem(key, member) :刪除名稱為key的zset中的元素member

zincrby(key, increment, member) :如果在名稱為key的zset中已經存在元素member,則該元素的score增加increment;否則向集合中新增該元素,其score的值為increment

zrank(key, member) :返回名稱為key的zset(元素已按score從小到大排序)中member元素的rank(即index,從0開始),若沒有member元素,返回“nil”

zrevrank(key, member) :返回名稱為key的zset(元素已按score從大到小排序)中member元素的rank(即index,從0開始),若沒有member元素,返回“nil”

zrange(key, start, end):返回名稱為key的zset(元素已按score從小到大排序)中的index從start到end的所有元素

zrevrange(key, start, end):返回名稱為key的zset(元素已按score從大到小排序)中的index從start到end的所有元素

zrangebyscore(key, min, max):返回名稱為key的zset中score >= min且score <= max的所有元素 zcard(key):返回名稱為key的zset的基數 zscore(key, element):返回名稱為key的zset中元素element的score zremrangebyrank(key, min, max):刪除名稱為key的zset中rank >= min且rank <= max的所有元素 zremrangebyscore(key, min, max) :刪除名稱為key的zset中score >= min且score <= max的所有元素

zunionstore / zinterstore(dstkeyN, key1,…,keyN, WEIGHTS w1,…wN, AGGREGATE SUM|MIN|MAX):對N個zset求並集和交集,並將最後的集合儲存在dstkeyN中。對於集合中每一個元素的score,在進行AGGREGATE運算前,都要乘以對於的WEIGHT引數。如果沒有提供WEIGHT,預設為1。預設的AGGREGATE是SUM,即結果集合中元素的score是所有集合對應元素進行SUM運算的值,而MIN和MAX是指,結果集合中元素的score是所有集合對應元素中最小值和最大值。

7對Hash操作的命令

hset(key, field, value):向名稱為key的hash中新增元素field<—>value

hget(key, field):返回名稱為key的hash中field對應的value

hmget(key, field1, …,field N):返回名稱為key的hash中field i對應的value

hmset(key, field1, value1,…,field N, value N):向名稱為key的hash中新增元素field i<—>value i

hincrby(key, field, integer):將名稱為key的hash中field的value增加integer

hexists(key, field):名稱為key的hash中是否存在鍵為field的域

hdel(key, field):刪除名稱為key的hash中鍵為field的域

hlen(key):返回名稱為key的hash中元素個數

hkeys(key):返回名稱為key的hash中所有鍵

hvals(key):返回名稱為key的hash中所有鍵對應的value

hgetall(key):返回名稱為key的hash中所有的鍵(field)及其對應的value

8持久化

save:將資料同步儲存到磁碟

bgsave:將資料非同步儲存到磁碟

lastsave:返回上次成功將資料儲存到磁碟的Unix時戳

shundown:將資料同步儲存到磁碟,然後關閉服務

9遠端服務控制

info:提供伺服器的資訊和統計

monitor:實時轉儲收到的請求

slaveof:改變複製策略設定

config:在執行時配置Redis伺服器

Redis高階應用
1、安全性
設定客戶端連線後進行任何操作指定前需要密碼,一個外部使用者可以再一秒鐘進行150W次訪問,具體操作密碼修改設定redis.conf裡面的requirepass屬性給予密碼,當然我這裡給的是primos
之後如果想操作可以採用登陸的時候就授權使用:
sudo /opt/java/redis/bin/redis-cli -a primos
或者是進入以後auth primos然後就可以隨意操作了

2、主從複製
做這個操作的時候我準備了兩個虛擬機器,ip分別是192.168.15.128和192.168.15.133
通過主從複製可以允許多個slave server擁有和master server相同的資料庫副本
具體配置是在slave上面配置slave
slaveof 192.168.15.128 6379
masterauth primos
如果沒有主從同步那麼就檢查一下是不是防火牆的問題,我用的是ufw,設定一下sudo ufw allow 6379就可以了
這個時候可以通過info檢視具體的情況

3、事務處理
redis對事務的支援還比較簡單,redis只能保證一個client發起的事務中的命令可以連續執行,而中間不會插入其他client的命令。當一個client在一個連線中發出multi命令時,這個連線會進入一個事務的上下文,連線後續命令不會立即執行,而是先放到一個佇列中,當執行exec命令時,redis會順序的執行佇列中的所有命令。
比如我下面的一個例子
set age 100
multi
set age 10
set age 20
exec
get age –這個內容就應該是20
multi
set age 20
set age 10
exec
get age –這個時候的內容就成了10,充分體現了一下按照佇列順序執行的方式
discard 取消所有事務,也就是事務回滾
不過在redis事務執行有個別錯誤的時候,事務不會回滾,會把不錯誤的內容執行,錯誤的內容直接放棄,目前最新的是2.6.7也有這個問題的
樂觀鎖
watch key如果沒watch的key有改動那麼outdate的事務是不能執行的

4、持久化機制
redis是一個支援持久化的記憶體資料庫
snapshotting快照方式,預設的儲存方式,預設寫入dump.rdb的二進位制檔案中,可以配置redis在n秒內如果超過m個key被修改過就自動做快照
append-only file aof方式,使用aof時候redis會將每一次的函 數都追加到檔案中,當redis重啟時會重新執行檔案中的儲存的寫命
令在記憶體中。
5、釋出訂閱訊息 sbusribe publish操作,其實就類似linux下面的訊息釋出
6、虛擬記憶體的使用
可以配置vm功能,儲存路徑,最大記憶體上線,頁面多少,頁面大小,最大工作執行緒
臨時修改ip地址ifconfig eth0 192.168.15.129

redis-cli命令抄襲點選開啟連結

redis-cli引數
Usage: redis-cli [OPTIONS] [cmd [arg [arg …]]]
-h Server hostname (default: 127.0.0.1)
-p Server port (default: 6379)
-s Server socket (overrides hostname and port)
-a Password to use when connecting to the server
-r 選項重複執行一個命令指定的次數。
-i 設定命令執行的間隔。
It is possible to specify sub-second times like -i 0.1
-n Database number
-x 選項從標準輸入(stdin)讀取最後一個引數
-d Multi-bulk delimiter in for raw formatting (default: \n)
-c 開啟reidis cluster模式,連線redis cluster節點時候使用
–raw Use raw formatting for replies (default when STDOUT is not a tty)
–latency Enter a special mode continuously sampling latency
–slave 模擬slave從master上接收到的commands。slave上接收到的commands都是update操作,記錄資料的更新行為。
–pipe 這個一個非常有用的引數。傳送原始的redis protocl格式資料到伺服器端執行。
–bigkeys Sample Redis keys looking for big keys
–eval Send an EVAL command using the Lua script at
–help Output this help and exit
–version Output version and exit

Examples:
cat /etc/passwd | redis-cli -x set mypasswd
redis-cli get mypasswd
redis-cli -r 100 lpush mylist x
redis-cli -r 100 -i 1 info | grep used_memory_human:
redis-cli –eval myscript.lua key1 key2 , arg1 arg2 arg3
(Note: when using –eval the comma separates KEYS[] from ARGV[] items)

常用命令:
1) 檢視keys個數
keys * // 檢視所有keys
keys prefix_* // 檢視字首為”prefix_”的所有keys

2) 清空資料庫
flushdb // 清除當前資料庫的所有keys
flushall // 清除所有資料庫的所有key

相關推薦

redis基本操作命令

1連線操作相關的命令quit:關閉連線(connection)auth:簡單密碼認證2對value操作的命令exists(key):確認一個key是否存在del(key):刪除一個keytype(key):返回值的型別keys(pattern):返回滿足給定pattern的所

redis基本操作命令整理ING

伺服器相關命令 命令 介紹 select database 選擇資料庫(Redis 資料庫編號從 0~15) quit 退出 echo msg 列印

redis基礎命令之key基本操作命令

redis是key-value儲存的,放在記憶體中,並在磁碟持久化的資料結構儲存系統,它可以用作資料庫、快取和訊息中介軟體。通過set key value來儲存,通過get key來獲取值一.建立key----set/setnx/mset/msetnx1.建立單個keyset

redis 30個基本操作命令

set:新增,如果說已經存在鍵名,替換 setnx:新增,如果說鍵名已經存在,新增失敗 鍵名具有唯一性 1,connect 描述:例項連線到一個Redis. 引數:host: string,port: int 返回值:BOOL 成功返回:TRUE;失敗返回

window下redis基本操作命令

開啟服務端命令 :redis-server.exe redis.windows.conf開啟客戶端命令:redis-cli.exe -h 127.0.0.1(目標IP) -p 6379(預設)一、查詢相應的key(1)redis允許模糊查詢key  有3個萬用字元  *、?、

Redis系列(十二):資料結構SortedSet跳躍表中基本操作命令和原始碼解析

1.SkipList Redis的sortedSet資料結構是有序不重複的(索引為唯一的,資料(score)卻可以重複), 跳錶是redis的一個核心元件,也同時被廣泛地運用到了各種快取地實現當中,它的主要優點, 就是可以跟紅黑樹、AVL等平衡樹一樣,做到比較穩定地插入、查詢與刪除。理論插入查詢刪除的演算法時

Linux基本操作命令

程序 詳細 位置 tool -1 擁有 Owner ss命令 單位 一、 ls ls最常用的參數有三個: -a -l -F 1、ls -a Linux上的文件以.開頭的文件被系統視為隱藏文件,僅用ls命令是看不到他們的,而用ls -a除了顯示 一般文件名外,連隱藏文

HADOOP基本操作命令

itl mapred lang reduce 磁盤 family home file cas Hadoop基本操作命令 在這篇文章中,我們默認認為Hadoop環境已經由運維人員配置好直接可以使用。假設Hadoop的安裝目錄HADOOP_HOME為/home/admin/ha

Linux的基本操作命令

linux cat inux 輸入 指定 修改 回車 txt文件 登錄密碼 mount 查看掛載目錄 cat ~ 查看文件下的內容 touch ~ 創建一個文件 echo 1234>>123.txt 創建一個內容為1234的123txt文件

2017-7-18-每日博客-關於Linux基本命令CnetOS7系統基本操作命令.doc

空間使用 正在 run 個數 linux oot disable 輸出 column 1.root/下 cat anaconda-ks.cfg 確定是否裝base軟件組 yum groupinstall base 安裝base組ifconfig 命令就可以使用了或者

DOS當中的基本操作命令,如何切換磁盤,如何查看文件和文件夾,如何清屏,進入文件夾的命令,javac是什麽意思,作用是什麽?DOS如何建文件夾?退出文件夾?

ava mpi dos compile 通配符 pil jdk 使用 onf 如何切換磁盤:使用盤符+:舉例 d: 如何查看文件和文件夾 dir/w 如何清屏: cls (clear screen) 進入文件夾的命令cd ,舉例cd JDK javac是什麽意思,c 是co

springboot集成redisredis基本操作

import put set hash getclass tid redist generate pre 1 pom.xml添加依賴    <dependency> <groupId>org.springframework.boot</gr

MYSQL數據庫基本操作命令

數據庫的備份與恢復 mysql 文件中 line ria 禁止 對數 ... 登錄 MySQL數據庫系統是一個典型的C/S(客戶端/服務器)架構的應用,要訪問MySQL數據庫需要使用專門的客戶端軟件。在Linux系統中,最簡單、易用的MySQL客戶端軟件是其自帶的mysql

linux基本操作命令的使用

lin usr 查看 特殊符號 nbsp files 進一步 image mem 為了盡快完成對公司的linux服務器的部署,安裝,操作,需要進一步學習Linux系統中基本的文件和目錄管理命令,同時要熟悉獲取命令幫助的常用方法以便及時了解與服務器管理、維護相關的其他命令的用

【華為網絡設備】基本操作命令

華為路由器 配置命令 d 1、基本查看命令disp int g0/0/0 #查看G0/0/0網口信息disp ip routing-table #查看路由表disp cu #查看當前配置disp saved-configuration #查看已保存配置dir flash #查看flash上的文件目

Vim基本操作命令

vim編輯器 常用命令 命令模式 末行模式 編輯模式 Vim是linux系統中最常見的文本編輯器,幾乎任意一款linux發行版默認都會安裝的軟件。對,它是一款自由軟件。學習Vim編輯器的基本操作命令後是有好處的,它可以讓你的工作事半功倍,同時令你更加的帥。 Vim編輯器中設置了三種模式--

Django基本操作命令

setting 工程 windows 基本操作 res rate 輸入 project 詳細 windows: 新建好Django 工程後,進入工程內,然後 shift + 單擊右鍵,選擇 “在此位置打開命令窗口”,運行如下指令 1、新建一個django項目 django-

關於Mysql(MariaDB)的基本操作命令指南

MariaDB MysqlMYSQL基本命令操作 1.登錄方法: mysql -u root -p 2.顯示所有數據庫: show databases; 3.操作指定數據庫(以information_schema為例) use information_schema 4.顯示所有的表 show tables;

SELinux——概述及基本操作命令

SELinux SandboxSELinux 基本概述:SELinux(Security-Enhanced Linux) 是美國國家安全局(NSA)對於強制訪問控制的實現,是 Linux歷史上最傑出的新安全子系統。NSA是在Linux社區的幫助下開發了一種訪問控制體系,在這種訪問控制體系的限制下,進程只能訪問

redis基本操作

itl res all 有序 red ret emc div redis ‘‘‘ pip install redis redis 可以看成內存中的大字典 redis五大數據類型 --> 指的是第一層的value值的類型 - 字符串