欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

.net core并發(fā)下線程安全問題詳解

 更新時(shí)間:2019年04月11日 09:07:29   作者:Vam8023  
這篇文章主要給大家介紹了關(guān)于.net core并發(fā)下線程安全問題的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用.net core具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

抱歉,其實(shí)內(nèi)容并不如題?。?!

背景(寫測試demo所出現(xiàn)的異常,供大家學(xué)習(xí)與拍磚):

.net core webapi項(xiàng)目,做了一個(gè)授權(quán)的filter(真正的生產(chǎn)項(xiàng)目的話,JWT很棒),單個(gè)接口測試沒有問題,當(dāng)用前端在同一個(gè)頁面調(diào)用多個(gè)接口的時(shí)候,運(yùn)行服務(wù),打開頁面,然后……Exceptions……(真正的開發(fā)中大家應(yīng)該也會遇到)

異常1:An attempt was made to use the context while it is being configured. A DbContext instance cannot be used inside OnConfiguring since it is still being configured at this point. This can happen if a second operation is started on this context before a previous operation completed. Any instance members are not guaranteed to be thread safe.

異常2:A second operation started on this context before a previous operation completed. Any instance members are not guaranteed to be thread safe.

異常3:Invalid attempt to call Read when reader is closed.

異常4:Unable to cast object of type 'System.Data.ProviderBase.DbConnectionClosedConnecting' to type 'System.Data.SqlClient.SqlInternalConnectionTds'.

異常5:Object reference not set to an instance of an object.

異常6:不允許啟動新事務(wù),因?yàn)橛衅渌€程正在該會話中運(yùn)行。

異常7:An error occurred while updating the entries. See the inner exception for details.

嘗試運(yùn)行了N多遍,嗯,挺不穩(wěn)定的(代碼垃圾?。?,那看看異常吧

一看很容易理解:在前一個(gè)操作完成之前,在此上下文中啟動第二個(gè)操作。任何實(shí)例成員都不能保證是線程安全的。就是說,我在用這個(gè)上下文的時(shí)候,你來搶個(gè)屁……

這個(gè)可能發(fā)生在并發(fā)的情況下,同時(shí)使用了同一個(gè)上下文……那么打開一個(gè)頁面,為什么會同時(shí)使用同一個(gè)上下文呢?好吧,在這里要負(fù)荊請罪了(可以說是自己的問題)

我在Filter里面有查詢,用到數(shù)據(jù)庫上下文<DbContext> 。罪過咯,直接想在Filter里面過濾黑名單,所以查了數(shù)據(jù)庫(這個(gè)業(yè)務(wù)是不合理的,這是一個(gè)作死的行為,請謹(jǐn)慎看待,這里做學(xué)習(xí)討論之用)。

public class AuthFilterAttribute : ActionFilterAttribute
{

 public override void OnActionExecuting(ActionExecutingContext context)
 {

  base.OnActionExecuting(context);
    .....
  
  //判斷是否在黑名單內(nèi)
  var blackList = _app.GetBlackList();
  ......
 }}

這里為什么用 ActionFilterAttribute ?是因?yàn)闇y試的時(shí)候要監(jiān)測一下接口運(yùn)行的整個(gè)過程,So……

然后還有一些錯(cuò)是:對象引用未設(shè)置為對象的實(shí)例。這個(gè)錯(cuò)誤太常見,不就是對象為Null了嗎?但是,未實(shí)例化對象在業(yè)務(wù)邏輯上的情況太多了。我的應(yīng)該有:

1、沒有獲取到當(dāng)前對象,這是.net core,不是.net,不是因?yàn)闆]有new對象。是注入中沒有注入成功,獲取注入后,沒有獲取到。(但我本來運(yùn)行的好好的,是因?yàn)橐幌率谴蜷_對接的頁面才發(fā)生的問題,可以排除了)

2、本來已經(jīng)實(shí)例的對象被回收了……(這可能性嘛……有一定的可能,但發(fā)生在哪呢?)

找啊找,其實(shí)方向有了,但是自己卻沒想起來……

其實(shí)如果不確定的話,倒是可以先找找別人是怎么說的(不是為了裝X,找開發(fā)上的問題我是推薦 github 和 stackoverflow 的,大部分的問題都可以找到):

(1)異常 1 還有同樣 一條搜索結(jié)果

(2)異常 2

 

雖然以上找的不一定是真正的答案,至少提供了一個(gè)方向,并且你至少可以嘗試性地去解決一下。這里提供的方向其實(shí)很明確:

1、是否應(yīng)該使用 Scoped 和 Transient 的,你卻使用了 Singleton;

2、多線程中使用了 async 卻沒有配對的使用 await;

至少我找到的關(guān)鍵點(diǎn)是這兩個(gè)。

那怎么找到并解決這個(gè)問題呢,.net core都是注入的,當(dāng)然 AuthFilterAttribute 也是注入的。跑到 Startup一看,很明顯,問題出在哪里了 -- 單例!本應(yīng)該是Scoped模式的,卻用了單例。

那就將 AuthFilterAttribute 換一種注入模式就行啦。

 

改為

我使用的是Filter,F(xiàn)ilter有自己的生命周期,去確認(rèn)一下:Filter的官方文檔

看到一張圖?。。。ó?dāng)然你也可以細(xì)細(xì)研讀一下這個(gè)文檔)如下:

這還不明顯??。?!

Filter會被回收的!?。∵@同樣解釋了 異常3、4、5、6、7所發(fā)生的原因。

OK,問題已經(jīng)解決了,這是在開發(fā)中遇到的問題,可以說是涉及到.net core 本身的運(yùn)行機(jī)制。

我算是一個(gè)應(yīng)用型的程序員,喜歡在應(yīng)用中學(xué)習(xí)底層的東西。那么接下來當(dāng)然就可以擴(kuò)展 Singleton、Scoped 和 Transient 等知識了。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對腳本之家的支持。

相關(guān)文章

  • .NET 水晶報(bào)表使用代碼

    .NET 水晶報(bào)表使用代碼

    下面就是介紹在.net下,如何使用水晶報(bào)表的方法。
    2009-04-04
  • .net core使用redis基于StackExchange.Redis

    .net core使用redis基于StackExchange.Redis

    這篇文章主要為大家詳細(xì)介紹了.net core使用redis基于StackExchange.Redis的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • asp.net 購物車的實(shí)現(xiàn)淺析

    asp.net 購物車的實(shí)現(xiàn)淺析

    我從來沒有進(jìn)行過正式的web開發(fā),但是我一直喜歡web,所以這篇文章也是我轉(zhuǎn)行web的一個(gè)開始吧?;蚨嗷蛏傥乙矃⒖剂藥讉€(gè)網(wǎng)站的實(shí)現(xiàn)(當(dāng)然了,只是看看大概的功能而已),所以也請大家多多指教。
    2011-02-02
  • .Net使用SuperSocket框架實(shí)現(xiàn)WebSocket后端

    .Net使用SuperSocket框架實(shí)現(xiàn)WebSocket后端

    這篇文章介紹了.Net使用SuperSocket框架實(shí)現(xiàn)WebSocket后端,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-01-01
  • asp.net+ajax的Post請求實(shí)例

    asp.net+ajax的Post請求實(shí)例

    這篇文章主要介紹了asp.net+ajax的Post請求實(shí)現(xiàn)方法,實(shí)例分析了Ajax的發(fā)送post數(shù)據(jù)的原理與技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-01-01
  • Asp.net SignalR快速入門

    Asp.net SignalR快速入門

    這篇文章主要介紹了Asp.net SignalR快速入門,幫助大家可以快速的上手Asp.net SignalR,感興趣的小伙伴們可以參考一下
    2016-04-04
  • 一個(gè)簡單的文件MD5碼自動計(jì)算比較器(附源碼)

    一個(gè)簡單的文件MD5碼自動計(jì)算比較器(附源碼)

    一直在玩 WOW ,發(fā)現(xiàn)網(wǎng)上的 MD5 計(jì)算工具都沒有自動比較功能,每次下載更新計(jì)算后,都要自己一個(gè)一個(gè)字母核對,比較麻煩。 最近開始學(xué)習(xí) C# ,用 .NET ,做了一個(gè)簡單的文件MD5碼自動計(jì)算比較器。
    2013-02-02
  • Visual Studio 2015和 .NET Core安裝教程

    Visual Studio 2015和 .NET Core安裝教程

    這篇文章主要為大家詳細(xì)介紹了Visual Studio Community 2015和 .NET Core安裝圖文教程,感興趣的小伙伴們可以參考一下
    2016-07-07
  • Log4net在.Net?Winform項(xiàng)目中的使用實(shí)例詳解

    Log4net在.Net?Winform項(xiàng)目中的使用實(shí)例詳解

    Log4net是一個(gè)流行的日志記錄工具,可以幫助開發(fā)人員在應(yīng)用程序中實(shí)現(xiàn)高效的日志記錄,本文將提供一個(gè)詳細(xì)的分步驟示例,來幫助您在.Net Winform項(xiàng)目中使用Log4net,感興趣的朋友一起看看吧
    2023-08-08
  • MongoDB.Net工具庫MongoRepository使用方法詳解

    MongoDB.Net工具庫MongoRepository使用方法詳解

    這篇文章主要為大家詳細(xì)介紹了MongoDB.Net工具庫MongoRepository的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01

最新評論