php - 如何解决连接问题上的 redis 错误?

标签 php symfony doctrine-orm redis symfony4

最近我正在将我的应用程序从 Symfony 3.4 升级到 Symfony 4.2。我遇到错误提示 read error on connection

这是堆栈跟踪:

at var/cache/dev/ContainerRUEbk9e/Redis_ca5fc0f.php:312
  at Redis->get('DoctrineNamespaceCacheKey[]')
     (var/cache/dev/ContainerRUEbk9e/Redis_ca5fc0f.php:312)
  at Redis_ca5fc0f->get('DoctrineNamespaceCacheKey[]')
     (vendor/doctrine/cache/lib/Doctrine/Common/Cache/RedisCache.php:47)
  at Doctrine\Common\Cache\RedisCache->doFetch('DoctrineNamespaceCacheKey[]')
     (vendor/doctrine/cache/lib/Doctrine/Common/Cache/CacheProvider.php:200)
  at Doctrine\Common\Cache\CacheProvider->getNamespaceVersion()
     (vendor/doctrine/cache/lib/Doctrine/Common/Cache/CacheProvider.php:177)
  at Doctrine\Common\Cache\CacheProvider->getNamespacedId('9f7b27184e58ac025013b8c22fbdfa8a')
     (vendor/doctrine/cache/lib/Doctrine/Common/Cache/CacheProvider.php:60)
  at Doctrine\Common\Cache\CacheProvider->fetch('9f7b27184e58ac025013b8c22fbdfa8a')
     (vendor/doctrine/orm/lib/Doctrine/ORM/Query.php:271)
  at Doctrine\ORM\Query->_parse()
     (vendor/doctrine/orm/lib/Doctrine/ORM/Query.php:295)
  at Doctrine\ORM\Query->_doExecute()
     (vendor/doctrine/orm/lib/Doctrine/ORM/AbstractQuery.php:967)
  at Doctrine\ORM\AbstractQuery->executeIgnoreQueryCache(null, 1)
     (vendor/doctrine/orm/lib/Doctrine/ORM/AbstractQuery.php:922)
  at Doctrine\ORM\AbstractQuery->execute(null, 1)
     (vendor/doctrine/orm/lib/Doctrine/ORM/AbstractQuery.php:726)
  at Doctrine\ORM\AbstractQuery->getResult()
     (src/Acme/AcmeBundle/Controller/AcmeController.php:1461)
  at Acme\AcmeBundle\Controller\AcmeController->acmeAction(object(Request))
     (vendor/symfony/symfony/src/Symfony/Component/HttpKernel/HttpKernel.php:150)
  at Symfony\Component\HttpKernel\HttpKernel->handleRaw(object(Request), 1)
     (vendor/symfony/symfony/src/Symfony/Component/HttpKernel/HttpKernel.php:67)
  at Symfony\Component\HttpKernel\HttpKernel->handle(object(Request), 1, true)
     (vendor/symfony/symfony/src/Symfony/Component/HttpKernel/Kernel.php:198)
  at Symfony\Component\HttpKernel\Kernel->handle(object(Request))
     (public/app_dev.php:35)
  at runSymfony()
     (public/app_dev.php:39)
  at require('/var/www/html/project/Website/public/app_dev.php')
     (vendor/symfony/symfony/src/Symfony/Bundle/WebServerBundle/Resources/router.php:42)

请检查问题

最佳答案

这可能会有帮助。之前我的配置是这样的:

snc_redis:
    clients:
        default:
            type: predis
            alias: default
            dsn: "%redis_dsn%"
            options:
                read_write_timeout: "%redis_read_write_timeout%"
        session:
            type: phpredis
            alias: session
            dsn: "%redis_dsn%"
            options:
                read_write_timeout: "%redis_read_write_timeout%"
        doctrine:
            type: phpredis
            alias: doctrine
            dsn: "%redis_dsn%"
            options:
                read_write_timeout: "%redis_read_write_timeout%"
    session:
        client: session
        prefix: session:main

    doctrine:
        metadata_cache:
            client: doctrine
            entity_manager: default          # the name of your entity_manager connection
            document_manager: default        # the name of your document_manager connection
            namespace: "%kernel.root_dir%"
        result_cache:
            client: doctrine
            entity_manager: [default, read]  # you may specify multiple entity_managers
        query_cache:
            client: doctrine
            entity_manager: default

改为如下

snc_redis:
    clients:
        default:
            type: predis
            alias: default
            dsn: "%redis_dsn%"
            options:
                read_write_timeout: "%redis_read_write_timeout%"
        session:
            type: predis
            alias: session
            dsn: "%redis_dsn%"
            options:
                read_write_timeout: "%redis_read_write_timeout%"
        doctrine:
            type: predis
            alias: doctrine
            dsn: "%redis_dsn%"
            options:
                read_write_timeout: "%redis_read_write_timeout%"
    session:
        client: session
        prefix: session:main

    doctrine:
        metadata_cache:
            client: doctrine
            entity_manager: default          # the name of your entity_manager connection
            document_manager: default        # the name of your document_manager connection
            namespace: "%kernel.root_dir%"
        result_cache:
            client: doctrine
            entity_manager: [default, read]  # you may specify multiple entity_managers
        query_cache:
            client: doctrine
            entity_manager: default

可能会帮助别人。

关于php - 如何解决连接问题上的 redis 错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54826103/

相关文章:

php - 原则 2 由于 ID 缺失而仍然无法插入

symfony - 是否可以使用原则 2 将 jQuery DataTables 插件集成到 Silex 应用程序中?

php - cURL 加载时间过长

php - 如何在 phpStorm 中为整个 PHP 文件自动导入命名空间?

php - 字符串中十进制数字的正则表达式

php - 添加集合/实体会使表单渲染非常慢

php - 运行特定的datafixture + Symfony2

php - symfony 3 如何禁用 Controller 中的输入

php - 如何清除或清空 doctrine symfony 中的 Array Collection

javascript - 从网站在主机服务器上创建文本文件