# Redis
[TOC]
SD提供了Redis異步連接池,連接池的使用和正常Redis擴展一樣。
## 創建Redis連接池
在SD的initAsynPools方法中已經創建好了redis和mysql默認的連接池。
```
/**
* 初始化各種連接池
* @param $workerId
*/
public function initAsynPools($workerId)
{
$this->asynPools = [];
if ($this->config->get('redis.enable', true)) {
$this->asynPools['redisPool'] = new RedisAsynPool($this->config, $this->config->get('redis.active'));
}
if ($this->config->get('mysql.enable', true)) {
$this->asynPools['mysqlPool'] = new MysqlAsynPool($this->config, $this->config->get('mysql.active'));
}
$this->redis_pool = $this->asynPools['redisPool'] ?? null;
$this->mysql_pool = $this->asynPools['mysqlPool'] ?? null;
}
```
如果你想創建多個Redis連接池可以仿照上面的方法。
```
$this->addAsynPool('redisPool2', new RedisAsynPool($this->config, ‘redis2’);
```
## 獲取Redis連接池
在Controller,Model,Task共同的基類CoreBase中默認獲取了RedisPool。
```
/**
* 當被loader時會調用這個方法進行初始化
* @param $context
*/
public function initialization(&$context)
{
$this->setContext($context);
$this->redis = $this->loader->redis("redisPool");
$this->db = $this->loader->mysql("mysqlPool",$this);
}
```
## 使用方法
Redis的使用方法和PhpRedis擴展一致,可以參考ServerRedisTest,這是關于Redis的測試用例。
```
$value = $this->redis->set('test', 'testRedis');
```
## Redis-LUA
SD支持Redis-LUA,根目錄下有個名為lua的文件夾,這里的lua腳本都會自動被SD加載進Redis中。
```
public function http_testRedisLua()
{
$value = $this->redis->evalSha(getLuaSha1('sadd_from_count'), ['testlua', 100], 2, [1, 2, 3]);
$this->http_output->end($value);
}
```
通過evalSha和getLuaSha1方法配合我們可以非常容易的使用Redis-LUA功能。其中sadd_from_count是lua文件夾某一個lua腳本的文件名。
在SD啟動時我們也能看到加載了哪些lua腳本,如果redis服務器不支持lua也會有相應的提示。

## 同步Redis
```
$redisSync = $this->redis_pool->getSync();
```
通過getSync返回一個同步的redis連接。
- SD3.X簡介
- 捐贈SD項目
- VIP服務
- 基礎篇
- 搭建環境
- 使用Composer安裝/更新SD框架
- 啟動命令
- 開發注意事項
- 框架配置
- 配置文件夾
- server.php
- ports.php
- business.php
- mysql.php
- redis.php
- timerTask.php
- log.php
- consul.php
- catCache.php
- client.php
- 自定義配置
- 框架入口
- MVC架構
- 加載器-Loader
- 控制器-Controller
- 模型-Model
- 視圖-View
- 同步任務-Task
- 封裝器
- Swoole編程指南-EOF協議
- Swoole編程指南-固定包頭協議
- 封裝器-Pack
- 路由器
- TCP相關
- 綁定UID
- Send系列
- Sub/Pub
- 獲取服務器信息
- Http相關
- HttpInput
- HttpOutput
- 默認路由規則
- WebSocket相關
- 使用SSL
- 公共函數
- 進階篇
- 內核優化
- 封裝器路由器原理剖析
- 對象池
- 上下文-Context
- 中間件
- 進程管理
- 創建自定義進程
- 進程間RPC
- 自定義進程如何使用連接池
- 異步連接池
- Redis
- Mysql
- Mqtt
- HttpClient
- Client
- AMQP
- RPC
- 日志工具-GrayLog
- 微服務-Consul
- Consul基礎
- 搭建Consul服務器
- SD中Consul配置
- 微服務
- 選舉-Leader
- Consul動態配置定時任務
- 熔斷與降級
- 集群-Cluster
- 高速緩存-CatCache
- 萬物-Actor
- Actor原型
- Actor的創建
- Actor間的通訊
- 消息派發-EventDispatcher
- 延遲隊列-TimerCallBack
- 協程
- 訂閱與發布
- MQTT簡易服務器
- AMQP異步任務調度
- 自定義命令-Console
- 調試工具Channel
- 特別注意事項
- 日常問題總結
- 實踐案例
- 物聯網自定義協議
- Actor在游戲的應用
- Mongodb以及一些同步擴展的使用
- 自定義進程使用MQTT客戶端
- 開發者工具
- SDHelper