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: github.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:b8d62829-704b-eea8-0fea-03174c42776b |
| current-catalog-service-hash | 81bb79d38c15960b92d99bca9288a9108c7a47b18f2423d0f6438c5b7bcd2114 |
| request-id | 9484:DECB5:193DF61:22B8042:6971ECC2 |
| html-safe-nonce | cb560e175a4920bf83ab49e6b72274a4e7c80ef172650155b3fbeb58b89ce324 |
| visitor-payload | eyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiI5NDg0OkRFQ0I1OjE5M0RGNjE6MjJCODA0Mjo2OTcxRUNDMiIsInZpc2l0b3JfaWQiOiI4MDEzOTQxNjEzNjg1NTg3ODYiLCJyZWdpb25fZWRnZSI6ImlhZCIsInJlZ2lvbl9yZW5kZXIiOiJpYWQifQ== |
| visitor-hmac | f5ca0973fbdadc6d3ec3cfa666c13307372616d93cd58d4f0a215ef4c04f3296 |
| 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 | 683712716975b3393656edf09255a1d488d0e68ab7b9ac97e40ecf40036f696c |
| 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 | ed99da4e2de688dd1056894c1eccd4c82c6bbbfe |
| ui-target | canary-1 |
| theme-color | #1e2327 |
| color-scheme | light dark |
Links:
Viewport: width=device-width