Laravel 5.1:类缓存不存在

时间:2015-11-22 05:09:17

标签: php laravel caching nginx redis

亲爱的许多问题的提供者,您好!

我现在正在使用SO一段时间(5年+),尽管大多是被动的。这次我遇到了一个让我整晚都无法解决问题的问题。

以下是它的全部内容。我正在将Laravel 5.1与Redis(缓存和会话)结合使用。可悲的是,当我切换到nginx并升级了一些软件包(作曲家)时,一切都停止了。 Laravel打印出以下异常:

ReflectionException in Container.php line 737:
Class cache does not exist
in Container.php line 737
at ReflectionClass->__construct('cache') in Container.php line 737
at Container->build('cache', array()) in Container.php line 627
at Container->make('cache', array()) in Application.php line 674
at Application->make('cache') in Container.php line 1159
at Container->offsetGet('cache') in SessionManager.php line 156
at SessionManager->createCacheHandler('redis') in SessionManager.php line 128
at SessionManager->createRedisDriver() in Manager.php line 87
at Manager->createDriver('redis') in Manager.php line 63
at Manager->driver() in SessionServiceProvider.php line 48
at SessionServiceProvider->Illuminate\Session\{closure}(object(Application), array()) in Container.php line 734
at Container->build(object(Closure), array()) in Container.php line 627
at Container->make('session.store', array()) in Application.php line 674
at Application->make('Illuminate\Session\Store') in LittleGateKeeperServiceProvider.php line 39
at LittleGateKeeperServiceProvider->register() in Application.php line 531
at Application->register(object(LittleGateKeeperServiceProvider)) in ProviderRepository.php line 74
at ProviderRepository->load(array('Illuminate\Encryption\EncryptionServiceProvider', 'Illuminate\Foundation\Providers\ArtisanServiceProvider', 'Illuminate\Auth\AuthServiceProvider', 'Illuminate\Broadcasting\BroadcastServiceProvider', 'Illuminate\Bus\BusServiceProvider', 'Illuminate\Cache\CacheServiceProvider', 'Illuminate\Foundation\Providers\ConsoleSupportServiceProvider', 'Illuminate\Routing\ControllerServiceProvider', 'Illuminate\Cookie\CookieServiceProvider', 'Illuminate\Database\DatabaseServiceProvider', 'Illuminate\Filesystem\FilesystemServiceProvider', 'Illuminate\Foundation\Providers\FoundationServiceProvider', 'Illuminate\Hashing\HashServiceProvider', 'Illuminate\Mail\MailServiceProvider', 'Illuminate\Pagination\PaginationServiceProvider', 'Illuminate\Pipeline\PipelineServiceProvider', 'Illuminate\Queue\QueueServiceProvider', 'Illuminate\Redis\RedisServiceProvider', 'App\Providers\PasswordResetServiceProvider', 'Illuminate\Session\SessionServiceProvider', 'Illuminate\Translation\TranslationServiceProvider', 'Illuminate\Validation\ValidationServiceProvider', 'Illuminate\View\ViewServiceProvider', 'Lahaxearnaud\LaravelPushbullet\LaravelPushbulletServiceProvider', 'Spatie\Backup\BackupServiceProvider', 'Collective\Remote\RemoteServiceProvider', 'Vinkla\Pusher\PusherServiceProvider', 'Way\Generators\GeneratorsServiceProvider', 'Xethron\MigrationsGenerator\MigrationsGeneratorServiceProvider', 'App\Providers\AppServiceProvider', 'App\Providers\EventServiceProvider', 'App\Providers\RouteServiceProvider', 'Tymon\JWTAuth\Providers\JWTAuthServiceProvider', 'ConnorVG\Transform\TransformServiceProvider', 'Maatwebsite\Excel\ExcelServiceProvider', 'yajra\Datatables\DatatablesServiceProvider', 'Fadion\Bouncy\BouncyServiceProvider', 'Spatie\LittleGateKeeper\LittleGateKeeperServiceProvider')) in Application.php line 507
at Application->registerConfiguredProviders() in RegisterProviders.php line 17
at RegisterProviders->bootstrap(object(Application)) in Application.php line 203
at Application->bootstrapWith(array('Illuminate\Foundation\Bootstrap\DetectEnvironment', 'Illuminate\Foundation\Bootstrap\LoadConfiguration', 'Illuminate\Foundation\Bootstrap\ConfigureLogging', 'Illuminate\Foundation\Bootstrap\HandleExceptions', 'Illuminate\Foundation\Bootstrap\RegisterFacades', 'Illuminate\Foundation\Bootstrap\RegisterProviders', 'Illuminate\Foundation\Bootstrap\BootProviders')) in Kernel.php line 222
at Kernel->bootstrap() in Kernel.php line 117
at Kernel->sendRequestThroughRouter(object(Request)) in Kernel.php line 87
at Kernel->handle(object(Request)) in index.php line 54

值得一提的是:我为nginx安装了predis,open resty。 奇怪的是,如果我使用文件缓存驱动程序,它运行得很好,没有任何例外。如果我通过cli ping redis,我会得到正确的'PONG'响应,我不知道现在要做什么..(除了不使用redis驱动程序; - ))。

也许值得一提的是,如果我通过cli运行artisan命令,它会给我带来不同的错误:

PHP Catchable fatal error:  Argument 2 passed to         Illuminate\Routing\UrlGenerator::__construct() must be an instance of Illuminate\Http\Request, null given, called in /var/www/html/*laravel-project*/vendor/laravel/framework/src/Illuminate/Routing/RoutingServiceProvider.php on line 62 and defined in /var/www/html/*laravel-project*/vendor/laravel/framework/src/Illuminate/Routing/UrlGenerator.php on line 99

Catchable fatal error: Argument 2 passed to Illuminate\Routing\UrlGenerator::__construct() must be an instance of Illuminate\Http\Request, null given, called in /var/www/html/*laravel-project*/vendor/laravel/framework/src/Illuminate/Routing/RoutingServiceProvider.php on line 62 and defined in /var/www/html/*laravel-project*/vendor/laravel/framework/src/Illuminate/Routing/UrlGenerator.php on line 99

因此我认为我的nginx vhost配置可能有问题(这是服务器设置的主要变化)。 vhost看起来像这样:

server {
    listen       80 default_server;
    #listen      [::]:80 default_server ipv6only=on; ## listen for ipv6
    server_name  *MY_SERVER_NAME*;
    root         /sites/*LARAVEL_PROJECT*/public;
    charset utf-8;

    # Elastic search api config
    location /elastic {
        proxy_pass http://localhost:9200;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection 'upgrade';
        proxy_set_header Host $host;
        proxy_cache_bypass $http_upgrade;
    }


    #auth_basic_user_file /etc/nginx/htpasswd.users;
    # Kibana web access
    location /kibana {
        auth_basic "Restricted Access";
        auth_basic_user_file /etc/nginx/htpasswd.users;
        proxy_pass http://localhost:5601;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection 'upgrade';
        proxy_set_header Host $host;
        proxy_cache_bypass $http_upgrade;
    }

    # entry point to the Laravel project
    location / {
        try_files $uri $uri/ /index.php?$query_string;
    }

    access_log /var/log/nginx/laravel-project-access.log;
    error_log  /var/log/nginx/laravel-project-error.log error;

    sendfile off;
    client_max_body_size 100m;

    location ~ \.php$ {
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
        fastcgi_pass unix:/var/run/php-fpm.sock;
        fastcgi_index index.php;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        include fastcgi_params;
        fastcgi_buffer_size 16k;
        fastcgi_buffers 4 16k;
    }

    location ~ /\.ht {
        deny all;
    }
}

有任何想法或建议吗?

提前谢谢!

3 个答案:

答案 0 :(得分:0)

就我而言(laravel 5.2),问题出现在自定义服务提供程序中,我在register()而不是boot()函数中声明了自定义响应宏。

将宏移动到boot()后,错误消失了。

此处找到解决方案: https://laracasts.com/discuss/channels/laravel/class-cache-does-not-exist-error-when-use-redis-session-file-session-is-fine

答案 1 :(得分:0)

可能是您在任何配置文件中使用url()帮助程序,如下面的代码,检查并删除它..

url('bassets/plugins/highcharts/highcharts.css')

答案 2 :(得分:0)

对我来说,它缺少存储文件夹和权限问题。因此,我在创建此文件夹后解决了该问题,然后将其授予apache:apache权限