Title: Releasing GIL in long-running C# method causes "Fatal Python error: PyEval_SaveThread: the function must be called with the GIL held, but the GIL is released (the current Python thread state is NULL)" · Issue #2208 · pythonnet/pythonnet · GitHub
Open Graph Title: Releasing GIL in long-running C# method causes "Fatal Python error: PyEval_SaveThread: the function must be called with the GIL held, but the GIL is released (the current Python thread state is NULL)" · Issue #2208 · pythonnet/pythonnet
X Title: Releasing GIL in long-running C# method causes "Fatal Python error: PyEval_SaveThread: the function must be called with the GIL held, but the GIL is released (the current Python thread state is NULL)" · Issue #2208 · pythonnet/pythonnet
Description: Environment Pythonnet version: 3.0.1 Python version: 3.9.13 Operating System: Windows 11 .NET Runtime: .NET Core 3.1 Details I'm trying to prevent a long running method in C# from blocking execution in Python. I followed the guidance on ...
Open Graph Description: Environment Pythonnet version: 3.0.1 Python version: 3.9.13 Operating System: Windows 11 .NET Runtime: .NET Core 3.1 Details I'm trying to prevent a long running method in C# from blocking executio...
X Description: Environment Pythonnet version: 3.0.1 Python version: 3.9.13 Operating System: Windows 11 .NET Runtime: .NET Core 3.1 Details I'm trying to prevent a long running method in C# from blocking exec...
Opengraph URL: https://github.com/pythonnet/pythonnet/issues/2208
X: @github
Domain: patch-diff.githubusercontent.com
{"@context":"https://schema.org","@type":"DiscussionForumPosting","headline":"Releasing GIL in long-running C# method causes \"Fatal Python error: PyEval_SaveThread: the function must be called with the GIL held, but the GIL is released (the current Python thread state is NULL)\"","articleBody":"### Environment\r\n\r\n- Pythonnet version: 3.0.1\r\n- Python version: 3.9.13\r\n- Operating System: Windows 11\r\n- .NET Runtime: .NET Core 3.1\r\n\r\n### Details\r\n\r\nI'm trying to prevent a long running method in C# from blocking execution in Python. I followed the guidance on https://github.com/pythonnet/pythonnet/wiki/Threading but I am getting a crash.\r\n\r\n- What commands did you run to trigger this issue? If you can provide a\r\n [Minimal, Complete, and Verifiable example](http://stackoverflow.com/help/mcve)\r\n this will help us understand the issue.\r\n\r\n```python\r\nimport pythonnet\r\npythonnet.load('coreclr')\r\n\r\nimport os\r\nbin_path = os.path.normpath(os.path.dirname(os.path.abspath(__file__)) + \"/../LongRunningTask/bin/Debug/netcoreapp3.1\")\r\n\r\nimport clr\r\nclr.AddReference(os.path.join(bin_path, \"LongRunningTask\"))\r\nclr.AddReference(\"System\")\r\n\r\nfrom LongRunningTask import LongRunningTask\r\nfrom threading import Thread, Timer\r\n\r\nt1 = Thread(target=LongRunningTask.Run)\r\n\r\nt1.daemon = True\r\nt1.start()\r\n```\r\n\r\n```csharp\r\nusing System.Threading;\r\nusing Python.Runtime;\r\n\r\nnamespace LongRunningTask\r\n{\r\n public class LongRunningTask\r\n {\r\n public static void Run()\r\n {\r\n var state = PythonEngine.BeginAllowThreads();\r\n Thread.Sleep(1000);\r\n PythonEngine.EndAllowThreads(state);\r\n }\r\n }\r\n}\r\n```\r\n\r\n- If there was a crash, please include the traceback here.\r\n\r\n```\r\nFatal Python error: PyGILState_Release: thread state 000001D4A5CA2A40 must be current when releasing\r\nPython runtime state: initialized\r\n\r\nThread 0x00001c08 (most recent call first):\r\n File \"C:\\Program Files (x86)\\Microsoft Visual Studio\\Shared\\Python39_64\\lib\\threading.py\", line 917 in run\r\n File \"C:\\Program Files (x86)\\Microsoft Visual Studio\\Shared\\Python39_64\\lib\\threading.py\", line 980 in _bootstrap_inner\r\n File \"C:\\Program Files (x86)\\Microsoft Visual Studio\\Shared\\Python39_64\\lib\\threading.py\", line 937 in _bootstrap\r\n\r\nCurrent thread 0x00005f6c (most recent call first):\r\n File \"C:\\Users\\shersh\\AppData\\Roaming\\Python\\Python39\\site-packages\\clr_loader\\types.py\", line 64 in __call__\r\n File \"C:\\Users\\shersh\\AppData\\Roaming\\Python\\Python39\\site-packages\\pythonnet\\__init__.py\", line 157 in unload\r\nFatal error. System.AccessViolationException: Attempted to read or write protected memory. This is often an indication that other memory is corrupt.\r\n at Python.Runtime.Runtime.PyGILState_Release(Python.Runtime.Native.PyGILState)\r\n at Python.Runtime.PythonEngine.ReleaseLock(Python.Runtime.Native.PyGILState)\r\n at Python.Runtime.Py+GILState.Dispose()\r\n at Python.Runtime.Loader.Shutdown(IntPtr, Int32)\r\n```\r\n","author":{"url":"https://github.com/sherryyshi","@type":"Person","name":"sherryyshi"},"datePublished":"2023-08-04T21:41:31.000Z","interactionStatistic":{"@type":"InteractionCounter","interactionType":"https://schema.org/CommentAction","userInteractionCount":1},"url":"https://github.com/2208/pythonnet/issues/2208"}
| route-pattern | /_view_fragments/issues/show/:user_id/:repository/:id/issue_layout(.:format) |
| route-controller | voltron_issues_fragments |
| route-action | issue_layout |
| fetch-nonce | v2:c6d727eb-bcdf-0739-6a21-f3749b49bae6 |
| current-catalog-service-hash | 81bb79d38c15960b92d99bca9288a9108c7a47b18f2423d0f6438c5b7bcd2114 |
| request-id | B89E:DB76B:1A1358A:2269EE9:69719F3D |
| html-safe-nonce | 93ee7115cca4f9b2c168df63ef8665666de60843a3d087e200456770ffa157d5 |
| visitor-payload | eyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiJCODlFOkRCNzZCOjFBMTM1OEE6MjI2OUVFOTo2OTcxOUYzRCIsInZpc2l0b3JfaWQiOiI5MDU3MzIzMDk2ODEyMzk2MzQ5IiwicmVnaW9uX2VkZ2UiOiJpYWQiLCJyZWdpb25fcmVuZGVyIjoiaWFkIn0= |
| visitor-hmac | c2ef77781bfb154fb7194547072fd81b06efb2560bac7b686f0555de0bd68ddd |
| hovercard-subject-tag | issue:1837375115 |
| github-keyboard-shortcuts | repository,issues,copilot |
| google-site-verification | Apib7-x98H0j5cPqHWwSMm6dNU4GmODRoqxLiDzdx9I |
| octolytics-url | https://collector.github.com/github/collect |
| analytics-location | / |
| fb:app_id | 1401488693436528 |
| apple-itunes-app | app-id=1477376905, app-argument=https://github.com/_view_fragments/issues/show/pythonnet/pythonnet/2208/issue_layout |
| twitter:image | https://opengraph.githubassets.com/eaa3bdf6027250e31067ae01d3df4299b56d0d99429e84dbca4d16d8b8fab3ee/pythonnet/pythonnet/issues/2208 |
| twitter:card | summary_large_image |
| og:image | https://opengraph.githubassets.com/eaa3bdf6027250e31067ae01d3df4299b56d0d99429e84dbca4d16d8b8fab3ee/pythonnet/pythonnet/issues/2208 |
| og:image:alt | Environment Pythonnet version: 3.0.1 Python version: 3.9.13 Operating System: Windows 11 .NET Runtime: .NET Core 3.1 Details I'm trying to prevent a long running method in C# from blocking executio... |
| og:image:width | 1200 |
| og:image:height | 600 |
| og:site_name | GitHub |
| og:type | object |
| og:author:username | sherryyshi |
| hostname | github.com |
| expected-hostname | github.com |
| None | fdfdce9cd4f6ab85dca2b0d11264270829297c962dd5a79df449062d7822258f |
| turbo-cache-control | no-preview |
| go-import | github.com/pythonnet/pythonnet git https://github.com/pythonnet/pythonnet.git |
| octolytics-dimension-user_id | 6050430 |
| octolytics-dimension-user_login | pythonnet |
| octolytics-dimension-repository_id | 14748123 |
| octolytics-dimension-repository_nwo | pythonnet/pythonnet |
| octolytics-dimension-repository_public | true |
| octolytics-dimension-repository_is_fork | false |
| octolytics-dimension-repository_network_root_id | 14748123 |
| octolytics-dimension-repository_network_root_nwo | pythonnet/pythonnet |
| turbo-body-classes | logged-out env-production page-responsive |
| disable-turbo | false |
| browser-stats-url | https://api.github.com/_private/browser/stats |
| browser-errors-url | https://api.github.com/_private/browser/errors |
| release | 51c736e60b302bd039c9d5164573d176ceb24bb2 |
| ui-target | full |
| theme-color | #1e2327 |
| color-scheme | light dark |
Links:
Viewport: width=device-width