redis服务器环境下mysql实现lnmp架构缓存

作者:weixin_41789003 时间:2024-01-20 01:44:29 

配置环境: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相应模块

redis服务器环境下mysql实现lnmp架构缓存

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: NOKEY
Preparing...        ########################################### [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 nginx
uid=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 nginx
uid=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 start
Starting php-fpm:                     [ OK ]
[root@server2 php-fpm.d]# netstat -antlp | grep php
tcp    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]# ls
default.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 -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
[root@server2 conf.d]# nginx
[root@server2 conf.d]# netstat -anplt |grep nginx
tcp    0   0 0.0.0.0:80         0.0.0.0:*          LISTEN   1141/nginx

redis服务器环境下mysql实现lnmp架构缓存

php测试:


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


物理机访问:


redis服务器环境下mysql实现lnmp架构缓存


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);
            //如果没有找到$key,就将该查询sql的结果缓存到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:     20090626
Zend Module Api No:   20090626
Zend Extension Api No:  220090626
[root@server2 phpredis-master]# ls
acinclude.m4  config.sub   library.c     README.markdown
aclocal.m4   configure    library.h     redis.c
autom4te.cache configure.in  ltmain.sh     redis_session.c
build      CREDITS     Makefile.global  redis_session.h
common.h    debian     missing      run-tests.php
config.guess  debian.control mkdeb-apache2.sh serialize.list
config.h.in   igbinary    mkinstalldirs   tests
config.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]# ls
curl.ini   json.ini   mysql.ini   pdo_sqlite.ini zip.ini
fileinfo.ini mbstring.ini pdo.ini    phar.ini
gd.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 reload
Reloading 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 redis
redis
server3:mysql配置

1、安装mysql-server


[root@server3 ~]# rpm -qa | grep mysql
mysql-community-common-5.7.17-1.el6.x86_64
mysql-community-client-5.7.17-1.el6.x86_64
mysql-community-libs-compat-5.7.17-1.el6.x86_64
mha4mysql-node-0.56-0.el6.noarch
mysql-community-libs-5.7.17-1.el6.x86_64
mysql-community-server-5.7.17-1.el6.x86_64
[root@server3 ~]# rpm -e `rpm -qa|grep mysql` --nodeps  ##不考虑依赖性删除mysql
warning: /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、开启mysql,并导入测试数据库


[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、数据库授权


[root@server3 ~]# mysql
mysql> 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)

测试:访问172.25.254.2/test.php

1、php默认从redis 索取数据,第一次redis无缓存,则php从mysql'索取数据

第一次无缓存

redis服务器环境下mysql实现lnmp架构缓存

第二次索取数据后:

redis服务器环境下mysql实现lnmp架构缓存

redis节点也可查看


[root@server1 redis-4.0.1]# redis-cli
127.0.0.1:6379> get 2
"test2"

2、将数据库server3节点内容更新并删除节点,则php从数据库索取数据节点更新内容


mysql> update test.test set name='westos' where id=1;
Query OK, 1 row affected (0.05 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> 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主机删除节点内容


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

刷新页面,再次访问

redis服务器环境下mysql实现lnmp架构缓存

以上redis 作为 mysql 的缓存服务器,但是如果更新了 mysql,redis中仍然会有对应的 KEY,数据就不会更新,此时就会出现 mysql 和 redis 数据不一致的情况。

总结

以上所述是小编给大家介绍的redis服务器环境下mysql实现lnmp架构缓存网站的支持!

来源:https://www.2cto.com/database/201807/761558.html

标签:mysql,lnmp,缓存,redis
0
投稿

猜你喜欢

  • thinkphp5实用入门进阶知识点和各种常用功能代码汇总

    2023-05-25 02:48:34
  • 详解Go语言中泛型的实现原理与使用

    2024-02-06 08:30:15
  • php获取文章内容第一张图片的方法示例

    2023-11-09 18:55:14
  • Python协程 yield与协程greenlet简单用法示例

    2023-02-23 04:07:25
  • Python破解网站登录密码脚本

    2022-09-29 23:21:38
  • rs.getrows的使用方法

    2008-04-05 14:01:00
  • python机器学习理论与实战(一)K近邻法

    2021-08-27 18:05:49
  • 打印出python 当前全局变量和入口参数的所有属性

    2022-09-01 07:06:51
  • Jupyter notebook在mac:linux上的配置和远程访问的方法

    2023-06-20 06:11:01
  • Python词云的正确实现方法实例

    2021-08-05 10:53:41
  • Python对两个有序列表进行合并和排序的例子

    2022-06-07 00:11:37
  • Python图像运算之图像点运算与灰度化处理详解

    2021-06-15 23:43:14
  • 什么是gRPC

    2023-01-16 15:23:53
  • javascript实现锁定网页、密码解锁效果(类似系统屏幕保护效果)

    2023-08-18 20:01:36
  • PHP制作图形验证码代码分享

    2024-05-11 09:26:01
  • Python ADF 单位根检验 如何查看结果的实现

    2021-05-24 13:40:39
  • 用 AjaxTags 简化 Ajax 开发

    2007-11-27 00:00:00
  • Python获取DLL和EXE文件版本号的方法

    2023-09-07 11:43:23
  • python requests包的request()函数中的参数-params和data的区别介绍

    2021-05-04 18:21:13
  • 区分有单选框的选项和普通的选项

    2008-04-17 13:44:00
  • asp之家 网络编程 m.aspxhome.com