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: github.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:8baa8de0-265c-b1ad-cc3c-3da982c61bc0 |
| current-catalog-service-hash | 81bb79d38c15960b92d99bca9288a9108c7a47b18f2423d0f6438c5b7bcd2114 |
| request-id | 872C:1792BE:2391970:3107B6D:6973AA2C |
| html-safe-nonce | b49369eaedf156f4bcc52b7cc6ed46c9cfb912937aaf6cd1acc6bf826efbe816 |
| visitor-payload | eyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiI4NzJDOjE3OTJCRToyMzkxOTcwOjMxMDdCNkQ6Njk3M0FBMkMiLCJ2aXNpdG9yX2lkIjoiMjAyMzE4MzY5Mjc0NTM4NjU0MCIsInJlZ2lvbl9lZGdlIjoiaWFkIiwicmVnaW9uX3JlbmRlciI6ImlhZCJ9 |
| visitor-hmac | a058a97a3837e6ec2dc18e4a7ad6db187ae037af019d3dc26f03c3eebb2593f2 |
| 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 | 3e9aa9d0c22a21b13b378b4acd09f5dd4876a884425aacd32a9f473b84c8762d |
| 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 | 9240c0b5247c88bacc8dffb46ecac04c94fd094b |
| ui-target | full |
| theme-color | #1e2327 |
| color-scheme | light dark |
Links:
Viewport: width=device-width