How laravel uses Redis to read website cache
Redis is completely open source and free, complies with the BSD protocol, and is a high-performance key-value database. Redis and other key-value caching products have the following three characteristics: Redis supports data persistence, which can keep data in memory on the disk and can be loaded again for use when restarting.
Redis not only supports simple key-value type data, but also provides storage of data structures such as list, set, zset, and hash.
Redis supports data backup, that is, data backup in master-slave mode.
Redis Advantages
Extremely high performance – Redis can read at a speed of 110,000 times/s. The writing speed is 81000 times/s.
Rich data types – Redis supports Strings, Lists, Hashes, Sets and Ordered Sets data type operations for binary cases.
Atomic - All operations of Redis are atomic, and Redis also supports atomic execution of several operations after they are fully merged.
Rich features – Redis also supports publish/subscribe, notifications, key expiration and other features.
How to install redis
1.Ubuntu (because I am using the Homestead environment virtual machine is Ubuntu has only used this method to install. For Windows, please go to http://www.redis.net.cn/tutor or http://www.jb51.net/article/84071.htm... )
Official Ubuntu installation method
$sudo apt-get update $sudo apt-get install redis-server
Since my website uses the laravel framework, I need to use the composer method to install it
composer require predis/predis
If you install the lumen microframework, you also need to install illuminate/redis (5.2.*)
composer require illuminate/redis (5.2.*)
Configuration
If lumen is installed
//需要在bootstrap/app.php里面加入此段代码 $app->register(Illuminate\Redis\RedisServiceProvider::class); $app->configure('database');
Redis can be used as the main database, so the configuration information of Redis in Laravel Located in config/database.php:
'redis' => [ 'cluster' => false, 'default' => [ 'host' => '127.0.0.1', 'port' => 6379, 'database' => 0, ], ],
The cluster option indicates whether to shard between multiple Redis nodes. Here we only have one node for local testing, so we set it is false.
The default option indicates the default Redis host connection. Here Redis and the Web server share a host, so the host is 127.0.0.1 and the Redis default port is 6379.
In addition, the default option also supports more connection parameters (if needed):
Parameters | Meaning | Default value |
---|---|---|
host | Server IP address/host name | 127.0.0.1 |
port | Redis server listening port number | 6379 |
password | If the server requires an authentication password | Do not use a password |
database | The database index selected when connecting | No index is set |
timeout | Timeout for connecting to the Redis server | 5 seconds |
read_write_timeout | Timeout for read and write operations through network connection | System default (set to -1 if the timeout is not limited) |
read_write_timeout |Timeout for read and write operations through network connection|System default (set to -1 if the timeout is not limited)
In addition, if Redis is used as a caching tool, you also need to configure the redis option in config/cache.php:
'redis' => [ 'driver' => 'redis', 'connection' => 'default', ],
The connection here corresponds to the default redis in config/database Host default configuration.
After completing the above configuration, we can use Redis for data access in the application code.
Look at an example——Laravel’s mysql is paired with Redis
My idea is that when reading First go to the cache to search. If you find it, you will be lucky. If you can't find it, go to the database to search and transfer it to the cache.
if (Cache::has($key)){ //首先查寻cache如果找到 $values = Cache::get($>key); //直接读取cache return $values; }else{ //如果cache里面没有 $values = DB::select($sql); Cache::put($key,$value,$time); return $values; }
But laravel's cache also provides a remember function
$values = Cache::remember($key,$time,function () { return DB::select($this->sql); });
If the cache has direct reading and return , if the cache item does not exist in the cache, the closure returned to the remember method will be run, and the result of the closure will be stored in the cache.
Related recommendations:
A PHP website cache code sharing
The above is the detailed content of How laravel uses Redis to read website cache. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

The computer prompts "MsVCP71.dll is missing from the computer", which is usually because the system lacks critical running components, which causes the software to not load normally. This article will deeply analyze the functions of the file and the root cause of the error, and provide three efficient solutions to help you quickly restore the program to run. 1. What is MSVCP71.dll? MSVCP71.dll belongs to the core runtime library file of Microsoft VisualC 2003 and belongs to the dynamic link library (DLL) type. It is mainly used to support programs written in C to call standard functions, STL templates and basic data processing modules. Many applications and classic games developed in the early 2000s rely on this file to run. Once the file is missing or corrupted,

InstallLaravelCashierviaComposerandconfiguremigrationandBillabletrait.2.CreatesubscriptionplansinStripeDashboardandnoteplanIDs.3.CollectpaymentmethodusingStripeCheckoutandstoreitviasetupintent.4.SubscribeusertoaplanusingnewSubscription()anddefaultpay

Maintaining knowledge of Redis’s latest features and best practices is the key to continuous learning and focus on official and community resources. 1. Regularly check Redis official website, document updates and ReleaseNotes, subscribe to the GitHub repository or mailing list, get version update notifications and read the upgrade guide. 2. Participate in technical discussions on Redis's Google Groups mailing list, Reddit sub-section, StackOverflow and other platforms to understand other people's experience and problem solutions. 3. Build a local testing environment or use Docker to deploy different versions for functional testing, integrate the Redis upgrade test process in CI/CD, and master the value of feature through actual operations. 4. Close

Define the schedule: Use Schedule object to configure Artisan command scheduling in the schedule method of the App\Console\Kernel class; 2. Set the frequency: Set the execution frequency through chain methods such as everyMinute, daily, hourly or cron syntax; 3. Pass parameters: Use arrays or strings to pass parameters to the command; 4. Scheduling the shell command: Use exec method to run system commands; 5. Add conditions: Use when, weekdays and other methods to control the execution timing; 6. Output processing: Use sendOutputTo, appendOutputTo or emailOutputTo to record or

Laravel's request life cycle goes through 7 stages from user-initiating a request to response return: 1. The request starts with public/index.php, loads the automatic loader and creates an application instance; 2. The HTTP kernel loads configuration, environment and service providers through boot classes; 3. The request handles security, session and other tasks through global middleware; 4. The router matches the request URI and method, executes the corresponding closure or controller, and applies routing middleware; 5. The controller instantiates through dependency injection, executes logic and returns views, JSON, redirects and other responses; 6. The response is encapsulated as a SymfonyResponse object and outputs through $response->send(); 7. Response sends

SoftdeletesinLaravelallowyoutomarkrecordsasdeletedwithoutremovingthemfromthedatabasebysettingadeleted_attimestamp,whichenablesdatarecoverywhenneeded.1.AddtheSoftDeletestraittoyourmodel:importanduseIlluminate\Database\Eloquent\SoftDeletesinyourmodelcl

Choosetheappropriateroutefilelikeweb.phpforwebinterfacesorapi.phpforAPIs;2.DefinebasicroutesusingRoute::method('uri',callback);3.RoutetocontrollersbycreatingthemviaArtisanandreferencingtheirmethods;4.Userequiredandoptionalparameterswithconstraintsvia

UseMail::fake()orNotification::fake()tomockfacadesandassertsentmessageswithoutrealsideeffects.2.Forcustomserviceclasses,useMockery::mock()with$this->instance()toinjectmockeddependenciesanddefineexpectedbehaviorlikeshouldReceive('method')->andRe
