亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

redis環境下mysql是如何實現lnmp架構緩存的

發布時間:2020-05-08 11:23:37 來源:億速云 閱讀:305 作者:三月 欄目:MySQL數據庫

本文主要給大家介紹redis環境下mysql是如何實現lnmp架構緩存的,文章內容都是筆者用心摘選和編輯的,具有一定的針對性,對大家的參考意義還是比較大的,下面跟筆者一起了解下redis環境下mysql是如何實現lnmp架構緩存的吧。

配置環境:centos 7.2

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安裝

?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
[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配置

?

1
2
3
4
5
6
7
8
9
10
11
12
13
[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配置

?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
[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測試:

?

1
2
3
4
5
6
7
8
9
[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

?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
[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模塊

?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
[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

?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
[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,并導入測試數據庫

?

1
2
3
4
5
6
7
8
9
10
11
12
[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、數據庫授權

?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
[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節點也可查看

?

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

2、將數據庫server3節點內容更新并刪除節點,則php從數據庫索取數據節點更新內容

?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
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主機刪除節點內容

?

1
2
3
4
5
6
7
[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是如何實現lnmp架構緩存的,很多讀者朋友肯定多少有一定的了解,如需獲取更多的行業知識信息 ,可以持續關注我們的行業資訊欄目的。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

乌鲁木齐县| 西贡区| 卓资县| 犍为县| 台江县| 吉安县| 敦煌市| 虞城县| 河北区| 博兴县| 平遥县| 宝丰县| 石棉县| 天峻县| 高邑县| 绍兴市| 巢湖市| 永川市| 乃东县| 桃园市| 富宁县| 大足县| 双鸭山市| 思茅市| 息烽县| 云龙县| 射洪县| 潮州市| 上犹县| 新疆| 静乐县| 迭部县| 临清市| 精河县| 团风县| 台北县| 福鼎市| 德保县| 历史| 卢湾区| 高青县|