IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效

目录

  • 引出
  • IDEA启动Tomcat两个端口的方式
    • 1.编辑配置
    • 2.添加新的端口-Dserver.port=8083
    • 3.service里面管理
    • 4.启动后进行测试
  • 使用nginx进行反向代理
    • 反向代理多个端口
    • 运行日志查看
    • 启动关闭重启
  • 分布式情况下synchronized失效
    • synchronized锁代码
    • 启动tomcat两个端口
    • nginx反向代理
    • JMeter高并发测试
      • 1.端口,路径,参数设置
      • 2请求头设置
      • 3.进行抢购的测试
  • 总结

引出


1.在idea中启动tomcat两个端口-Dserver.port=8083;
2.nginx进行反向代理多个url的配置;
3.synchronize锁代码,启动tomcat两个端口+nginx反向代理,用JMeter高并发测试,验证分布式情况下,synchronize锁失效情况;

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第1张图片

IDEA启动Tomcat两个端口的方式

1.编辑配置

编辑配置

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第2张图片

复制之前的服务app

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第3张图片

2.添加新的端口-Dserver.port=8083

修改名字,点击修改选项

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第4张图片

添加虚拟选项vm options

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第5张图片

输入-Dserver.port=8083

设置新的服务的端口号

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第6张图片

3.service里面管理

在service里面管理多个端口

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第7张图片

service里面管理

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第8张图片

4.启动后进行测试

启动后进行测试

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第9张图片

使用nginx进行反向代理

start nginx --启动
nginx -s stop --停止
nginx -s reload --重启

反向代理多个端口

在这里插入图片描述

	upstream pet{
		server 127.0.0.1:10009;
		server 127.0.0.1:10002;
	}

server里面设置

		location / {
			proxy_pass http://pet;
		}

cmd命令启动nginx

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第10张图片

运行日志查看

查看运行的日志文件

在这里插入图片描述

根据日志修改配置文件

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第11张图片

再次启动,运行成功

在这里插入图片描述

启动关闭重启

在这里插入图片描述

分布式情况下synchronized失效

synchronized锁代码

    @Override
    public synchronized HttpResp<?> killStart(Integer bookId) { // 方案1:加锁
        KillBook killBook =  (KillBook)redisTemplate.opsForHash().get("killBook",bookId +"");
        if (killBook !=null && killBook.getKillNum() > 0){
            killBook.setKillNum(killBook.getKillNum()-1);
            log.debug("当前库存-->>>"+killBook.getKillNum());
            redisTemplate.opsForHash().put("killBook", bookId+"", killBook);
            return HttpResp.ok();
        }else {
            return HttpResp.fail();
        }
    }

启动tomcat两个端口

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第12张图片

nginx反向代理

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第13张图片

反向代理链接

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第14张图片
IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第15张图片

JMeter高并发测试

1.端口,路径,参数设置

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第16张图片

路径设置

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第17张图片

2请求头设置

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第18张图片

添加请求头jwt

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第19张图片

3.进行抢购的测试

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第20张图片

!出现锁失效的情况

IDEA启动Tomcat两个端口的方式 & 使用nginx进行反向代理 & JMeter测试分布式情况下synchronized锁失效_第21张图片


总结

1.在idea中启动tomcat两个端口-Dserver.port=8083;
2.nginx进行反向代理多个url的配置;
3.synchronize锁代码,启动tomcat两个端口+nginx反向代理,用JMeter高并发测试,验证分布式情况下,synchronize锁失效情况;

你可能感兴趣的:(SpringBoot,#,Redis,Java,intellij-idea,tomcat,nginx)