idea运行两个tomcat_在idea上配置多个端口启动web应用

目标

在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文件如下所示:

org.springframework.boot

spring-boot-starter-web

org.springframework.boot

spring-boot-starter-data-redis

org.redisson

redisson

3.2.3

org.springframework.boot

spring-boot-starter-test

test

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进行压测,模拟高并发


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