在idea上配置多个端口启动web应用

  • Post author:
  • Post category:其他


目标

在idea上新建web项目,然后配置多个端口启动web应用,然后用一个nginx服务对其进行负载,搭建tomcat间,再模拟多个请求。

步骤

1.打开idea,new一个名为“redis_study”的project,然后在redis_study工程下新建“distributed_lock”的module,

2.web项目创建完成后,添加IndexController类,如下所示

@RestController
public class IndexController {

//    @Autowired
//    private Redisson redisson;
    @Autowired
    private StringRedisTemplate stringRedisTemplate;

    @RequestMapping(value="/deduct_lock",method= RequestMethod.GET)//写法与springMVC有点相似
    public String deductStock() {
        synchronized (this) {
            int stock = Integer.parseInt(stringRedisTemplate.opsForValue().get("stock"))
            if (stock > 0) {
                int realStock = stock - 1;
                stringRedisTemplate.opsForValue().set("stock", realStock + "");
                System.out.println("扣减库存成功,剩余库存为" + realStock);
            } else {
                System.out.println("扣减失败,库存不足");
            }
            return "end";
        }
    }
}

pom文件如下所示:

  <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>
        <dependency>
            <groupId>org.redisson</groupId>
            <artifactId>redisson</artifactId>
            <version>3.2.3</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

3.使用redis客户端,在redis为stock创建库存为50,如下图所示:

4.由于该web项目需要以8081和8082端口启动,所以添加了两个配置文件,application-8081.properties和application-8082.properties,配置文件中加上了redis的配置信息,如下图

server.port=8081
# Redis数据库索引(默认为0)
spring.redis.database=0
# Redis服务器地址
spring.redis.host=192.168.10.151
# Redis服务器连接端口
spring.redis.port=6379
# Redis服务器连接密码(默认为空)

spring.redis.timeout=5000

5.在右上角打开“Edit Configurations”,添加两个启动配置

“DistributedLockApplication-8081”的program arguments参数配置为–spring.profiles.active=8081

“DistributedLockApplication-8082”的program arguments参数配置为–spring.profiles.active=8082

他们会分别读取application-8081.properties和application-8082.properties配置文件。

6.启动web服务

在idea上选择“DistributedLockApplication-8081”然后点击启动web项目,8082端口的启动类似,启动完成后如下图

在浏览器上分别输入:http://localhost:8081/deduct_lock和http://localhost:8082/deduct_lock,发现redis上库存有减少

启动两个tomcat,监听端口分别是8081和8082,他们连接同一个redis,并对库存“stock”进行扣减,大功告成

下一步将通过nginx搭建tomcat集群,然后用jmeter进行压测,模拟高并发



版权声明:本文为yougou_sully原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。