热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

负载均衡_Nginx反向代理动静分离负载均衡及rewrite隐藏路径详解(NginxApacheMySQLRedis)–第二部分

nginx反向代理、动静分离、负载均衡及rewrite隐藏路径详解

nginx反向代理、动静分离、负载均衡及rewrite隐藏路径详解

(Nginx Apache mysql Redis)

楓城浪子原创,转载请标明出处!

更多技术博文请见个人博客:https://fengchenglangzi.000webhostapp.com

微信bh19890922

QQ445718526、490425557

2.3 Redis 主从搭建

2.3.1 redis安装配置

1
2
3
4
5

[root@localhost redis-2.8.13]# yum install gcc gcc-c++ -y

[root@localhost ~]# cd /usr/local/src/

[root@localhost src]# wget -c http://download.redis.io/releases/redis-2.8.13.tar.gz

注:安装gcc gcc-c++,下载redis源码包

1
2
3
4
5
6
7
8
9

[root@localhost src]# tar -zxf redis-2.8.13.tar.gz

[root@localhost src]# cd redis-2.8.13

[root@localhost redis-2.8.13]# make

[root@localhost redis-2.8.13]# cd src

[root@localhost src]# make install PREFIX=/usr/local/redis

注:解压redis,并编译安装到指定目录

技术分享

1

[root@localhost redis-2.8.13]# cp redis.conf /usr/local/redis/

注:将redis配置文件复制到安装目录下,由于redis安装不会自动生成配置文件,故此操作在源码解压目录中操作

1
2
3

[root@localhost redis-2.8.13]# echo ‘export PATH=/usr/local/redis/bin:$PATH‘  >> /etc/profile

[root@localhost redis-2.8.13]# source /etc/profile

注:把redis下的bin目录加入环境变量profile末尾,然后执行命令使其生效。

1

[root@localhost redis]# sed -i ‘s/daemonize no/daemonize yes/g‘ redis.conf

注:由于默认redis启动不是后端启动,所以可以修改redis配置文件,把此处的no改为yes即可

技术分享

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

[root@localhost redis]# ./bin/redis-server ./redis.conf

[root@localhost redis]# ps aux | grep redis

root 4490 0.1 0.4 137372 2324 pts/0 Sl 05:26 0:00 /usr/local/redis/bin/redis-server *:6379

root 4500 0.0 0.1 103320 884 pts/0 S+ 05:32 0:00 grep redis

[root@localhost redis]# netstat -anlp | grep redis

tcp 0 0 0.0.0.0:6379 0.0.0.0:* LISTEN 4490/redis-server *

tcp 0 0 :::6379 :::* LISTEN 4490/redis-server *

[root@localhost redis]#

注:执行./bin/redis-server ./redis.conf 启动redis,虽然无任何提示,但可以使用ps命令查看redis进程以及使用netstat命令查看redis端口号

停止redis
redis-cli shutdown

关闭所有
redis-cli -p 6397 shutdown

关闭6397端口的redis

注:关闭以后缓存数据会自动转储到硬盘上,硬盘地址可以查看redis.conf配置文件中的dbfilename dump.rdb

2.3.2 Redis主从配置

Redis主从配置非常简单,而且redis支持多重slave,所以可以无限延伸下去

1

[root@localhost ~]# sed -i ‘/port 6379/a\slaveof 192.168.8.135 6379‘ /usr/local/redis/redis.conf

注:只需要在slave上面的redis主配置文件中port 6379 行下面加上slaveof 192.168.8.135 6379即可

1
2
3
4
5
6
7

[root@localhost ~]# pkill redis

[root@localhost ~]# /usr/local/redis/bin/redis-server ./redis.conf

[root@localhost ~]# redis-cli

127.0.0.1:6379> info

注:重启redis,并执行info命令,如果显示如下图所示,表示slave配置完成

技术分享

2.3.3 安装php-redis连接驱动

注:驱动需要和php安装在一起

所以一下配置在LAP上面进行

驱动作用:要确保PHP能够连接Redis缓存服务器,需添加PHP Redis扩展程序,即添加PHP扩展模块

1
2
3
4
5
6
7
8
9
10
11

[root@localhost src]# wget -c https://github.com/phpredis/phpredis/archive/3.1.2.tar.gz

[root@localhost src]# tar zxf 3.1.2.tar.gz

[root@localhost src]# cd phpredis-3.1.2/

[root@localhost phpredis-3.1.2]# /usr/local/php5/bin/phpize

[root@localhost phpredis-3.1.2]# ./configure --with-php-cOnfig=/usr/local/php5/bin/php-config --enable-redis

[root@localhost phpredis-3.1.2]# make -j8 && make install

注:下载驱动并编译安装,由于驱动本身解压后是没有configure执行文件的,所以使用phpize命令创建

如果出现以下报错请执行yum install m4 autoconf -y

技术分享

记录下图中部分/usr/local/php5/lib/php/extensions/no-debug-non-zts-20090626/

技术分享

1
2
3
4
5
6
7

[root@localhost phpredis-3.1.2]# cat >> /usr/local/php5/lib/php.ini <

extension_dir = "/usr/local/php5/lib/php/extensions/no-debug-non-zts-20090626/"

extension=redis.so

EOF

注:在php.ini最后追加以上内容

1

[root@localhost phpredis-3.1.2]# /usr/local/apache2/bin/apachectl restart

注:重启apache,然后刷新网页出现如下redis信息,即集成完成!

技术分享

2.4 发布Discuz论坛

1
2
3
4
5
6
7
8
9

[root@localhost src]# wget http://download.comsenz.com/DiscuzX/3.2/Discuz_X3.2_SC_UTF8.zip

root@localhost src]# unzip Discuz_X3.2_SC_UTF8.zip

[root@localhost src]# cp -a readme/ upload/ utility/ /usr/local/apache2/htdocs/

[root@localhost htdocs]# cp -a ./upload/* .

[root@localhost htdocs]# ../bin/apachectl restart

注:下载discuz软件,并解压复制到apache发布目录,并拷贝upload里的文件到发布根目录

访问http://192.168.8.135/install/进行安装

技术分享

提示不可写,直接在发布目录执行如下命令

1

[root@localhost htdocs]# chmod -R o+w .*

技术分享

此处省略discuz的安装过程,出现以下界面表示discuz安装完成

技术分享

1

[root@localhost config]# vim config_global.php

注:修改config_global.php ,此文件在发布目录config下,修改为如下图所示

技术分享

第二台LAP无需安装discuz,直接从第一台LAP上把发布目录拷贝过来即可,或者更方便的做法是部署一台NFS服务器,两台LAP共享发布目录即可

1

[root@localhost htdocs]# scp -r .* [email&#160;protected]:/usr/local/apache2/htdocs/

2.5 测试redis缓存discuz以及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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52

[root@localhost config]# redis-cli
127.0.0.1:6379> KEYS *

(empty list or set)

127.0.0.1:6379> KEYS *

1) "NgoypY_diytemplatenamehome"

2) "NgoypY_usergroups"

3) "NgoypY_onlinerecord"

4) "NgoypY_announcements"

5) "NgoypY_heats"

6) "NgoypY_pluginlanguage_system"

7) "NgoypY_userstats"

8) "NgoypY_usergroup_7"

9) "NgoypY_forum_index_page_7"

10) "NgoypY_pluginlanguage_script"

11) "NgoypY_style_default"

12) "NgoypY_userapp"

13) "NgoypY_historyposts"

14) "NgoypY_setting"

15) "NgoypY_plugin"

16) "NgoypY_cronnextrun"

17) "NgoypY_diytemplatenameforum"

18) "NgoypY_ipbanned"

19) "NgoypY_diytemplatename"

20) "NgoypY_magic"

21) "NgoypY_forumlinks"

22) "NgoypY_onlinelist"

127.0.0.1:6379>

注:在discuz论坛上面随便点击内容,然后在redis master上面执行以上命令,可以看到缓存的数据

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
42
43
44
45
46
47

[root@localhost ~]# redis-cli

127.0.0.1:6379> KEYS *

1) "NgoypY_magic"

2) "NgoypY_heats"

3) "NgoypY_diytemplatenamehome"

4) "NgoypY_historyposts"

5) "NgoypY_userapp"

6) "NgoypY_pluginlanguage_system"

7) "NgoypY_style_default"

8) "NgoypY_usergroup_7"

9) "NgoypY_forumlinks"

10) "NgoypY_plugin"

11) "NgoypY_usergroups"

12) "NgoypY_setting"

13) "NgoypY_onlinerecord"

14) "NgoypY_diytemplatenameforum"

15) "NgoypY_diytemplatename"

16) "NgoypY_userstats"

17) "NgoypY_cronnextrun"

18) "NgoypY_announcements"

19) "NgoypY_pluginlanguage_script"

20) "NgoypY_onlinelist"

21) "NgoypY_ipbanned"

127.0.0.1:6379>

注:以上是redis slave上面查看的内容,与master一致,表示redis缓存与redis主从配置无问题

至此基本环境搭建完毕!

本文出自 “楓城浪子” 博客,请务必保留此出处http://fengchenglangzi.blog.51cto.com/1322043/1963223


推荐阅读
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了软件测试知识点之数据库压力测试方法小结相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 原文地址http://balau82.wordpress.com/2010/02/28/hello-world-for-bare-metal-arm-using-qemu/最开始时 ... [详细]
  • 一面自我介绍对象相等的判断,equals方法实现。可以简单描述挫折,并说明自己如何克服,最终有哪些收获。职业规划表明自己决心,首先自己不准备继续求学了,必须招工作了。希望去哪 ... [详细]
  • MySQL5.6.40在CentOS764下安装过程 ... [详细]
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • Monkey《大话移动——Android与iOS应用测试指南》的预购信息发布啦!
    Monkey《大话移动——Android与iOS应用测试指南》的预购信息已经发布,可以在京东和当当网进行预购。感谢几位大牛给出的书评,并呼吁大家的支持。明天京东的链接也将发布。 ... [详细]
  • yum安装_Redis —yum安装全过程
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了Redis—yum安装全过程相关的知识,希望对你有一定的参考价值。访问https://redi ... [详细]
  • 本文介绍了关于apache、phpmyadmin、mysql、php、emacs、path等知识点,以及如何搭建php环境。文章提供了详细的安装步骤和所需软件列表,希望能帮助读者解决与LAMP相关的技术问题。 ... [详细]
  • 本文详细介绍了MySQL表分区的创建、增加和删除方法,包括查看分区数据量和全库数据量的方法。欢迎大家阅读并给予点评。 ... [详细]
  • Redis底层数据结构之压缩列表的介绍及实现原理
    本文介绍了Redis底层数据结构之压缩列表的概念、实现原理以及使用场景。压缩列表是Redis为了节约内存而开发的一种顺序数据结构,由特殊编码的连续内存块组成。文章详细解释了压缩列表的构成和各个属性的含义,以及如何通过指针来计算表尾节点的地址。压缩列表适用于列表键和哈希键中只包含少量小整数值和短字符串的情况。通过使用压缩列表,可以有效减少内存占用,提升Redis的性能。 ... [详细]
  • [翻译]微服务设计模式5. 服务发现服务端服务发现
    服务之间需要互相调用,在单体架构中,服务之间的互相调用直接通过编程语言层面的方法调用就搞定了。在传统的分布式应用的部署中,服务地 ... [详细]
author-avatar
三少乾坤_943
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有