php 加 redis 入门及简单应用
本篇文章给大家分享的内容是php 加 redis 入门及简单应用 ,有着一定的参考价值,有需要的朋友可以参考一下
一、实验环境: win10 + redis3.2 + php7
二、php-redis / redis /redis图形管理工个等安装,此步骤略过;
三、redis常用的五种数据类型,不做详细说明
参考:http://www.runoob.com/redis/r...
四、php + mysql + redis 简单应用
数据库名称:redis 数据表:redis_user
模拟 php 操作Mysql + redis 的 CURD 操作
1、config.php配置文件
<?php $config = array( 'mysql'=>array( 'host'=>'127.0.0.1', 'user'=>'root', 'pass'=>'root', 'dbname'=>'redis', 'prefix'=>'redis_' ), 'redis'=>array( 'host'=>'127.0.0.1', 'port'=>6379 ) );
index.php 入口文件,操作Mysql时请使用主键ID
<?php reqiure_once('Mysql.php'); //增加数据 // echo Mysql::getInstance()->table('user')->insert(['user'=>'张三','pass'=>md5('123456'),'create_time'=>date('Y-m-d H:i:s')]); //删除数据 // echo Mysql::getInstance()->table('user')->where(array('id'=>30))->delete(); //查看单条数据 // $data = Mysql::getInstance()->table('user')->where(array('id'=>'30'))->find(); // print_r($data); //查找所有数据 // $all = Mysql::getInstance()->table('user')->field('id,user')->select(); $all = Mysql::getInstance()->table('user')->select(); print_r($all); //修改数据 // echo Mysql::getInstance()->table('user')->where(array('id'=>30))->update(['user'=>'张三adfadfasdf11111111','pass'=>md5('123456aaa')]); ?>
Mysql.php 数据库以及redis操作文件
<?php class Mysql { static $instance; private $conn; private $redis; private $options = array(); //单例模式 private function __construct() { error_reporting(E_ALL^E_NOTICE^E_WARNING); require_once(__DIR__.'/Config.php'); $conn = mysqli_connect($config['mysql']['host'],$config['mysql']['user'],$config['mysql']['pass'],$config['mysql']['dbname']); if(mysqli_connect_errno($conn)) { echo "连接Mysql失败:".mysqli_connect_error(); exit; } mysqli_query($conn,'set names utf8'); $this->options['prefix'] = $config['mysql']['prefix']; $this->conn = $conn; $this->redis = new Redis(); $this->redis->connect($config['redis']['host'],$config['redis']['port']); } //获取对象实例 static function getInstance() { if(self::$instance) { return self::$instance; } else { self::$instance = new self(); return self::$instance; } } //设置表名 public function table(string $table) { $this->options['table'] = '`'.$this->options['prefix'].$table.'`'; return $this; } //设置redis键名 public function redis(string $key) { $this->options['key'] = $key; return $this; } //设置条件 public function where(array $where) { $condition = ''; $and = count($where) > 1 ? ' and ' : ''; foreach ($where as $key => $value) { if($key == 'id') {$this->options['user_id'] = $value;} if(strpos($key,':')) { $arr = explode(':', $key); $condition .= '`'.$arr['0'].'` '.$arr['1']. ' "'.$value.'" ' . $and ; } else { $condition .= '`'.$key.'` = ' .'"'.$value.'"' .$and ; } } $this->options['where'] = rtrim($condition,' and '); return $this; } //设置字段 public function field(string $field) { $this->options['field'] = $field; return $this; } //增加数据 public function insert(array $data) { $key = '`'.implode('`,`', array_keys($data)).'`'; $value = '"'.implode('","', $data).'"'; $sql = "insert into {$this->options['table']} (".$key.") values (".$value.");"; if( mysqli_query($this->conn,$sql) ) { $user_id = $this->conn->insert_id; $data['id'] = $user_id; //以hash类型存储 $this->redis->hset($this->options['table'],$user_id,json_encode($data)); return $user_id; } else { return 0; } } //删除数据 public function delete() { $where = $this->options['where'] ? $this->options['where'] : '1'; $sql = "delete from {$this->options['table']} where {$where};"; if(mysqli_query($this->conn,$sql)) { $this->redis->hdel($this->options['table'],$this->options['user_id']); return 1; } else { return 0; } } //修改数据 public function update(array $data) { $condition = ''; $where = $this->options['where'] ? $this->options['where'] : '1'; foreach ($data as $key => $value) { $condition .= ", `".$key."` = '".$value."'"; } $condition = substr($condition, 1); $sql = " update {$this->options['table']} set {$condition} where {$where} ; "; if(mysqli_query($this->conn,$sql)) { $hashData = (array)json_decode($this->redis->hget($this->options['table'],$this->options['user_id'])); foreach ($data as $key => $value) { $hashData[$key] = $value; } $this->redis->hset($this->options['table'],$this->options['user_id'],json_encode($hashData)); return 1; } else { return 0; } } //查找单条数据 public function find() { $field = $this->options['field'] ? $this->options['field'] : '*'; $where = $this->options['where'] ? $this->options['where'] : '1'; if($this->options['user_id']) { echo '从redis获取数据<pre class="brush:php;toolbar:false">'; $data = (array)json_decode($this->redis->hget($this->options['table'],$this->options['user_id'])); if($field != '*') { $field = explode(',', $field); foreach ($field as $value) { $arr[$value] = $data[$value]; $arr['typ'] = 'redis'; } return $arr; } return $data; } else { $sql = " select {$field} from {$this->options['table']} where {$where}; "; if($query = mysqli_query($this->conn,$sql)) { return mysqli_fetch_assoc($query); } else { return array(); } } } //查找所有数据 public function select() { $data = array(); $field = $this->options['field'] ? $this->options['field'] : '*'; $hashData = $this->redis->hgetall($this->options['table']); if($hashData) { if($field != '*') { $field = explode(',', $field); } foreach ($hashData as $key => $value) { $data[$key] = array(); $values = (array)json_decode($value); if($field != '*') { foreach ($field as $k => $v) { $data[$key][$v] = $values[$v]; } }else{ $data[$key] = $values; } } echo '从redis获取数据<pre class="brush:php;toolbar:false">'; } else { $sql = " select {$field} from {$this->options['table']} ; "; if($query = mysqli_query($this->conn,$sql)) { while ($row = mysqli_fetch_assoc($query)) { $data[] = $row; } } } return $data; } public function __destruct() { mysqli_close($this->conn); } }
Atas ialah kandungan terperinci php 加 redis 入门及简单应用 . Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Mod Redis cluster menyebarkan contoh Redis ke pelbagai pelayan melalui sharding, meningkatkan skalabilitas dan ketersediaan. Langkah -langkah pembinaan adalah seperti berikut: Buat contoh Redis ganjil dengan pelabuhan yang berbeza; Buat 3 contoh sentinel, memantau contoh redis dan failover; Konfigurasi fail konfigurasi sentinel, tambahkan pemantauan maklumat contoh dan tetapan failover; Konfigurasi fail konfigurasi contoh Redis, aktifkan mod kluster dan tentukan laluan fail maklumat kluster; Buat fail nodes.conf, yang mengandungi maklumat setiap contoh Redis; Mulakan kluster, laksanakan perintah Buat untuk membuat kluster dan tentukan bilangan replika; Log masuk ke kluster untuk melaksanakan perintah maklumat kluster untuk mengesahkan status kluster; buat

PHP dan Python masing -masing mempunyai kelebihan sendiri, dan pilihannya harus berdasarkan keperluan projek. 1.Php sesuai untuk pembangunan web, dengan sintaks mudah dan kecekapan pelaksanaan yang tinggi. 2. Python sesuai untuk sains data dan pembelajaran mesin, dengan sintaks ringkas dan perpustakaan yang kaya.

Redis menggunakan jadual hash untuk menyimpan data dan menyokong struktur data seperti rentetan, senarai, jadual hash, koleksi dan koleksi yang diperintahkan. Redis berterusan data melalui snapshots (RDB) dan menambah mekanisme tulis sahaja (AOF). Redis menggunakan replikasi master-hamba untuk meningkatkan ketersediaan data. Redis menggunakan gelung acara tunggal untuk mengendalikan sambungan dan arahan untuk memastikan atom dan konsistensi data. Redis menetapkan masa tamat tempoh untuk kunci dan menggunakan mekanisme memadam malas untuk memadamkan kunci tamat tempoh.

Masa depan PHP akan dicapai dengan menyesuaikan diri dengan trend teknologi baru dan memperkenalkan ciri -ciri inovatif: 1) menyesuaikan diri dengan pengkomputeran awan, kontena dan seni bina microservice, menyokong Docker dan Kubernetes; 2) memperkenalkan pengkompil JIT dan jenis penghitungan untuk meningkatkan prestasi dan kecekapan pemprosesan data; 3) Berterusan mengoptimumkan prestasi dan mempromosikan amalan terbaik.

PHP tidak mati, tetapi sentiasa menyesuaikan diri dan berkembang. 1) PHP telah menjalani beberapa lelaran versi sejak tahun 1994 untuk menyesuaikan diri dengan trend teknologi baru. 2) Ia kini digunakan secara meluas dalam e-dagang, sistem pengurusan kandungan dan bidang lain. 3) Php8 memperkenalkan pengkompil JIT dan fungsi lain untuk meningkatkan prestasi dan pemodenan. 4) Gunakan OPCACHE dan ikut piawaian PSR-12 untuk mengoptimumkan prestasi dan kualiti kod.

Langkah-langkah untuk menyelesaikan masalah yang tidak dapat dijumpai oleh Redis-Server: periksa pemasangan untuk memastikan Redis dipasang dengan betul; Tetapkan pembolehubah persekitaran redis_host dan redis_port; Mulakan Redis Server Redis-server; Semak sama ada pelayan sedang menjalankan ping redis-cli.

Untuk melihat semua kunci di Redis, terdapat tiga cara: Gunakan perintah kunci untuk mengembalikan semua kunci yang sepadan dengan corak yang ditentukan; Gunakan perintah imbasan untuk melangkah ke atas kunci dan kembalikan satu set kunci; Gunakan arahan maklumat untuk mendapatkan jumlah kunci.

Alat dan kerangka yang perlu dikuasai dalam pembangunan H5 termasuk Vue.js, React dan Webpack. 1.vue.js sesuai untuk membina antara muka pengguna dan menyokong pembangunan komponen. 2. Leact mengoptimumkan rendering halaman melalui DOM maya, sesuai untuk aplikasi yang kompleks. 3.WebPack digunakan untuk pembungkusan modul dan mengoptimumkan beban sumber.
