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