当前位置: 代码网 > it编程>数据库>Redis > easyswoole3.5 redis使用详细解析

easyswoole3.5 redis使用详细解析

2024年06月17日 Redis 我要评论
安装redis指定版本composer require easyswoole/redis:^1.3redis配置,dev.php<?phpuse easyswoole\log\loggerint

安装redis指定版本

composer require easyswoole/redis:^1.3

redis配置,dev.php

<?php
use easyswoole\log\loggerinterface;
return [
    'server_name' => "easyswoole",
    'main_server' => [
        'listen_address' => '0.0.0.0',
        'port' => 9503,
        'server_type' => easyswoole_web_server, //可选为 easyswoole_server  easyswoole_web_server easyswoole_web_socket_server
        'sock_type' => swoole_tcp,
        'run_model' => swoole_process,
        'setting' => [
            'worker_num' => 8,
            'reload_async' => true,
            'max_wait_time' => 3
        ],
        'task' => [
            'workernum' => 4,
            'maxrunningnum' => 128,
            'timeout' => 15
        ]
    ],
    "log" => [
        'dir' => null,
        'level' => loggerinterface::log_level_debug,
        'handler' => null,
        'logconsole' => true,
        'displayconsole' => true,
        'ignorecategory' => []
    ],
    'temp_dir' => null,
    // 添加 redis 及对应的连接池配置
    /*################ redis config ##################*/
    'redis' => [
        'host' => '127.0.0.1', // redis 地址
        'port' => '6379', // redis 端口
        'auth' => '', // redis 密码
        'timeout' => 3.0, // redis 操作超时时间
        'reconnecttimes' => 3, // redis 自动重连次数
        'db' => 0, // redis 库
    ],
];

easyswooleevent.php,加入预加载

   public static function initialize()
    {
        date_default_timezone_set('asia/shanghai');
        $rdconfig = new redisconfig(config::getinstance()->getconf('redis'));
        redispool::getinstance()->register($rdconfig);
    }

控制器使用

public function getone()
	{
		$param = contextmanager::getinstance()->get('param');
        $redis =  redispool::defer();
        //redis 操作
        $redisdata = $redis->get($this->key.$param['id']);
        if ($redisdata) {
            $this->writejson(status::code_ok, json_decode($redisdata, true), "获取数据成功.");
            return false;
        }
		$model = new studentmodel();
        try {
            $info = $model->where('id', $param['id'])->get();
        } catch (exception|\easyswoole\orm\exception\exception|\throwable $e) {
            $this->writejson(status::code_bad_request, [], $e->getmessage());
            return false;
        }
        if (!$info) {
            $this->writejson(400, [], '该数据不存在');
            return false;
        }
        $redis->set($this->key.$param['id'], json_encode($info, json_unescaped_unicode), $this->time);
		$this->writejson(status::code_ok, $info, "获取数据成功.");
	}

到此这篇关于easyswoole3.5 redis使用的文章就介绍到这了,更多相关easyswoole3.5 redis使用内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com