高并发测试
接口幂等性
https://blog.csdn.net/qq_29978863/article/details/107739744
https://www.zhihu.com/question/324268535/answer/2443802529
https://blog.csdn.net/lengyue1084/article/details/123982611
幂等性:同一个接口,多次发出同一个请求,必须保证操作只执行一次。
唯一索引
使用唯一索引可以避免脏数据的添加,当插入重复数据时数据库会抛异常,保证了数据的唯一性。
乐观锁
这里的乐观锁指的是用乐观锁的原理去实现,为数据字段增加一个version字段,当数据需要更新时,先去数据库里获取此时的version版本号
select version from tablename where xxx
更新数据时首先和版本号作对比,如果不相等说明已经有其他的请求去更新数据了,提示更新失败。
update tablename set count=count+1,version=version+1 where version=#{version}
悲观锁
乐观锁可以实现的往往用悲观锁也能实现,在获取数据时进行加锁,当同时有多个重复请求时其他请求都无法进行操作
分布式锁
幂等的本质是分布式锁的问题,分布式锁正常可以通过redis或zookeeper实现;在分布式环境下,锁定全局唯一资源,使请求串行化,实际表现为互斥锁,防止重复,解决幂等。
token机制
token机制的核心思想是为每一次操作生成一个唯一性的凭证,也就是token。一个token在操作的每一个阶段只有一次执行权,一旦执行成功则保存执行结果。对重复的请求,返回同一个结果。token机制的应用十分广泛。
JMeter
安装
下载安装包
http://jmeter.apache.org/download_jmeter.cgi
解压压缩包
启动
进入到解压目录到bin,启动jmeter:sh jmeter
配置启动方式
vim .bash_profile
export JMETER_HOME={{jmeter解压路径}}
source ~/.bash_profile