Home Backend Development PHP Tutorial About laravel's method of using Redis to implement website cache reading

About laravel's method of using Redis to implement website cache reading

Jun 13, 2018 am 09:46 AM
laravel redis redis cache use

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
Copy after login

Because of my website The laravel framework used needs to be installed using the composer method

composer require predis/predis
Copy after login

If you install the lumen micro-framework, you also need to install illuminate/redis (5.2.*)

composer require illuminate/redis (5.2.*)
Copy after login

Configuration

If lumen is installed

//需要在bootstrap/app.php里面加入此段代码
$app->register(Illuminate\Redis\RedisServiceProvider::class);
$app->configure('database');
Copy after login

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,
],
],
Copy after login

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
hostServer IP address/host name127.0.0.1
portRedis server listening port number6379
password If the server requires an authentication passwordDo not use a password

database

The database index selected when connecting

No index is set

timeout

Timeout for connecting to the Redis server5 seconds
read_write_timeoutTimeout 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',
],
Copy after login

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;
 }
Copy after login

But laravel’s cache also provides a remember function

 $values = Cache::remember($key,$time,function () {
   return DB::select($this->sql);
  });
Copy after login

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!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

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

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to install redis in centos7 How to install redis in centos7 Apr 14, 2025 pm 08:21 PM

Laravel's Primary Function: Backend Development Laravel's Primary Function: Backend Development Apr 15, 2025 am 12:14 AM

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.

How to configure slow query log in centos redis How to configure slow query log in centos redis Apr 14, 2025 pm 04:54 PM

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

How to choose a GitLab database in CentOS How to choose a GitLab database in CentOS Apr 14, 2025 pm 05:39 PM

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: Classifying Its Database Approach Redis: Classifying Its Database Approach Apr 15, 2025 am 12:06 AM

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.

Frequently Asked Questions in CentOS Redis Configuration Frequently Asked Questions in CentOS Redis Configuration Apr 14, 2025 pm 04:36 PM

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

How to build redis How to build redis Apr 15, 2025 am 07:42 AM

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.

How to set the Centos Redis configuration password How to set the Centos Redis configuration password Apr 14, 2025 pm 05:06 PM

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

See all articles