Nginx可以干许多事情,在这里我们主要使用Nginx的反向代理与负载均衡功能。

1、Nginx的下载安装

在安装Nginx前需要安装如下软件:

GCC  Nginx是C写的,需要用GCC编译

PCRE(Perl Compatible Regular Expression)  Nginx的Rewrite和HTTP模块会用到

zlib  Gzip会用到

OpenSSL  ssl用到

如下命令:

yum install gcc
yum install -y pcre pcre-devel
yum install -y zlib zlib-devel
yum install -y openssl openssl-devel

创建目录(nginx-src),从官方地址(http://nginx.org/)下载,解压,配置,编译,安装:

 mkdir nginx-src && cd nginx-src
 wget http://nginx.org/download/nginx-1.7.3.tar.gz
 tar xzf nginx-1.7.3.tar.gz
 cd nginx-1.7.3
 ./configure
 make
 make install
 whereis nginx
 nginx: /usr/local/nginx

默认的安装路径为:/usr/local/nginx;跳转到/usr/local/nginx/sbin目录下:

启动:./nginx
停止:./nginx -s stop

启动后查看是否启动成功,可以在浏览器中输入http://loalhost后有Nginx提示首页或者输入如下命令查看:

ps -ef|grep nginx

类似如下的结果表示成功启动:

查看nginx的版本:

/usr/local/nginx/sbin/nginx -v

2、配置Nginx服务器组

创建两个nginx-sample-01与nginx-sample-02的Spring Boot服务,然后修改服务端口分别为:8081与8082,并且添加一个简单的服务类,代码如下:

8081端口的nginx-sample-01项目:

@RestController
public class TestCtrl {

    @RequestMapping(value="/")
    public void nginx( ) throws Exception {
    	System.out.println("nginx01---------------");
    }
}

8082端口的nginx-sample-02项目:

@RestController
public class TestCtrl {

    @RequestMapping(value="/")
    public void nginx( ) throws Exception {
    	System.out.println("nginx02---------------");
    }
}

然后打包为jar后,放到CentOS服务器上。使用如下类似的命令启动Web服务。

java -jar xxx.jar

现在有两个Spring Boot对外提供服务,Nginx来做负载均衡。编辑/usr/local/nginx/conf下的nginx.conf文件,添加upstream配置,这是配置一组被代理的服务器地址。

 upstream mysvr {
        server 192.168.2.129:8081;
        server 192.168.2.129:8082;
    }

server {
        listen       80;
        server_name  localhost;

        location / {
            proxy_pass http://mysvr;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

 }

重启nginx服务器后,在浏览器中访问http://localhost,这时候如果有如下输入,则说明配置生效。

nginx01---------------------
nginx02---------------------
nginx01---------------------
nginx02---------------------
...

nginx默认就是轮询其权重都默认为1,服务器处理请求的顺序:ABABABABAB....

将nginx添加到系统服务,这样我们就可以方便的进行常用操作了。

# vi /etc/init.d/nginx

打开nginx后,添加如下现行代码:

# chkconfig: 2345 85 15
# Startup script for the nginx Web Server
# chmod +x /etc/init.d/nginx
# chkconfig --add nginx
# chkconfig --list nginx
nginx 0:off 1:off 2:on 3:on 4:on 5:on 6:off

成功以后就可以使用如下命令来操作nginx了。

service nginx start/stop/reload..

3、nginx其它负载均衡

(1)ip_hash  nginx中的ip_hash技术能够将某个ip的请求定向到同一台后端,这样一来这个ip下的某个客户端和某个后端就能建立起稳固的session。但是可能获取不到正确的ip地址,如nginx之前还有代理,或者nginx后端还有分流的情况,都要考虑。

(2)upstream_hash nginx新版本中可支持读取cookie值,所以也可以改成 hash   $cookie_jsessionid;假如在php中配置的session为无cookie方式,配合nginx自己的一个userid_module模块就可以用nginx自发一个cookie。

(3)使用nginx sticky实现基于cookie的负载均衡   http://www.ttlsa.com/nginx/nginx-modules-nginx-sticky-module/

(4)一致性hash算法 可以使用第三方moduler的一致性hash算法来分配请求。

参考如下博文了解这个算法:http://www.cnblogs.com/haippy/archive/2011/12/10/2282943.html

github下载:https://github.com/replay/ngx_http_consistent_hash
unzip ngx_http_consistent_hash-master.zip
./configure --add-module=/home/mazhi/Downloads/ngx_http_consistent_hash-master
make
make install

修改mysvr服务器组,如下:

upstream mysvr {
        consistent_hash $request_uri;
        server 10.10.20.20:8081;
        server 10.10.20.20:8082;
}

剑指架构师系列-Nginx的安装与使用的更多相关文章

  1. 剑指架构师系列-MySQL的安装及主从同步

    1.安装数据库 wget http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm rpm -ivh mysql-commun ...

  2. 剑指架构师系列-Redis安装与使用

    1.安装Redis 我们在VMware中安装CentOS 64位系统后,在用户目录下下载安装Redis. 下载redis目前最稳定版本也是功能最完善,集群支持最好并加入了sentinel(哨兵-高可用 ...

  3. 剑指架构师系列-持续集成之Maven+Nexus+Jenkins+git+Spring boot

    1.Nexus与Maven 先说一下这个Maven是什么呢?大家都知道,Java社区发展的非常强大,封装各种功能的Jar包满天飞,那么如何才能方便的引入我们项目,为我所用呢?答案就是Maven,只需要 ...

  4. 剑指架构师系列-Linux下的调优

    1.I/O调优 CentOS下的iostat命令输出如下: $iostat -d -k 1 2 # 查看TPS和吞吐量 参数 -d 表示,显示设备(磁盘)使用状态:-k某些使用block为单位的列强制 ...

  5. 剑指架构师系列-MySQL调优

    介绍MySQL的调优手段,主要包括慢日志查询分析与Explain查询分析SQL执行计划 1.MySQL优化 1.慢日志查询分析 首先需要对慢日志进行一些设置,如下: SHOW VARIABLES LI ...

  6. 剑指架构师系列-Logstash分布式系统的日志监控

    Logstash主要做由三部署组成: Collect:数据输入 Enrich:数据加工,如过滤,改写等 Transport:数据输出 下面来安装一下: wget https://download.el ...

  7. 剑指架构师系列-ActiveMQ队列的使用

    安装ActiveMQ只需要下载包后解压,然后就可以启动与关闭ActiveMQ了,如下: ./activemq start ./activemq stop 访问管理页面: http://10.10.20 ...

  8. 剑指架构师系列-spring boot的logback日志记录

    Spring Boot集成了Logback日志系统. Logback的核心对象主要有3个:Logger.Appender.Layout 1.Logback Logger:日志的记录器 主要用于存放日志 ...

  9. 剑指架构师系列-ftp服务器

    1.安装FTP 我们在开发项目时,肯定需要专门的一台ftp服务器来存在上传的静态资源,今天我们就在CentOS下搭建一个ftp服务器. 1.安装vsftpd组件,安装完后,有/etc/vsftpd/v ...

随机推荐

  1. 老男孩python学习之作业一购物小程序

    想学编程由来已久 始终没有个结果,痛心不已 如今再次捡起来,望不负期望,不负岁月 ......一万字的废话...... 先介绍一下我的自学课程吧 "路飞学城"的<python ...

  2. BeautifulSoup重点复习

    html = """ <html><head><title>The Dormouse's story</title>< ...

  3. Delphi 10.2.3 + Xcode 9.2 开发 IOS 程序,免证书+免越狱,真机调试

    工具列表: 1,delphi 10.2.3 + PAServer19.0. 2,配置好一些的 PC 一台,建议至少 4 代 intel i5 + 16G + 256GSSD,低于此配置将产生拖延症. ...

  4. Ubuntu 18.04 LTS修改 国内源(以中科大源为例)

    国内有很多Ubuntu的镜像源,包括阿里的.网易的,还有很多教育网的源,比如:清华源.中科大源. 我们这里以中科大的源为例讲解如何修改Ubuntu 18.04里面默认的源. 可以进入这个链接进行下载: ...

  5. Oracle表空间的管理方式

    解释说明:表空间是一个逻辑概念:=> oracle 逻辑概念段区块管理方式: number one => tablespace number two=> segments Oracl ...

  6. Web SCADA 电力接线图工控组态编辑器

    前言 SVG并非仅仅是一种图像格式, 由于它是一种基于XML的语言,也就意味着它继承了XML的跨平台性和可扩展性,从而在图形可重用性上迈出了一大步.如SVG可以内嵌于其他的XML文档中,而SVG文档中 ...

  7. 云如何让App开发更简单?

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 互联网"下半场",移动App开发对于质量.速度的要求更加苛刻.4月初,腾讯云正式上线移动开发平台MobileLine,借 ...

  8. Linux使用踩坑记

    Ubuntu安装坑: 1.对于新手第一次安装ubuntu,特殊情况会出现因为分辨率问题导致安装界面不全,无法进行下一步操作. 解决方案:使用alt+鼠标左键拖动屏幕Linux文件名乱码问题: 2.因为 ...

  9. Linux(七)开机,重启和用户登录注销

    7.1 关机&重启命令 基本介绍: shutdown -h now       立刻进行关机 shutdown -h 1            1分钟后关机 shutdown -r now  ...

  10. P1837 单人纸牌_NOI导刊2011提高(04)

    题目描述 单人纸牌游戏,共36张牌分成9叠,每叠4张牌面向上.每次,游戏者可以从某两个不同的牌堆最顶上取出两张牌面相同的牌(如黑桃10和梅花10)并且一起拿走.如果最后所有纸牌都被取走,则游戏者就赢了 ...