I need to run a background logic that takes around 25-30 sec inside a WCF method that can't take more than 1 sec to complete. I've decided to wrap that logic into a WaitCallback and pass it to ThreadPool.QueueUserWorkItem right before I exit the web method. Initially it worked ok but now I'm having second thoughts because I suspect that sometimes QueueUserWorkItem method doesn't return in a timely manner as a result web method doesn't respond within 1 sec on a regular basis. Are there any issues with using QueueUserWorkItem inside WCF methods?
Using ThreadPool.QueueUserWorkItem in WCF method
903 Views Asked by kirill_l At
1
There are 1 best solutions below
Related Questions in WCF
- Migrate ASMX web method to WCF which accepts string array
- Handling WCF enums when client and server have different versions of enum
- Objective tools for monitoring WCF APIs for latency, failures, and breakdowns?
- ASP.NET Core Web api + WCF
- WCF Authentification Android App - Maui WCF Webservice Basic
- WCF to WCFCore - Help Menu
- Problem with hashtag (#) character in httpclient and WCF
- How to add REST API to a .NET Framework Solution with existing WCF Services?
- How to run WCF service in VSCODE
- Adding HTTP Headers using MessageInspector in WCF (VB.NET) Not Working
- The data returned by the WCF service contains special characters, causing an error when the client attempts to receive it!"
- How to configure rest api’s in WCF project , making it hybrid solution
- WCF + PostgresQL. Npqsql connection is not open
- CORS Error that is not fixed with usual solution
- .NET project hosted on IIS is timing out in 5 minutes but works fine on localhost
Related Questions in THREADPOOL
- C++ error: no matching member function for call to 'enqueue' futures.emplace_back(TP.enqueue(sum_plus_one, x, &M));
- Efficiently Handling Large Number of API Calls with Delphi 10.4 and OmniThreadLibrary
- RedisConnectionFailureException intermittently
- Java custom ThreadPool - pause task submission and cancel current queued tasks
- DataInputStream not recognising input
- Why is publishDir not copying large directories?
- asio using both coroutine and thread_pool issue
- The infinite loop to make the connection with opcua server, regardless of disconnecting the client
- Tcl Thread: Why this ten lines don't commit in parallel?
- ThreadPoolExecutor too fast for CPU bound task
- Handling a thread crash
- Why do I see this error "org.springframework.core.task.TaskRejectedException" when using Spring Framework 5.3.2?
- Can using a CPU with higher computing power necessarily reduce the number of required logical cores under the same load?
- How does the ThreadPool decide which type of thread to use for a work item
- std::thread move problem (use member function)
Related Questions in QUEUEUSERWORKITEM
- Background threads in ASP.NET - what mechanism is best?
- Call a method after ThreadPool.QueueUserWorkItem finished
- QueueUserWorkItem weird behavior
- why my threadpool 's threads do not finish at same time
- QueueUserWorkItem with WaitCallback getting the return value
- Copied WIT won't calculate remaining time in Backlog bord
- Using ThreadPool.QueueUserWorkItem for Millions of threads
- ThreadPool.QueueUserWorkItem, The Thread Exited has with code 0 (0x0)
- Calling Win32 QueueUserWorkItem() with a private member function
- Tracking Thread usage in .NET/IIS program
- Memory leak when using .NET ThreadPool
- How to monitor the state of the .Net Thread Pool?
- Parameter to QueueUserWorkItem with a lambda expression?
- ThreadPool with 2 WaitCallback will sometimes be stuck
- ThreadPool.QueueUserWorkItem vs Parallel.For
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular # Hahtags
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
No not as such, but your question touches upon a more general problem, what to do with long-running service calls? You can either:
Or, design your service calls with a start / get current progress / get final result API, all of which return quickly:
This is more work, but a better design, and you now also have to maintain a list of running jobs (your async proceessing which could use
QueueUserWorkItemor whatever), but all the service calls would return quickly.