


About laravel's method of using Redis to implement website cache reading
This article mainly introduces to you the relevant information about laravel using Redis to implement website cache reading. The article introduces it in detail through sample code. It has certain reference learning value for everyone's study or work. Friends who need it Come and learn together.
Introduction to redis
Redis is completely open source and free, abides by 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 the data in the 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, so I have only used this method to install)
Official Ubuntu installation method
$sudo apt-get update $sudo apt-get install redis-server
Because of my website The laravel framework used needs to be installed using the composer method
composer require predis/predis
If you install the lumen micro-framework, 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 is located in config/database.php:
'redis' => [ 'cluster' => false, 'default' => [ 'host' => '127.0.0.1', 'port' => 6379, 'database' => 0, ], ],
The cluster option indicates whether to perform sharding among multiple Redis nodes. Here we only test one node locally, so we set it to 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 cached There is 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.
The above is the entire content of this article. I hope it will be helpful to everyone's study. For more related content, please pay attention to the PHP Chinese website!
Related recommendations:
About the binding operations of Laravel framework routing and controllers
For the life cycle of the Laravel framework And principle analysis
The above is the detailed content of About laravel's method of using Redis to implement website cache reading. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

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

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

Undress AI Tool
Undress images for free

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)

Hot Topics



Laravel's core functions in back-end development include routing system, EloquentORM, migration function, cache system and queue system. 1. The routing system simplifies URL mapping and improves code organization and maintenance. 2.EloquentORM provides object-oriented data operations to improve development efficiency. 3. The migration function manages the database structure through version control to ensure consistency. 4. The cache system reduces database queries and improves response speed. 5. The queue system effectively processes large-scale data, avoid blocking user requests, and improve overall performance.

Enable Redis slow query logs on CentOS system to improve performance diagnostic efficiency. The following steps will guide you through the configuration: Step 1: Locate and edit the Redis configuration file First, find the Redis configuration file, usually located in /etc/redis/redis.conf. Open the configuration file with the following command: sudovi/etc/redis/redis.conf Step 2: Adjust the slow query log parameters in the configuration file, find and modify the following parameters: #slow query threshold (ms)slowlog-log-slower-than10000#Maximum number of entries for slow query log slowlog-max-len

When installing and configuring GitLab on a CentOS system, the choice of database is crucial. GitLab is compatible with multiple databases, but PostgreSQL and MySQL (or MariaDB) are most commonly used. This article analyzes database selection factors and provides detailed installation and configuration steps. Database Selection Guide When choosing a database, you need to consider the following factors: PostgreSQL: GitLab's default database is powerful, has high scalability, supports complex queries and transaction processing, and is suitable for large application scenarios. MySQL/MariaDB: a popular relational database widely used in Web applications, with stable and reliable performance. MongoDB:NoSQL database, specializes in

Redis's database methods include in-memory databases and key-value storage. 1) Redis stores data in memory, and reads and writes fast. 2) It uses key-value pairs to store data, supports complex data structures such as lists, collections, hash tables and ordered collections, suitable for caches and NoSQL databases.

Troubleshooting Redis configuration under CentOS When deploying Redis on CentOS system, you may encounter various problems. This article summarizes some common problems and their solutions to help you complete Redis configuration smoothly. FAQs and Solutions Redis compilation and installation failure problem: When compiling Redis source code, you may encounter situations such as low compiler version, missing dependency libraries, or insufficient system resources. Solution: Upgrade the GCC compiler: Use sudoyumininstallcentos-release-scl and sudoyumininstalldevtoolset-7, and then execute sclenabled

Docker is a technology that implements Redis containerization to ensure the security, portability and scalability of services. Prerequisites: Docker installation and Redis image. Steps: Run the command line docker run to create the Redis container. Connect to the container using the Redis client or command line. Start/stop/restart the container via the command line. View the log or delete the container.

Setting a password for Redis in CentOS system can be achieved by modifying the configuration file or temporarily setting it using the command line. Method 1: Modify the redis.conf configuration file to locate the Redis configuration file: The Redis configuration file is usually located in /etc/redis/redis.conf. Edit the configuration file: Open the configuration file using a text editor (such as vi or nano): sudovi/etc/redis/redis.conf Set password: Find the requiredpass line (add if not), and replace the value after it with the password you selected: requirepassyour_st
