使用nginx对spring boot项目进行代理

摘要:使用nginx对spring boot项目进行反向代理,并且使用轮询均衡负载策略

均衡负载与集群

集群和均衡都涉及到多个机器提供的服务的问题

不同点是,集群是互相通信、协同的的多个服务,服务之前能够状态共享。而均衡负载一般说的是,服务之间相互独立,不知道彼此。因此,使用均衡负载最好是提供的无状态的服务,如果服务有状态,那么就需要一个统一管理状态的服务单独部署

搭建过程

相关工具

  • 使用spring boot快速搭建一个web项目
  • virtual box作为虚拟机,并安装docker
  • 独立安装nginx,对docker容器进行反向代理

spring boot项目

只需要添加spring-boot-starter-web依赖即可,并且添加如下代码

package com.luzj.mychdocker10;

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

/**
 * @author luzj
 * @description:
 * @date 2018/7/27
 */
@RestController
public class IndexController {
    @RequestMapping("/index")
    public String index(){
        return "hello docker 1";
    }

    @RequestMapping("/tips")
    public String tips(){
        return "是莉娜呀!!!";
    }
}

然后将项目打包,之后修改上面index()的代码,使返回不同的字符串,这样便于观察nginx是否将请求分发到每一个服务上面去

服务2代码

  @RequestMapping("/index")
    public String index(){
        return "hello docker 2";
    }

服务3代码

  @RequestMapping("/index")
    public String index(){
        return "hello docker 3";
    }

分别将3个服务打成jar,待之后部署到docker上,分别是mychdocker10-0.0.1-SNAPSHOT.jar,mychdocker10-0.0.2-SNAPSHOT.jar,mychdocker10-0.0.3-SNAPSHOT.jar

docker+nginx部署项目

docker和nginx全部部署在virtual box上。其中docker部署用来部署前面的jar包,而nginx单独部署,对三个docker容器代理。

之所以nginx单独部署,是因为单独拉取的nginx镜像无法使用vim编写配置文件。

使用docker部署jar包

# 在 /home/<username>/目录下新建 dockerdir目录
mkdir -p /home/<username>/dockerdir

# 将jar包拷入多次可让敌人中

# 编写Dockerfile
vim Dockerfile

# Dockerfile内容
FROM java:8
add mychdocker10-0.0.3-SNAPSHOT.jar  app.jar
expose 8080
entrypoint ["java","-jar","/app.jar"]

# 编译docker镜像,balancejar 为镜像名称, . 表示当前目录
docker build -t balancejar .

# 运行容器,8081:8080表示将docker内部8080端口映射到宿主机的8081端口
docker run -d -p 8081:8080 --name balanceContainer balancejar

另外两个jar的的部署方式和上面的一样,分别映射到8082和8082端口

docker镜像列表:

docker容器列表:

virtual box端口映射

我们的docker是安装在virtual box上面的,如果想让本机可以访问,还需要将虚拟机的端口映射到宿主机的端口

选择[控制]->[设置]->[网络]->[端口转发],即可见端口映射配置面板,如下图

查看docker部署结果

可以看到直接在本机上可以访问了

配置nginx

nginx打开配置文件

vim /usr/local/nginx/conf/nginx.conf

添加如下配置信息到http模块里面

# 配置代理server组,标识为Tomcat
upstream tomcat {
      server  127.0.0.1:8081 weight=10;
      server  127.0.0.1:8082 weight=10;
      server  127.0.0.1:8083 weight=10;
}

server {
        listen 80; # 默认监听端口80
        server_name  cc520.me;# 对外服务名

        # ...其他配置信息

        # 配置代理路径
        location /docker{
                proxy_pass http://tomcat/;
        }

        # 对“/”路径转发 /docker
        location = / {
        return 302 /docker;
        }
    # ...其他配置信息
}

访问nginx进行验证

依次访问http://cc520.me/docker/index3次,可以看到如下结果

第一次

第二次

第三次

可以看到nginx使用默认的轮询策略进行服务分发,访问3次,依次访问了代理的3个服务

小结

我们使用docker部署springboot项目,之后使用nginx对3个docker容器进行代理,最后在浏览器访问查看nginx是否对springboot项目进行均衡负载

参考

nginx官方文档

docker官方文档

《springboot实战-汪云飞》

使用Nginx实现Tomcat集群负载均衡

原文地址:https://www.cnblogs.com/Franken-Fran/p/nginx_balanceLoad.html

时间: 2024-08-26 06:54:19

使用nginx对spring boot项目进行代理的相关文章

笔记:Spring Boot 项目构建与解析

构建 Maven 项目 通过官方的 Spring Initializr 工具来产生基础项目,访问 http://start.spring.io/ ,如下图所示,该页面提供了以Maven构建Spring Boot 项目的功能. 选择构建工具 Maven Project,Spring Boot 版本选择 1.5.4,填写 Group 和 Artifact 信息,在Search for dependencies 中可以搜索需要的其他依赖包,这里我们需要实现 RESTful API,所以可以添加 Web

Spring Boot项目搭建

1.Spring Boot概述 Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置.总所周知,Spring平台饱受非议的一点就是大量的XML配置以及复杂的依赖管理,而Spring Boot的出现就是用来简化操作的.相比传统的Spring,项目搭建更简单.方便.快速. 2.项目搭建 本文采用IDEA搭建Spring Boot,Demo结构图如下: 通过ID

[读书笔记] 一、Spring boot项目搭建与配置文件

读书笔记:[JavaEE开发的颠覆者 Spring Boot实战] 作者:汪云飞 从今天开始坚持读书,并记录下此读书笔记. 一,初接触 Spring boot 项目Hello world搭建 1.pom.xml 配置如下: <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocat

Eclipse中创建新的Spring Boot项目

简单几步,在Eclipse中创建一个新的Spring Boot项目: 1.Eclipse中安装STS插件: Help -> Eclipse Marketplace... Search或选择"Popular"标签,选择Spring Tool Suite (STS) for Eclipse插件,安装: 2.New -> Project... 找到Spring目录,选择Spring Starter Project,Next 3.填写跟项目相关的各种信息,然后Next: 4.选择需

Spring boot 1: 使用IDEA创建Spring boot项目

项目用到的环境: Windows 10 JDK8 IntelliJ IDEA 2017.1.3 Apache Tomcat 8 Maven 3.3.3 使用IDEA新建spring boot项目 新建项目 选择类型为Spring Initializer. 填入相关的项目信息 选择denpendcy 接着下一步, 选择web. 选择路径 再下一步, 选择项目的路径, 点击完成 新建成的项目的文件目录结构如下图: 第一个Spring boot项目 pom.xml如下所示: <dependencies

Spring Boot项目部署到 IBM WebSphere 8.5.5需要注意的地方

遇到问题 对Spring Boot观察了好久,最近终于开始有机会使用Spring Boot来做项目的开发,Spring Boot不需要部署,用jar包模式运行的机制,非常适合做快速开发,能在项目演示和迭代期间起到快速的推进作用.整体来说是一个非常好快速开发框架. 今天着重要说一下的是Spring Boot项目打包成war包,部署到J2EE容器,特别是Websphere遇到的问题. 首先Spring Boot项目build的war包,在Tomcat 7,8,Jetty等容器下,不论是嵌入到ecli

spring boot项目如何测试,如何部署

有很多网友会时不时的问我,spring boot项目如何测试,如何部署,在生产中有什么好的部署方案吗?这篇文章就来介绍一下spring boot 如何开发.调试.打包到最后的投产上线. 开发阶段 单元测试 在开发阶段的时候最重要的是单元测试了,springboot对单元测试的支持已经很完善了. 1.在pom包中添加spring-boot-starter-test包引用 <dependency> <groupId>org.springframework.boot</groupI

Spring Boot项目打包方式为war

spring boot项目默认是使用内嵌的tomcat打包为jar的方式,我们可以进行一些修改让其打包方式为war包: 修改maven的pom.xml <packaging>war</packaging> 然后将内嵌的tomcat依赖修改为: <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web-tomc

spring boot项目起步(一)

一.eclipse中创建spring boot项目 访问https://start.spring.io/,填入Group,Artifact,以及依赖的库,本次仅加入web的依赖(即springMVC的依赖),如图: 点击生成项目后下载解压. eclipse中导入生成的spring boot项目,File-Import-Maven-Existing Maven Projects-选择解压的项目-导入到eclipse中完成. 右键项目,run as maven build,goal为package,