nginx高可用,构建LNAMMP架构

简介:

  keepalived实现nginx高可用:

  Directory1:

   IP:172.16.72.5

  Directory2:

   IP:172.16.72.4

  RS1:

   IP:172.16.72.6

  RS2:

   IP:172.16.72.7

  Virtual IP:172.16.72.1

  ①安装nginx,keepalived

  yum -y install nginx keepalived

  ②校准时间,设置ntpd服务,时间服务器

  ③配置Directory1的nginx

  配置文件/etc/nginx/nginx.conf

  c04062c735ddd351f18f7f77eef6c5ab.jpg-wh_

  upstream设置后端服务器的相关信息

  在servver中设置Directory反代

    proxy_pass

  Directory2的nginx配置相同;

  配置keepalived:

  1176656302d18da35df8518949267991.jpg-wh_

  keepalived脚本接口,用于判断nginx服务是否开启

  若nginx服务已关闭,则返回exit 1,权重-10,这样在抢占模式下BACKUP就会转为MASTER;

  

  f5a2f9fc998b740d325b0ba894d43295.jpg-wh_

  

  Directory2的配置:

  nginx配置

  d00c3d947e5e2cce7a8264ca97865271.jpg-wh_

  keepalived配置:

  6c1d98a270b86ccb3c93264b8add088c.jpg-wh_

  3e568cbc197f4c75e3ca5fef1a8b43ee.jpg-wh_

  

  nginx高可用验证:

  MASTER为Directory1:

   7b6bae986998a1a024bee7e388c1fb08.jpg-wh_

  浏览器访问:

  d22c3e771228ac6f95cc3579852c29e6.jpg-wh_

  12e6f3b020368c2bb28c34f55b1f707f.jpg-wh_


  关闭Directory1的nginx服务

  [root@localhost 桌面]# nginx -s stop

  MASTER转到Directory2上:

  

  d958781a7c36a5821f17e7416682c962.jpg-wh_

  访问浏览器:

  13c0fc03421055479692ebd3222d347e.jpg-wh_

  3c1b39e65e4fb0a55e69ebae4d31287e.jpg-wh_



  构建LNAMMP架构:

    1) Nginx既是前端调度器,又是缓存服务器;

    2) 将php的session缓存于memcached中;

    3) 在Apache和php上部署Discuz论坛程序;

    4) 使用https连接,即使用户使用的是http协议也可以以https协议进行访问;

    

   ①配置Nginx前端调度器,缓存服务器:

    如上所述;

    

   ②后端真实服务器上配置Discuz程序

   将Discuz程序导入,使用unzip解压缩;

   配置Mariadb

   如:

   514be989a91df7fea79a9dd094f6504b.jpg-wh_


   解压后产生文件有upload,readme,utility;

   安装php-fpm;

   

   ③配置后端服务器的httpd

   两个Real Server的配置均相同,配置密钥的方式在这里不说了

   e9ac973f6e3b2f46343022b29a4ebb4e.jpg-wh_

    #yum install -y mod_ssl

    安装httpd下的https插件


   ④前端nginx的rewrite与反代

    在nginx高可用的基础上进行的修改

   c2cd1ba22ea0a1bcf184bb4dc7a8b3bd.jpg-wh_

   rewrite重写为https模式;

  

   08b742ff0e02522133d683970fe4df2a.jpg-wh_

   当访问80端口后,重写为https的域名,由443端口获取,再将其反代到wjq这个服务器组中;

   

   访问结果:

   直接访问https://www.wujunqi1.com/upload/install/index.php

   11e5a0048ccb72781885ebf7196da0da.jpg-wh_

   访问:http://www.wujunqi1.com/upload/install/index.php便会转到https服务


   断掉Directory1的nginx服务:

   #nginx -s stop

   访问第二台Directory2,结果相同

   0509df9f60bd84717cc20ece6e051655.jpg-wh_

   

  设置memcached缓存服务器:

    缓存服务器IP为172.16.72.5即第一台MASTER主机

    安装memcached

    #yum install -y memcached

    启动memcached

    #systemctl start memcached.service

    并在后端RS的php上设置会话缓存,主要配置/etc/php-fpm.d/www.conf(安装的是php-fpm)

    若安装的是php,则修改/etc/php.ini配置文件;

    d3794c9835c56861c11260e996c6280c.jpg-wh_

    需要注意的是,在配置php会话缓存时,需要与memcached相对应的配置项,如php-pecl-memcache   或者php-pecl-memcached;

    使用如下代码,去验证php缓存是否成功:

    923c22b1bb2f831a9462e477d178a2d3.jpg-wh_

    修改缓存服务器IP地址即可;

    该代码的主要意义在于,连接远程缓存服务器,并将hellokey作为键值,Hello World作为缓存数   据保存在缓存服务器中,保存时间600秒;

    访问nginx的虚拟IP,172.16.72.1,反代至后端的172.16.72.6主机得出缓存成功的结果;

    e364ee23b36648a2df57c41f88911f0d.jpg-wh_

    

    本文转自 wujunqi1996 51CTO博客,原文链接:http://blog.51cto.com/12480612/1979122

  




相关文章
|
3月前
|
负载均衡 关系型数据库 应用服务中间件
高可用系列文章之二 - 传统分层架构技术方案
高可用系列文章之二 - 传统分层架构技术方案
|
3月前
|
负载均衡 应用服务中间件 Linux
高可用系列文章之三 - NGINX 高可用实施方案
高可用系列文章之三 - NGINX 高可用实施方案
|
3月前
|
供应链 Java
云HIS技术架构:Angular+Nginx+Java+Spring,SpringBoot
标准数据维护 用户信息:维护用户的基本信息,所在科室以及各个系统所具体的权限。 科室信息:维护医院的科室信息。 数据字典:标准字典信息的维护。 药品/诊疗目录维护:维护药品和诊疗目录的基本信息。
34 2
|
3天前
|
存储 运维 负载均衡
Heartbeat+Nginx实现高可用集群
通过Heartbeat与Nginx的结合,您可以建立一个高可用性的负载均衡集群,确保在服务器故障时仍能提供无中断的服务。这种配置需要仔细的计划和测试,以确保系统在故障情况下能够正确运行。
10 2
|
5天前
|
运维 负载均衡 关系型数据库
MySQL高可用解决方案演进:从主从复制到InnoDB Cluster架构
MySQL高可用解决方案演进:从主从复制到InnoDB Cluster架构
|
13天前
|
负载均衡 网络协议 应用服务中间件
【亮剑】在Linux中构建高可用性和高性能网络服务的负载均衡工具HAProxy、Nginx和Keepalived。
【4月更文挑战第30天】本文介绍了在Linux中构建高可用性和高性能网络服务的负载均衡工具HAProxy、Nginx和Keepalived。HAProxy是一个高性能的开源TCP和HTTP负载均衡器,适合处理大量并发连接;Nginx是一个多功能Web服务器和反向代理,支持HTTP、HTTPS和TCP负载均衡,同时提供缓存和SSL功能;Keepalived用于监控和故障切换,通过VRRP实现IP热备份,保证服务连续性。文中详细阐述了如何配置这三个工具实现负载均衡,包括安装、配置文件修改和启动服务,为构建可靠的负载均衡系统提供了指导。
|
29天前
|
Kubernetes 搜索推荐 应用服务中间件
通过keepalived+nginx实现 k8s apiserver节点高可用
通过keepalived+nginx实现 k8s apiserver节点高可用
39 16
|
2月前
|
监控 Java 数据库
揭秘Java性能调优的层次 | 综合多方向提升应用程序性能与系统高可用的关键(架构层次规划)
揭秘Java性能调优的层次 | 综合多方向提升应用程序性能与系统高可用的关键(架构层次规划)
46 0
|
3月前
|
缓存 负载均衡 监控
从零开始搭建一个高可用的后端架构
【2月更文挑战第6天】本文将介绍如何从零开始搭建一个高可用的后端架构,包括架构设计、技术选型、部署和监控等方面。通过对各种技术的分析和实践,帮助读者深入理解高可用架构的实现和优化。
|
应用服务中间件 nginx