Title: Segmentation Fault on PythonEngine.Initialize() · Issue #2479 · pythonnet/pythonnet · GitHub
Open Graph Title: Segmentation Fault on PythonEngine.Initialize() · Issue #2479 · pythonnet/pythonnet
X Title: Segmentation Fault on PythonEngine.Initialize() · Issue #2479 · pythonnet/pythonnet
Description: Environment Pythonnet version: 3.0.4 Python version: 3.11.3 Operating System: Linux Mint 21.1 .NET Runtime: NET 8 Details I have a C# NET application that works well under Windows but fails with multiple different Python versions under L...
Open Graph Description: Environment Pythonnet version: 3.0.4 Python version: 3.11.3 Operating System: Linux Mint 21.1 .NET Runtime: NET 8 Details I have a C# NET application that works well under Windows but fails with mu...
X Description: Environment Pythonnet version: 3.0.4 Python version: 3.11.3 Operating System: Linux Mint 21.1 .NET Runtime: NET 8 Details I have a C# NET application that works well under Windows but fails with mu...
Opengraph URL: https://github.com/pythonnet/pythonnet/issues/2479
X: @github
Domain: patch-diff.githubusercontent.com
{"@context":"https://schema.org","@type":"DiscussionForumPosting","headline":"Segmentation Fault on PythonEngine.Initialize()","articleBody":"### Environment\r\n\r\n- Pythonnet version: 3.0.4\r\n- Python version: 3.11.3\r\n- Operating System: Linux Mint 21.1\r\n- .NET Runtime: NET 8\r\n\r\n### Details\r\n\r\n- I have a C# NET application that works well under Windows but fails with multiple different Python versions under Linux. Pythonnet fails when I try to initialize it with PythonEngine.Initialize()\r\n- I'm compiling this CLI application in VS2022 under Windows using net8.0\r\n- Because pythonnet requires libpython3.11.so, I'm compiling Python from source on the target system with the ```--enable-shared``` flag. To compile Python 3.11.3 I'm using the following commands:\r\n\r\n```\r\n./configure --enable-shared\r\nmake -s -j2\r\n```\r\n- Is there a compilation flag I'm missing?\r\n\r\n```\r\nif (!Linux)\r\n{\r\n PythonHome = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, \"python-3.11.3-embed-amd64\");\r\n PythonDLL = \"python311.dll\";\r\n PythonPath = $\"{PythonHome}/Lib\";\r\n path = PythonHome + \";\" + Environment.GetEnvironmentVariable(\"PATH\", EnvironmentVariableTarget.Process);\r\n}\r\nelse\r\n{\r\n PythonHome = \"/home/user/cli/Python-3.11.3\";\r\n PythonPath = $\"{PythonHome}/Lib\";\r\n PythonDLL = $\"libpython3.11.so\";\r\n path = PythonHome + \":\" + Environment.GetEnvironmentVariable(\"PATH\", EnvironmentVariableTarget.Process);\r\n\r\n}\r\nEnvironment.SetEnvironmentVariable(\"PATH\", path, EnvironmentVariableTarget.Process);\r\nConsole.WriteLine(\"PATH = \" + Environment.GetEnvironmentVariable(\"PATH\", EnvironmentVariableTarget.Process));\r\nEnvironment.SetEnvironmentVariable(\"PYTHONHOME\", PythonHome, EnvironmentVariableTarget.Process);\r\nConsole.WriteLine(\"PYTHONHOME = \" + Environment.GetEnvironmentVariable(\"PYTHONHOME\", EnvironmentVariableTarget.Process));\r\nEnvironment.SetEnvironmentVariable(\"PYTHONPATH\", PythonPath, EnvironmentVariableTarget.Process);\r\nConsole.WriteLine(\"PYTHONPATH = \" + Environment.GetEnvironmentVariable(\"PYTHONPATH\", EnvironmentVariableTarget.Process));\r\nEnvironment.SetEnvironmentVariable(\"PYTHONNET_PYDLL\", PythonDLL, EnvironmentVariableTarget.Process);\r\nConsole.WriteLine(\"PYTHONNET_PYDLL = \" + Environment.GetEnvironmentVariable(\"PYTHONNET_PYDLL\", EnvironmentVariableTarget.Process));\r\n\r\nif (Linux)\r\n{\r\n Runtime.PythonDLL = PythonDLL;\r\n PythonEngine.PythonHome = PythonHome;\r\n PythonEngine.PythonPath = PythonPath;\r\n\r\n}\r\nConsole.WriteLine(\"Initializing.\");\r\nPythonEngine.Initialize();\r\nConsole.WriteLine(\"Allowing threads.\");\r\nPythonEngine.BeginAllowThreads();\r\nConsole.WriteLine(\"Initialized.\");\r\n```\r\n\r\nNo NET exception is thrown. It simply segfaults during initialization.\r\n```\r\nPATH = /home/user/cli/Python-3.11.3:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin\r\nPYTHONHOME = /home/user/cli/Python-3.11.3\r\nPYTHONPATH = /home/user/cli/Python-3.11.3/Lib\r\nPYTHONNET_PYDLL = libpython3.11.so\r\nInitializing.\r\nSegmentation fault (core dumped)\r\n```\r\n","author":{"url":"https://github.com/ddaigle-dge","@type":"Person","name":"ddaigle-dge"},"datePublished":"2024-10-08T03:09:24.000Z","interactionStatistic":{"@type":"InteractionCounter","interactionType":"https://schema.org/CommentAction","userInteractionCount":0},"url":"https://github.com/2479/pythonnet/issues/2479"}
| 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:60d22244-6ed3-b525-06bb-f51b734f57ed |
| current-catalog-service-hash | 81bb79d38c15960b92d99bca9288a9108c7a47b18f2423d0f6438c5b7bcd2114 |
| request-id | 8906:397E8F:749656:9C1F95:69719F32 |
| html-safe-nonce | 53d5267d9a61323937550bb497745e0b86847af528ad885d5a52bf500ef5f991 |
| visitor-payload | eyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiI4OTA2OjM5N0U4Rjo3NDk2NTY6OUMxRjk1OjY5NzE5RjMyIiwidmlzaXRvcl9pZCI6IjMxNDI4MTYwMjI1MzIzMDA1OTQiLCJyZWdpb25fZWRnZSI6ImlhZCIsInJlZ2lvbl9yZW5kZXIiOiJpYWQifQ== |
| visitor-hmac | 77c315c4e20425d6bbb58542ed492b21caf621ee8ecc9dc9cb89e309ebfd5fb1 |
| hovercard-subject-tag | issue:2571936815 |
| 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/2479/issue_layout |
| twitter:image | https://opengraph.githubassets.com/8af5a9001be50c642e1c59b8e5473de8c46c46117f599334cd88c35efd43804b/pythonnet/pythonnet/issues/2479 |
| twitter:card | summary_large_image |
| og:image | https://opengraph.githubassets.com/8af5a9001be50c642e1c59b8e5473de8c46c46117f599334cd88c35efd43804b/pythonnet/pythonnet/issues/2479 |
| og:image:alt | Environment Pythonnet version: 3.0.4 Python version: 3.11.3 Operating System: Linux Mint 21.1 .NET Runtime: NET 8 Details I have a C# NET application that works well under Windows but fails with mu... |
| og:image:width | 1200 |
| og:image:height | 600 |
| og:site_name | GitHub |
| og:type | object |
| og:author:username | ddaigle-dge |
| 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