国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 數(shù)據(jù)庫(kù) > MySQL > 正文

redis服務(wù)器環(huán)境下mysql實(shí)現(xiàn)lnmp架構(gòu)緩存

2024-07-25 19:08:40
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

配置環(huán)境:redhat6.5

server1:redis(172.25.254.1)

server2:php(172.25.254.2)

server3:mysql(172.25.254.3)

配置步驟:

server2:

1、server2安裝php的redis相應(yīng)模塊

redis,服務(wù)器環(huán)境,mysql,lnmp,架構(gòu)緩存

2、nginx安裝

[root@server2 php-fpm.d]# rpm -ivh nginx-1.8.0-1.el6.ngx.x86_64.rpm warning: nginx-1.8.0-1.el6.ngx.x86_64.rpm: Header V4 RSA/SHA1 Signature, key ID 7bd9bf62: NOKEYPreparing...        ########################################### [100%]  1:nginx         ########################################### [100%]---------------------------------------------------------------------- Thanks for using nginx! Please find the official documentation for nginx here:* https://nginx.org/en/docs/Commercial subscriptions for nginx are available on:* https://nginx.com/products/ ----------------------------------------------------------------------[root@server2 php-fpm.d]# id nginxuid=498(nginx) gid=499(nginx) groups=499(nginx)

3、nginx和php配置

1、php配置

[root@server2 php-fpm.d]# cd /etc/php-fpm.d/[root@server2 php-fpm.d]# id nginxuid=498(nginx) gid=499(nginx) groups=499(nginx)[root@server2 php-fpm.d]# vim www.conf  39 user = nginx 41 group = nginx [root@server2 php-fpm.d]# vim /etc/php.ini 946 date.timezone = Asia/Shanghai[root@server2 php-fpm.d]# /etc/init.d/php-fpm startStarting php-fpm:                     [ OK ][root@server2 php-fpm.d]# netstat -antlp | grep phptcp    0   0 127.0.0.1:9000       0.0.0.0:*          LISTEN   1125/php-fpm    [root@server2 php-fpm.d]# vim /etc/php.ini

2、nginx配置

[root@server2 ~]# cd /etc/nginx/conf.d/[root@server2 conf.d]# lsdefault.conf example_ssl.conf[root@server2 conf.d]# vim default.conf  10     index index.php index.html index.htm; 30   location ~ /.php$ { 31     root      html; 32     fastcgi_pass  127.0.0.1:9000; 33     fastcgi_index index.php; 34     fastcgi_param SCRIPT_FILENAME /usr/share/nginx/html$fastcgi_script  _name; 35     include    fastcgi_params; 36   }[root@server2 conf.d]# nginx -tnginx: the configuration file /etc/nginx/nginx.conf syntax is oknginx: configuration file /etc/nginx/nginx.conf test is successful[root@server2 conf.d]# nginx [root@server2 conf.d]# netstat -anplt |grep nginxtcp    0   0 0.0.0.0:80         0.0.0.0:*          LISTEN   1141/nginx

redis,服務(wù)器環(huán)境,mysql,lnmp,架構(gòu)緩存

php測(cè)試:

[root@server2 conf.d]# cd /usr/share/nginx/html/[root@server2 html]# vim index.php[root@server2 html]# cat index.php <!--phpphpinfo()-->[root@server2 html]# /etc/init.d/php-fpm reloadReloading php-fpm: [14-Jul-2018 01:09:13] NOTICE: configuration file /etc/php-fpm.conf test is successful                              [ OK ]

物理機(jī)訪(fǎng)問(wèn):

redis,服務(wù)器環(huán)境,mysql,lnmp,架構(gòu)緩存

4、php配置redis+mysql

[root@server2 ~]# cd /usr/share/nginx/html/[root@server2 html]# vim test.php   <!--php      $redis = new Redis();      $redis--->connect('172.25.254.1',6379) or die ("could net connect redi  s server");   #   $query = "select * from test limit 9";      $query = "select * from test";      for ($key = 1; $key < 10; $key++)      {          if (!$redis->get($key))          {             $connect = mysql_connect('172.25.254.3','redis','wes  tos');             mysql_select_db(test);             $result = mysql_query($query);             //如果沒(méi)有找到$key,就將該查詢(xún)sql的結(jié)果緩存到redis             while ($row = mysql_fetch_assoc($result))             {                 $redis->set($row['id'],$row['name']);             }             $myserver = 'mysql';             break;         }         else         {             $myserver = "redis";             $data[$key] = $redis->get($key);         }     }     echo $myserver;     echo "";     for ($key = 1; $key < 10; $key++)     {        echo "number is $key";        echo "";        echo "name is $data[$key]"  ;        echo "";   }>

5、添加php支持的redis模塊

[root@server2 ~]# unzip phpredis-master.zip [root@server2 ~]# cd phpredis-master[root@server2 phpredis-master]# phpize Configuring for:PHP Api Version:     20090626Zend Module Api No:   20090626Zend Extension Api No:  220090626[root@server2 phpredis-master]# lsacinclude.m4  config.sub   library.c     README.markdownaclocal.m4   configure    library.h     redis.cautom4te.cache configure.in  ltmain.sh     redis_session.cbuild      CREDITS     Makefile.global  redis_session.hcommon.h    debian     missing      run-tests.phpconfig.guess  debian.control mkdeb-apache2.sh serialize.listconfig.h.in   igbinary    mkinstalldirs   testsconfig.m4    install-sh   php_redis.h[root@server2 phpredis-master]# ./configure [root@server2 phpredis-master]# make && make install [root@server2 ~]# cd /etc/php.d/[root@server2 php.d]# lscurl.ini   json.ini   mysql.ini   pdo_sqlite.ini zip.inifileinfo.ini mbstring.ini pdo.ini    phar.inigd.ini    mysqli.ini  pdo_mysql.ini sqlite3.ini[root@server2 php.d]# cp mysql.ini redis.ini[root@server2 php.d]# vim redis.ini  2 extension=redis.so [root@server2 php.d]# /etc/init.d/php-fpm reloadReloading php-fpm: [14-Jul-2018 01:21:56] NOTICE: configuration file /etc/php-fpm.conf test is successful                              [ OK ][root@server2 php.d]# php -m |grep redisredisserver3:mysql配置

1、安裝mysql-server

[root@server3 ~]# rpm -qa | grep mysqlmysql-community-common-5.7.17-1.el6.x86_64mysql-community-client-5.7.17-1.el6.x86_64mysql-community-libs-compat-5.7.17-1.el6.x86_64mha4mysql-node-0.56-0.el6.noarchmysql-community-libs-5.7.17-1.el6.x86_64mysql-community-server-5.7.17-1.el6.x86_64[root@server3 ~]# rpm -e `rpm -qa|grep mysql` --nodeps  ##不考慮依賴(lài)性刪除mysqlwarning: /etc/my.cnf saved as /etc/my.cnf.rpmsave[root@server3 ~]# rpm -qa | grep mysql[root@server3 ~]# cd /var/lib/mysql/[root@server3 mysql]# rm -fr *[root@server3 mysql]# ls[root@server3 mysql]# yum install -y mysql-server ##安裝

2、開(kāi)啟mysql,并導(dǎo)入測(cè)試數(shù)據(jù)庫(kù)

[root@server3 ~]# /etc/init.d/mysqld start[root@server3 ~]# mysql < test.sql[root@server3 ~]# mysql < test.sql [root@server3 ~]# cat test.sql use test;CREATE TABLE `test` (`id` int(7) NOT NULL AUTO_INCREMENT, `name` char(8) DEFAULT NULL, PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;INSERT INTO `test` VALUES (1,'test1'),(2,'test2'),(3,'test3'),(4,'test4'),(5,'test5'),(6,'test6'),(7,'test7'),(8,'test8'),(9,'test9');#DELIMITER $$#CREATE TRIGGER datatoredis AFTER UPDATE ON test FOR EACH ROW BEGIN#  SET @RECV=gman_do_background('syncToRedis', json_object(NEW.id as `id`, NEW.name as `name`)); # END$$#DELIMITER ;

3、數(shù)據(jù)庫(kù)授權(quán)

[root@server3 ~]# mysqlmysql> grant all on test.* to redis@'%' identified by 'westos';Query OK, 0 rows affected (0.00 sec)mysql> select * from test.test;+----+-------+| id | name |+----+-------+| 1 | test1 || 2 | test2 || 3 | test3 || 4 | test4 || 5 | test5 || 6 | test6 || 7 | test7 || 8 | test8 || 9 | test9 |+----+-------+9 rows in set (0.00 sec)

測(cè)試:訪(fǎng)問(wèn)172.25.254.2/test.php

1、php默認(rèn)從redis 索取數(shù)據(jù),第一次redis無(wú)緩存,則php從mysql'索取數(shù)據(jù)

第一次無(wú)緩存

redis,服務(wù)器環(huán)境,mysql,lnmp,架構(gòu)緩存

第二次索取數(shù)據(jù)后:

redis,服務(wù)器環(huán)境,mysql,lnmp,架構(gòu)緩存

redis節(jié)點(diǎn)也可查看

[root@server1 redis-4.0.1]# redis-cli127.0.0.1:6379> get 2"test2"

2、將數(shù)據(jù)庫(kù)server3節(jié)點(diǎn)內(nèi)容更新并刪除節(jié)點(diǎn),則php從數(shù)據(jù)庫(kù)索取數(shù)據(jù)節(jié)點(diǎn)更新內(nèi)容

mysql> update test.test set name='westos' where id=1;Query OK, 1 row affected (0.05 sec)Rows matched: 1 Changed: 1 Warnings: 0mysql> select * from test.test;+----+--------+| id | name  |+----+--------+| 1 | westos || 2 | test2 || 3 | test3 || 4 | test4 || 5 | test5 || 6 | test6 || 7 | test7 || 8 | test8 || 9 | test9 |+----+--------+9 rows in set (0.00 sec)

redis的master主機(jī)刪除節(jié)點(diǎn)內(nèi)容

[root@server1 redis-4.0.1]# redis-cli127.0.0.1:6379> get 2"test2"127.0.0.1:6379> del 1(integer) 1127.0.0.1:6379> get 1(nil)

刷新頁(yè)面,再次訪(fǎng)問(wèn)

redis,服務(wù)器環(huán)境,mysql,lnmp,架構(gòu)緩存

以上redis 作為 mysql 的緩存服務(wù)器,但是如果更新了 mysql,redis中仍然會(huì)有對(duì)應(yīng)的 KEY,數(shù)據(jù)就不會(huì)更新,此時(shí)就會(huì)出現(xiàn) mysql 和 redis 數(shù)據(jù)不一致的情況。

總結(jié)

以上所述是小編給大家介紹的redis服務(wù)器環(huán)境下mysql實(shí)現(xiàn)lnmp架構(gòu)緩存,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)VeVb武林網(wǎng)網(wǎng)站的支持!


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到MYSQL教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 新营市| 牙克石市| 青田县| 个旧市| 阜宁县| 金平| 封开县| 宁德市| 平塘县| 乐亭县| 西青区| 沙河市| 保德县| 永康市| 太仆寺旗| 周至县| 石景山区| 淮安市| 阿鲁科尔沁旗| 墨江| 南皮县| 清水县| 怀远县| 怀来县| 平武县| 突泉县| 潞西市| 阳新县| 阿鲁科尔沁旗| 札达县| 凌海市| 海城市| 遂溪县| 凤凰县| 巴中市| 南昌市| 阳朔县| 永福县| 买车| 无为县| 南江县|