久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

Spring?boot?整合?Redisson實現分布式鎖并驗證功能

這篇文章主要介紹了Spring?boot?整合?Redisson實現分布式鎖并驗證,redisson是官方推薦的分布式鎖實現方案,采用redis自身的原子命令和lua腳本來實現,需要的朋友可以參考下

簡述

整篇文章寫的比較粗糙,大佬看了輕噴。前半部分 是整合spring boot和redisson, 后半部分是驗證分布式鎖。在整個過程中遇見了不少的問題,在此做個記錄少走彎路

redisson是官方推薦的分布式鎖實現方案,采用redis自身的原子命令和lua腳本來實現

1. 在idea中新建spring boot工程并引入所需依賴

idea中直接新建一個spring boot項目即可,再在pom.xml中引入所需依賴,依賴信息如下

  <!-- redis所需 -->
         <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>
        <!-- web頁面訪問所需 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
<dependency>
    <groupId>org.redisson</groupId>
    <artifactId>redisson-spring-data-25</artifactId>
    <version>3.16.4</version>
</dependency>
<!-- Redisson所需依賴 -->
<dependency>
    <groupId>org.redisson</groupId>
    <artifactId>redisson-spring-boot-starter</artifactId>
    <version>3.16.4</version>
</dependency>

2. 編寫相關代碼實現

采用一個票卷庫存來進行鎖的驗證,需要預先在redis里面設置一個key為ticket的信息,值為100之類的數字即可 代碼示例編寫:

@RestController
@Slf4j
public class RedisController {
    // spring boot 操作redis的模板方法類
    @Autowired
    private StringRedisTemplate redisTemplate;

    // redisson操作bean
    @Resource
    private Redisson redisson;
    @RequestMapping("/lock")
    public String deductTicket(){
        String lockKey = "ticket";
        
        // 在spring boot 2.0.6版本中整合的redisson,key和鎖不能一樣
        // redis setnx 操作,此處的lockKey在后面追加1是為了避免redisson鎖時報錯, 需要和待鎖住的數據的key信息不同
        RLock lock = redisson.getLock(lockKey+"1");
        try {
            lock.lock();
            int ticketCount = Integer.parseInt(redisTemplate.opsForValue().get(lockKey));
            if (ticketCount > 0) {
                int realTicketCount = ticketCount - 1;
                log.info("扣除成功:剩余票數:" + realTicketCount);
                redisTemplate.opsForValue().set(lockKey, realTicketCount + "");
                return realTicketCount + "";
            } else {
                log.error("扣除失敗");
                return "error";
            }
            return "end";
        } finally {
            lock.unlock();
        }
    }
}

application.yml配置信息如下

server:
  port: 8899  # web服務對外端口
  redis:
    host: 192.168.0.160 #redis地址
    database: 0 #采用的庫編號
    port: 6379 #redis端口
    password: 123456 #redis密碼,如果redis沒有設置密碼直接去掉該配置不寫空

3. 模擬實際環境驗證

一個簡單的分布式鎖驗證的demo完成了,比較粗糙,驗證的方式有多樣的,可以采用java本身的多線程進行驗證,也可以類似實際環境部署多個節點來驗證,這里為了技術的廣度的一個應用,采用后面的方式。

3.1 下載idea的docker插件并配置相關鏡像信息

  • docker插件下載

  • idea配置docker連接虛擬機上的docker

    開啟docker遠程連接

vim /usr/lib/systemd/system/docker.service

找到 ExecStart,在最后面添加 -H tcp://0.0.0.0:2375

重啟docker

systemctl daemon-reload 
systemctl start docker

開放端口

firewall-cmd --zone=public --add-port=2375/tcp --permanent

idea配置docker連接

配置完成后可在idea中看到連接的docker鏡像、容器相關信息

3.2 將spring boot打包的jar構建為docker鏡像

編寫Dockerfile

在工程目錄中新建Dockerfile,與pom.xml文件同級

Dockerfile內容如下

FROM openjdk:8-jdk-alpine # 指定基礎鏡像為jdk8
ADD target/spring-0.0.1-SNAPSHOT.jar app.jar #將打包的jar包放入鏡像中并重命名為app.jar
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]  #啟動jar包

在pom.xml中添加插件信息

<plugin>
    <groupId>com.spotify</groupId>
    <artifactId>docker-maven-plugin</artifactId>
    <version>1.0.0</version>
    <configuration>
        <imageName>com.demo/${project.artifactId}</imageName>
        <dockerDirectory></dockerDirectory>
        <resources>
            <resource>
                <targetPath>/</targetPath>
                <directory>${project.build.directory}</directory>
                <include>${project.build.finalName}.jar</include>
            </resource>
        </resources>
    </configuration>
</plugin>

idea添加docker構建配置

此處操作的目的是為了便于在idea中直接構建鏡像啟動容器

配置信息如下

(1)Dockerfile文件位置

(2)鏡像tag

(3)構建成功后啟動的容器名稱

(4)端口映射 宿主機端口:容器內端口

jar包打好之后可直接點擊

如果沒有問題idea的docker控制臺會輸出容器內啟動相關日志信息

此處為了驗證分布式鎖,需要兩個節點以上,所以這里我手動啟動了另外一個docker容器(暫時沒有編寫shell腳本)

啟動命令如下

docker run -d --name demo2 -p 8900:8899 demo:1.1

容器名稱demo2 映射到宿主機端口 8900

查看應用日志可使用 docker logs -f 容器名稱

spring boot 構建docker鏡像應該有更簡單的方式,歡迎在評論區交流補充

3.2 配置nginx

可以更改默認的日志格式如下,為了記錄代理的具體節點信息

 log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for" ' '"$upstream_addr"';

配置負載均衡

upstream tomcat { 
        server 192.168.0.160:8899 weight=10; # 此處設置權重為相同的即可
        server 192.168.0.160:8900 weight=10;
    }

配置代理

location  / {
           proxy_pass http://tomcat;
           proxy_redirect default;
        }

完整的代理配置如下

配置完成后

nginx -s reload

進行訪問驗證

192.168.0.160/lock

可查看nginx、容器內日志信息來驗證是否訪問成功

nginx如何訪問出現error,可查看nginx中的錯誤日志。如果是權限問題(# failed (13: Permission denied) while connecting to upstream) 可用root用戶啟動或使用命令 setsebool -P httpd_can_network_connect 1 來解決

3.3 下載安裝Jmeter進行測試

Jmeter下載地址:jmeter.apache.org/download_jm…

下載解壓后在bin目錄中店家jmeter.bat即可啟動jmeter

新增計劃

配置線程信息

(1) 請求線程數

(2) 多少s內啟動完線程 設置為0代表同時啟動 設置為2代表2s內啟動完20個線程,1s啟動10個線程

添加請求

(1) ip地址

(2) 端口

(3) path信息,這里設置為jar中的地址信息

點擊綠色三角箭頭啟動并進行驗證

查看redis緩存中設置的數據是否在測試完成后符合預期值,也可查看nginx中的日志來確定請求是否平均分配到了兩個節點

參考文章:
juejin.cn/post/684490…

juejin.cn/post/709110…

到此這篇關于Spring boot 整合 Redisson實現分布式鎖并驗證的文章就介紹到這了,更多相關Spring boot 分布式鎖內容請搜索html5模板網以前的文章希望大家以后多多支持html5模板網!

【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

相關文檔推薦

這篇文章主要為大家詳細介紹了如何利用SpringBoot+WebSocket實現即時通訊功能,文中示例代碼講解詳細,對我們學習或工作有一定參考價值,需要的可以參考一下
本文主要介紹了SpringBoot二維碼生成base64并上傳OSS的實現示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學
本文主要介紹了SpringSecurity實現退出登錄和退出處理器,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習
這篇文章主要介紹了springboot+redis實現一個簡單的熱搜功能,通過代碼介紹了過濾不雅文字的過濾器,代碼簡單易懂,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
這篇文章主要介紹了在SpringBoot中使用HATEOAS的方法,HATEOAS是實現REST規范的一種原則,通過遵循HATEOAS規范,可以解決我們實際代碼實現的各種個問題,下文更多相關介紹,需要的小伙伴可
在我們開發系統過程中,經常會處理一些費時間的任務(如:向數據庫中插入大量數據),這個時候就就需要使用多線程,下面這篇文章主要給大家介紹了關于Spring多線程的使用以及問題的相關
主站蜘蛛池模板: 日本精品一区二区三区视频 | 欧美一级毛片久久99精品蜜桃 | 97视频人人澡人人爽 | 午夜在线| 天天射夜夜操 | 伊人免费在线观看 | 国产激情网 | 五月天天丁香婷婷在线中 | 99免费在线视频 | 一区二区三区欧美 | 久久精品日产第一区二区三区 | 欧美日韩中文字幕在线播放 | 精品视频免费 | 日本不卡视频 | 国产黄色av电影 | 国产成人免费 | 99国产精品久久久 | 婷婷成人在线 | 亚洲欧美日韩在线一区二区 | 成人精品一区二区 | 国产精品国产 | 韩日一区二区三区 | 国产人成精品一区二区三 | 成人国产精品久久 | 亚洲九九色 | 9191av| 免费麻豆视频 | 最新中文字幕 | 成人免费片 | 新91| 亚洲国产精品久久久久婷婷老年 | 亚洲视频一区在线播放 | 国产ts人妖一区二区三区 | 国产在线视频一区 | 精品国产乱码久久久久久蜜退臀 | 欧美一区二区三区电影 | 久久日本 | 黑人巨大精品欧美黑白配亚洲 | а天堂中文最新一区二区三区 | 国产成人在线看 | 一级毛片黄片 |