日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

Redis缓存数据库服务器

發布時間:2023/12/15 数据库 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Redis缓存数据库服务器 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Redis緩存數據庫服務器
Redis是一個開源的科技與內存也可持久化的日志型、Key-Value數據庫
Redis的存儲分為內存存儲、磁盤存儲和Log文件三部分,配置文件中有三個參數對其進行配置。

優勢:
和Mecached相比,它更加安全也支持存儲的value類型相對更多。
Redis會周期性的把更新的數據寫入磁盤或者把修改操作寫入追加的記錄
文件,并且在此基礎上實現了master-slave(主從)同步

/var/log/redis_6379.log 日志文件
/var/lib/redis/6379 數據目錄
/usr/local/bin/redis-server Redis服務器軟件存儲路徑

vim /etc/redis/6379.conf 配置文件
.....
maxmemory <bytes> 最大內存
maxmemory-policy volatile-lru 內存滿時,使用LRU算法清理舊數據
daemonize yes 守護進程
pidfile /var/run/redis_6379.pid 進程PID
port 6379 端口號
timeout 300 連接超時時間
loglevel notice 日志級別
logfile /var/log/redis_6379.log 日志文件
databases 16 數據庫個數
save 900 1 數據庫鏡像頻率
dbfilename dump.rdb 鏡像備份文件名
/var/lib/redis/6379 備份文件路徑
slaveof <masterip> <masterport> 設置主服務器IP及端口,主動與主服務器同步數據
masterauth <master-password> 主從認證的密碼
requirepass foobared 客戶端連接服務器后需要先輸入密碼,再做其他操作
maxclients 10000 最大客戶端并發連接數量
maxmemory <bytes> 最大內存使用量

key匹配 >keys * 顯示所有key >keys h?llo ?匹配任意一個字符 >keys h*llo *匹配任意多個字符 >keys h[ae]llo 匹配hello和hallo

flushall
清空所有數據

select id選擇數據庫,id用數字指定,默認數據庫為0>select 0>select 1move key db_id 將當前數據庫的key移動到db_id數據庫中 >move key 1key移動到1數據庫中

rename key newkey
給key改名為newkey,newkey已存在時,則覆蓋其值

sort key 對key進行排序 >lpush cost 1 8 7 2 5 >sort cost 默認對數字排序,升序 >sort cost desc 降序

一、redis基礎管理
1、安裝
tar xzf redis-3.0.6.tar.gz?
cd redis-3.0.6/
make && make install

2、初始化
./utils/install_server.sh?
提示的問題可全部回車,但是要觀察各種文件存放的路徑

3、服務管理
ls /etc/init.d/redis_6379 //查看啟動腳本
service redis_6379 status 查看狀態
service redis_6379 stop
service redis_6379 start
netstat -nautlp |grep redis

4、服務器基礎測試
redis-cli?
ping 測試服務器
PONG
127.0.0.1:6379> set username songtao 設置變量?
127.0.0.1:6379> get username 查看test值
"songtao"
127.0.0.1:6379> set counter 10
OK
127.0.0.1:6379> INCR counter?
(integer) 11
127.0.0.1:6379> GET counter
"11"
127.0.0.1:6379> INCR mycounter 設置計數器mycounter
(integer) 1
127.0.0.1:6379> INCR mycounter 對計數器mycounter進行自增運算
(integer) 2

5、操作字符串
格式:set key value [ex seconds] [px milliseconds] [nx|xx]
設置key及值(value),過期時間可以設置為秒或毫秒為單位。
nx只有key不存在,才對key進行操作
xx只有key已存在,才對key進行操作

setrange key offset value 從偏移量開始復寫key的特定位的值 set first "hello" setrange first 5 "xixi" 改寫為hellxixisrtlen ket 統計字串長度 strlen first append key value 字符存在則追加,不存在則創建keyvalue 返回值為key的長度 >append myname jacobsetbit key iffset valuekey所存儲字串,設置或清除特定偏移量上的位(bitvalue值可以為10,odffset為0~2^32之間 key不存在,則創建新key >setbit abc 0 1 >setbit abc 1 0 abc:第0位為1,第一位為0bitcount key 統計字串中被設置為1的比特位數量 >setbit abcd 0 1 //0001 >setbit abcd 3 1 //1001 >bitcount abcd //結果為2記錄用戶上線頻率,將key設置為用戶名,offset設置為上線日 并在該offset上設置為1。 >setbit abcd 100 1 //網站上線100天用戶登錄1次 >setbit abcd 225 1 //網站上線250天用戶登錄1次 >bitcount abcd //結果為2decr keykey中的值減1key不存在則先初始化為0,再減1 >set test 10 >decr testdecrby key decrementkey中的值,減去decrement >set count 100 >decrby count 20get key 返回key所存儲的字符串值 如果key不存在則返回特殊值nil 如果key的值不是字串,則返回錯誤,get只能處理字串getrange key start end 返回字串值中的子字串,截取范圍為startend 負數偏移量表述從未尾計數,-1表示最后一個字符,-2表示倒數第二個字符 >set first "hello,the world" >getrange first -5 -1 >getrange first 0 4

incr key
將key的值加1,如果key不存在,則初始化為0后再加1
用于計數器:

set page 20
incr page

incrby key increment 將key的值增加incrementincrbyfloat key increment 為key中多存儲的值加上浮點數增量 increment >set num 16.1 >incrbyfloat num 1.1mget key [key...] 一次獲取一個或多個key的值,空格分隔mset key value [key value ...] 一次設置多個key及值,空格分隔

例·
redis-cli
127.0.0.1:6379> set first 'hello world' 設置字符串變量
127.0.0.1:6379> get first
"hello world"
127.0.0.1:6379> SETRANGE first 6 ' hehehe' 將從第6字符修改,改寫為hello hehehe
127.0.0.1:6379> get first?
127.0.0.1:6379> APPEND username "sudan" 向變量中追加
127.0.0.1:6379> SETBIT mytest 0 1
(integer) 0
127.0.0.1:6379> SETBIT mytest 1 0
(integer) 0
127.0.0.1:6379> get mytest
127.0.0.1:6379> SETBIT peter 100 1 設置2進制的第100位為1
(integer) 0
127.0.0.1:6379> SETBIT peter 105 1 設置2進制的第105位為1
(integer) 0
127.0.0.1:6379> BITCOUNT peter 統計peter設置為1的位數有多少
(integer) 2
127.0.0.1:6379> set num1 100 相當于是num1=100
OK
127.0.0.1:6379> get num1
"100"
127.0.0.1:6379> INCR num1 相當于是num1++
(integer) 101
127.0.0.1:6379> DECR num1 相當于是num1--
(integer) 100
127.0.0.1:6379> DECRBY num1 10 # num1=num1-10
127.0.0.1:6379> INCRBY num1 10 # num1=num1+10
127.0.0.1:6379> set hi "hello world"
127.0.0.1:6379> STRLEN hi
127.0.0.1:6379> GETRANGE hi 6 -1
127.0.0.1:6379> GETRANGE hi 6 1
127.0.0.1:6379> set num2 10.5
127.0.0.1:6379> INCRBYFLOAT num2 0.3
"10.8"
127.0.0.1:6379> INCRBYFLOAT num2 -0.8
"10"
127.0.0.1:6379> MGET num1 num2
127.0.0.1:6379> MSET a 10 b "abc"
OK
127.0.0.1:6379> get a
"10,"
127.0.0.1:6379> get b
"abc"

Hash表數據
Redis hash是一個string類型的field和value的映射表
一個key可以對應多個field,一個field對應一個value
將一個對象存儲為hash類型,較于每個字段都存儲成srting類型更能節省內存

hset key field value 將hash表中field值設置為value >hset site google 'www.goog.cn' >hset site baidu 'www.baidu.com'hget key filed 獲取hash表中field的值 >hget site googlehmset key field value [field value..] 同時給hash表中的多個field賦值 >hmset site google www.goog.cn baidu www.baidu.comhmget key field [field...] 返回hash表中多個field的值 >hmget site google baiduhkeys key 返回hash表中所有field名稱 >hmset site google www.goog.cn baidu www.baidu.com >hkeys sitehgetall key 返回hash表中所有field的值hvals key 返回hash表中所有field的值 >hvals keyhdel key field [field...] 刪除hash表中多個field的值,不存在則忽略 >hdel site google baidu

例:
redis-cli
127.0.0.1:6379> hset site google "www.google.com"
(integer) 1
127.0.0.1:6379> hset site baidu "www.baidu.com"
(integer) 1
127.0.0.1:6379> HGET site google
"www.google.com"
127.0.0.1:6379> hget site baidu
"www.baidu.com"
127.0.0.1:6379> hmset site2 tudu "www.tedu.cn" tar "www.tarler.com"
127.0.0.1:6379> hmget site2 tudu tar
127.0.0.1:6379> HKEYS site 查看key中存在的value
127.0.0.1:6379> HKEYS site2
127.0.0.1:6379> HGETALL site 返回field和value
127.0.0.1:6379> HVALS site 返回site中所有的value
127.0.0.1:6379> HDEL site google 從site中刪除google

list列表
Redis的list是一個字符隊列
一個key可以有多個值

lpush key value [value...] 將一個或多個值value插入到列表key的表頭 key不存在,則創建key >lpush list a b c //list1值依次為c b a 同等與lpush list a;lpush list b;lpush list clrange key start stop 從開始位置讀取key的值到stop結束 >lrange xixi 0 2 從0位置開始,讀到2位結束 >lrange xixi 0 -1 從開始讀到結束為止 >lrange xixi 0 -2 從開始讀到倒數第2位為止lpop key 移除并返回列表頭元素數據,key不存在則返回nil >lpop xiix 刪除表頭元素,可以多次執行llen key 返回列表key的長度lindex key index 返回列表中第index個值 >lindex key 0 >lindex key -2lset key index value 將key中index位置的值修改為value >lset abc 3 test 將list中第3個值修改為testrpush key value [value..] 將value插入到key的末尾 >rpush haha a b c //haha值為a b c >rpush haha d //末尾插入d

例:
redis-cli
127.0.0.1:6379> LPUSH mylist chenshun chenglixin yegutian
127.0.0.1:6379> LRANGE mylist 1 -1 查看列表中第1至最后1位的值
127.0.0.1:6379> LPUSH mylist mayang
127.0.0.1:6379> LRANGE mylist 0 -1 查看所有的值
127.0.0.1:6379> help @<tab> #<tab>表示按tab鍵
127.0.0.1:6379> help @list
127.0.0.1:6379> RPUSH mylist wanghong
127.0.0.1:6379> LRANGE mylist 0 -1
127.0.0.1:6379> LSET mylist 2 chenyuan
127.0.0.1:6379> LLEN mylist
127.0.0.1:6379> LPOP mylist
127.0.0.1:6379> RPOP mylist
127.0.0.1:6379> LINDEX mylist 1
127.0.0.1:6379> get username
127.0.0.1:6379> ttl username # 查看生存周期
127.0.0.1:6379> PERSIST username # 設置永不過期
127.0.0.1:6379> EXPIRE username 30 # 生存時間為30秒
127.0.0.1:6379> del mylist # 刪除mylist
127.0.0.1:6379> keys?# 查看所有的key
127.0.0.1:6379> set hello 10
OK
127.0.0.1:6379> set hllo 20
OK
127.0.0.1:6379> set habllo 30
OK
127.0.0.1:6379> set hfllo 40
OK
127.0.0.1:6379> KEYS h?llo # ?匹配任意一個字符
127.0.0.1:6379> KEYS hllo #?匹配0到多個任意思字符
127.0.0.1:6379> KEYS h[a-z]llo # []匹配1個字符
127.0.0.1:6379> set h1llo 5
127.0.0.1:6379> KEYS h[a-z0-9]llo
127.0.0.1:6379> KEYS h[ade0-9]llo
127.0.0.1:6379> KEYS?
127.0.0.1:6379> FLUSHALL 清空所有數據
127.0.0.1:6379> KEYS?
127.0.0.1:6379> set username zhangsan
127.0.0.1:6379> get username
"zhangsan"
127.0.0.1:6379> select 1
127.0.0.1:6379[1]> get username
(nil)
127.0.0.1:6379[1]> select 0
127.0.0.1:6379> get username
"zhangsan"
127.0.0.1:6379> select 0
127.0.0.1:6379> MOVE username 1
(integer) 1
127.0.0.1:6379> get username
(nil)
127.0.0.1:6379> select 1
OK
127.0.0.1:6379[1]> get username
"zhangsan"
127.0.0.1:6379[1]>?
127.0.0.1:6379[1]> keys?
1) "username"
127.0.0.1:6379[1]> RENAME username name # 改名
OK
127.0.0.1:6379[1]> keys *
1) "name"
127.0.0.1:6379[1]> get name
"zhangsan"
127.0.0.1:6379[1]> lpush mylist 10 2 38 69 42
127.0.0.1:6379[1]> SORT mylist # 不會改變mylist
127.0.0.1:6379[1]> LRANGE mylist 0 -1
127.0.0.1:6379[1]> sort mylist desc # 降序
127.0.0.1:6379[1]> lpush names zhangsan lisi bob alice
127.0.0.1:6379[1]> sort names alpha #按字母順序排序

按字母順序排序,從下標為1的單詞開始,取出2項
127.0.0.1:6379[1]> SORT names alpha limit 1 2
127.0.0.1:6379[1]> SORT names alpha limit 1 2 desc

將mylist排序后,另存為mylist2
127.0.0.1:6379[1]> sort mylist store mylist2
127.0.0.1:6379[1]> LRANGE mylist2 0 -1

配置redis主從

1、主服務器使用現有的redis

2、從服務器
yum install -y gcc gcc-c++
tar xzf redis-3.0.6.tar.gz?
cd redis-3.0.6/
make && make install
./utils/install_server.sh

3、主服務器設置同步密碼
vim /etc/redis/6379.conf 配置文件
requirepass redis123 設置服務器密碼

重啟服務:
service redis_6379 restart 或
/etc/init.d/redis_6379 restart

4、設置關閉服務的認證密碼
vim /etc/init.d/redis_6379?
$CLIEXEC -a redis123 -p $REDISPORT shutdown

重啟服務:service redis_6379 restart

5、配置從屬服務器配置文件
vim /etc/redis/6379.conf?
slaveof 192.168.4.1 6379 主服務器ip
masterauth redis123

重啟服務:service redis_6379 restart

6、驗證主從數據是否相同
登錄主:?
redis-cli -h 192.168.4.1 -a redis123
192.168.4.1:6379> set aaa 100

從:
redis-cli?
127.0.0.1:6379> keys *
127.0.0.1:6379> get aaa



? ? ?本文轉自夜流璃雨 51CTO博客,原文鏈接:http://blog.51cto.com/13399294/2062645,如需轉載請自行聯系原作者





總結

以上是生活随笔為你收集整理的Redis缓存数据库服务器的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。