全網(wǎng)最完整的Redis新手入門指導(dǎo)教程
前言
本文提供全網(wǎng)最完整的Redis入門指導(dǎo)教程,下面我們從下載Redis安裝包開始,一步一步的學(xué)習(xí)使用。
下載Redis
官網(wǎng)提供的Redis安裝包是服務(wù)于Linux的,而我們需要在Window下使用Redis,所以,我們?nèi)ハ旅孢@個(gè)網(wǎng)址中下載。
Redis的下載地址:https://github.com/microsoftarchive/redis/releases。
如下圖所示,Redis的windows版是由microsoftarchive提供,是微軟的一個(gè)工作小組,所以我們可以選擇完全信任,下面我們選擇最新版的Redis版本下載(可以看到,盡管是最新版本,但最后一次提交已經(jīng)是2016年了)
下載完成后解壓到文件夾,得到文件如下:
重要文件講解:
redis-server.exe:Redis服務(wù)端宿主程序,運(yùn)行后會(huì)啟動(dòng)一個(gè)控制臺(tái)窗體,該窗體是宿主程序,如關(guān)閉窗體,則Redis服務(wù)關(guān)閉。
redis-check-dump.exe:本地?cái)?shù)據(jù)庫(kù)檢查程序。
redis-check-aof.exe:更新日志檢查程序。
redis-benchmark.exe:性能測(cè)試,用以模擬同時(shí)由N個(gè)客戶端發(fā)送M個(gè) SETs/GETs 查詢。
redis-cli.exe: Redis客戶端程序,服務(wù)端開啟后,可以通過(guò)該客戶端進(jìn)行命令測(cè)試。(運(yùn)行后,會(huì)啟動(dòng)一個(gè)控制臺(tái)窗體,可在控制臺(tái)內(nèi)輸入命令)
Windows Service Documentation.docx:Redis服務(wù)端使用文檔。
redis.windows-service.conf:Redis啟動(dòng)服務(wù)默認(rèn)加載的配置文件(下文會(huì)介紹如何將Redis服務(wù)已Windows服務(wù)模式啟動(dòng)),雙擊redis-server.exe啟動(dòng)時(shí)并不加載該文件,雙擊exe啟動(dòng)時(shí)會(huì)提示未指定配置文件,使用默認(rèn)配置,這個(gè)默認(rèn)配置應(yīng)該是exe內(nèi)部編寫的。
redis.windows.conf :Redis配置文件,其內(nèi)容和redis.windows-service.conf是一模一樣的,相當(dāng)于一個(gè)備份,如果希望Redis讀取的配置文件是redis.windows.conf ,則需要對(duì)Redis進(jìn)行命令操作,重新設(shè)置配置文件。
了解Redis文件信息后,我們運(yùn)行redis-server.exe,然后我們編寫一個(gè)C#的控制臺(tái)項(xiàng)目訪問(wèn)Redis。
Redis訪問(wèn)
C#想訪問(wèn)Redis需要使用開源類庫(kù),那么應(yīng)該使用哪個(gè)類庫(kù)呢?
打開Redis的中文官網(wǎng)http://www.redis.cn/,在客戶端菜單下可以發(fā)現(xiàn)C#可用的Redis客戶端很多,如下圖:
這里我們使用ServiceStack.Redis來(lái)訪問(wèn)Redis。
創(chuàng)建項(xiàng)目
首先我們創(chuàng)建一個(gè)項(xiàng)目RedisConsole,然后在Nuget下搜索ServiceStack.Redis,如下圖:
然后創(chuàng)建一個(gè)RedisManager類來(lái)管理Redis,代碼如下:
using ServiceStack.Redis; using ServiceStack.Text; using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Runtime.Serialization.Formatters.Binary; using System.Text; using System.Threading.Tasks; namespace RedisConsole { /// <summary> /// RedisManager類主要是創(chuàng)建鏈接池管理對(duì)象的 /// </summary> public class RedisManager { /// <summary> /// 綁定本機(jī)Redis /// </summary> private static string ConnStr = "localhost:6379";//password@ip:port 123@localhost:6379 private static PooledRedisClientManager _prcm; /// <summary> /// 靜態(tài)構(gòu)造方法,初始化鏈接池管理對(duì)象 /// </summary> static RedisManager() { _prcm = CreateManager(new string[] { ConnStr }, new string[] { ConnStr }); } /// <summary> /// 創(chuàng)建鏈接池管理對(duì)象 /// </summary> private static PooledRedisClientManager CreateManager(string[] readWriteHosts, string[] readOnlyHosts) { //WriteServerList:可寫的Redis鏈接地址。 //ReadServerList:可讀的Redis鏈接地址。 //MaxWritePoolSize:最大寫鏈接數(shù)。 //MaxReadPoolSize:最大讀鏈接數(shù)。 //AutoStart:自動(dòng)重啟。 //LocalCacheTime:本地緩存到期時(shí)間,單位:秒。 //RecordeLog:是否記錄日志,該設(shè)置僅用于排查redis運(yùn)行時(shí)出現(xiàn)的問(wèn)題,如redis工作正常,請(qǐng)關(guān)閉該項(xiàng)。 //RedisConfigInfo類是記錄redis連接信息,此信息和配置文件中的RedisConfig相呼應(yīng) // 支持讀寫分離,均衡負(fù)載 return new PooledRedisClientManager(readWriteHosts, readOnlyHosts, new RedisClientManagerConfig { MaxWritePoolSize = 5, // “寫”鏈接池鏈接數(shù) MaxReadPoolSize = 5, // “讀”鏈接池鏈接數(shù) AutoStart = true, }, 0,//初始化數(shù)據(jù)庫(kù) 默認(rèn)有16個(gè)數(shù)據(jù) 這里設(shè)置初始化為第0個(gè) 50,//連接池?cái)?shù)量 5//連接池超時(shí)秒數(shù) ) { ConnectTimeout = 6000,//連接超時(shí)時(shí)間,毫秒 SocketSendTimeout = 6000,//數(shù)據(jù)發(fā)送超時(shí)時(shí)間,毫秒 SocketReceiveTimeout = 6000,// 數(shù)據(jù)接收超時(shí)時(shí)間,毫秒 IdleTimeOutSecs = 60,//連接最大的空閑時(shí)間 默認(rèn)是240 PoolTimeout = 6000 //連接池取鏈接的超時(shí)時(shí)間,毫秒 }; } /// <summary> /// 客戶端緩存操作對(duì)象 /// </summary> public static IRedisClient GetClient() { if (_prcm == null) { _prcm = CreateManager(new string[] { RedisPath }, new string[] { RedisPath }); } return _prcm.GetClient(); } } }
然后在Main函數(shù)里使用RedisManager來(lái)進(jìn)行寫入和讀取,代碼如下:
static void Main(string[] args) { var redisClient = RedisManager.GetClient(); redisClient.Set<string>("Name", "Kiba518"); redisClient.Set<int>("Age", 10000); Console.WriteLine($"MyName:{redisClient.Get<string>("Name")}====MyAge:{redisClient.Get<int>("Age")}"); redisClient.Dispose(); //釋放內(nèi)存 Console.ReadLine(); }
運(yùn)行結(jié)果如下圖所示:
可以看到,我們成功的完成了Redis的插入和讀取。
但我們不滿足于此,我們需要一個(gè)圖形管理界面更直觀的查看Redis數(shù)據(jù)庫(kù)。
下載RedisStudio。
下載地址:https://github.com/cinience/RedisStudio/releases
運(yùn)行RedisStudio,連接本地Redis,如下圖:
連接成功后,點(diǎn)擊Data菜單,查看數(shù)據(jù)。
可以看到,我們添加的數(shù)據(jù)被寫進(jìn)了第0個(gè)數(shù)據(jù)庫(kù)(Redis默認(rèn)會(huì)創(chuàng)建16個(gè)數(shù)據(jù)庫(kù),數(shù)據(jù)庫(kù)編號(hào)以0開頭)。
Redis的Windows服務(wù)
使用Cmd的命令窗口作為Redis的宿主進(jìn)程確實(shí)有一些問(wèn)題,比如關(guān)閉了就不能用了,比如不能開機(jī)自啟。為了讓Redis服務(wù)可以更好的運(yùn)行,我們需要把Redis的宿主改成Windows是服務(wù)。
這件事不需要我們自行開發(fā),redis-server.exe中已經(jīng)提供了這些功能,它的Main函數(shù)會(huì)處理一些他接受的參數(shù)。
現(xiàn)在我們使用命令行啟動(dòng)redis-server.exe。
注:使用Redis命令時(shí),需要在先將目錄跳轉(zhuǎn)到Redis所在文件夾,如【cd/d D:\Redis-x64-3.2.100】
redis-server.exe --service-install redis.windows.conf --loglevel verbose
參數(shù)介紹:
service-install:?jiǎn)?dòng)Redis服務(wù)安裝,必須是第一個(gè)參數(shù)。
redis.windows.conf:指定配置文件。
loglevel verbose:日志級(jí)別。
CMD運(yùn)行結(jié)果如下圖所示:
查看服務(wù)。
如上圖所示,服務(wù)已經(jīng)成功的安裝到系統(tǒng)中了,右鍵就可以啟動(dòng)服務(wù)了。
當(dāng)然我們也可以通過(guò)命令行啟動(dòng)和關(guān)閉服務(wù),命令如下:
啟動(dòng)服務(wù)命令:redis-server.exe --service-start
關(guān)閉服務(wù)命令:redis-server.exe --service-stop
刪除服務(wù)命令:redis-server.exe--service-uninstall
CMD運(yùn)行關(guān)閉服務(wù)結(jié)果如下圖:
注意:redis.windows.conf文件默認(rèn)配置的IP需要修改成本機(jī)的IP,window服務(wù)才能正常啟動(dòng)。
配置密碼
我們都知道數(shù)據(jù)庫(kù)是需要密碼的,這樣才能保證安全性,不然任何一個(gè)知道你服務(wù)器IP的人只要按個(gè)端口試一遍就可以連接你的數(shù)據(jù)庫(kù)了。
Redis的數(shù)據(jù)庫(kù)密碼需要在配置文件中設(shè)置,默認(rèn)是沒(méi)有密碼的。
因?yàn)樯衔奈覀兣渲肳indows服務(wù)時(shí),指定了redis.windows.conf文件為配置文件,所以我們現(xiàn)在需要在redis.windows.conf文件中配置密碼。
打開redis.windows.conf文件,搜索【# requirepass foobared】定位到配置密碼的行(配置文件中#為注釋符),然后在該行下方輸入requirepass 123456,其中123456就是數(shù)據(jù)庫(kù)的密碼了,如下圖所示:
現(xiàn)在我們測(cè)試一下,運(yùn)行我們剛才的項(xiàng)目,結(jié)果如下圖所示:
可以看到,系統(tǒng)提示了驗(yàn)證錯(cuò)誤的異常。
這是因?yàn)槲覀兩衔呐渲玫倪B接字符串是【localhost:6379】這里面只有IP和端口,現(xiàn)在因?yàn)橛辛嗣艽a所以這個(gè)字符串不在合法了。
現(xiàn)在我們將密碼加入進(jìn)字符串,修改代碼如下:
private static string ConnStr = 123456@localhost:6379;
項(xiàng)目成功運(yùn)行,訪問(wèn)Redis數(shù)據(jù)庫(kù)成功,如下圖:
----------------------------------------------------------------------------------------------------
代碼已經(jīng)傳到Github上了,歡迎大家下載。
Github地址:https://github.com/kiba518/RedisConsole
----------------------------------------------------------------------------------------------------
總結(jié)
到此這篇關(guān)于Redis新手入門指導(dǎo)教程的文章就介紹到這了,更多相關(guān)Redis新手入門教程內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
redis底層數(shù)據(jù)結(jié)構(gòu)之skiplist實(shí)現(xiàn)示例
這篇文章主要為大家介紹了redis底層數(shù)據(jù)結(jié)構(gòu)之skiplist實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12Redis中Bloom filter布隆過(guò)濾器的學(xué)習(xí)
布隆過(guò)濾器是一個(gè)非常長(zhǎng)的二進(jìn)制向量和一系列隨機(jī)哈希函數(shù)的組合,可用于檢索一個(gè)元素是否存在,本文就詳細(xì)的介紹一下Bloom filter布隆過(guò)濾器,具有一定的參考價(jià)值,感興趣的可以了解一下2022-12-12redis中使用bloomfilter的白名單功能解決緩存穿透問(wèn)題
本文主要介紹了redis中使用bloomfilter的白名單功能解決緩存穿透問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07redis 億級(jí)數(shù)據(jù)讀取的實(shí)現(xiàn)
本文主要介紹了redis 億級(jí)數(shù)據(jù)讀取的實(shí)現(xiàn),億級(jí)數(shù)據(jù)規(guī)模下實(shí)現(xiàn)高效的數(shù)據(jù)讀取成為了許多企業(yè)和開發(fā)者面臨的重大挑戰(zhàn),下面就來(lái)介紹一下,感興趣的可以了解一下2024-08-08RedisTemplate訪問(wèn)Redis的更好方法
這篇文章主要為大家介紹了RedisTemplate訪問(wèn)Redis的更好方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01在CenOS系統(tǒng)下安裝和配置Redis數(shù)據(jù)庫(kù)的教程
這篇文章主要介紹了在CenOS系統(tǒng)下安裝和配置Redis數(shù)據(jù)庫(kù)的教程,Redis是一個(gè)可基于內(nèi)存的高性能NoSQL數(shù)據(jù)庫(kù),需要的朋友可以參考下2015-11-11