Supported languages in Azure Functions (original) (raw)
This article explains the levels of support offered for your preferred language when using Azure Functions. It also describes strategies for creating functions using languages not natively supported.
There are two levels of support:
- Generally available (GA) - Fully supported and approved for production use.
- Preview - Not yet supported, but expected to reach GA status in the future.
Languages by runtime version
Make sure to select your preferred development language at the top of the article.
The following table shows the .NET versions supported by Azure Functions.
The supported version of .NET depends on both your Functions runtime version and your chosen execution model:
The following table shows the language versions supported for Node.js functions.
Supported version | Support level | Expected end-of-support date |
---|---|---|
Node.js 22 | GA (Linux) Preview (Windows) | April 30, 2027 |
Node.js 20 | GA | April 30, 2026 |
TypeScript is supported through transpiling to JavaScript. For more information, see the Azure Functions Node.js developer guide.
The following table shows the language versions supported for Python functions.
Supported version | Support level | Expected end-of-support date |
---|---|---|
Python 3.12 | GA | October 2028 |
Python 3.11 | GA | October 2027 |
Python 3.10 | GA | October 2026 |
Python 3.9 | GA | October 2025 |
For more information, see Azure Functions Python developer guide.
For information about planned changes to language support, see the Azure roadmap updates.
Language support details
The following table shows which languages supported by Functions can run on Linux or Windows. It also indicates whether your language supports editing in the Azure portal. The language is based on the Runtime stack option you choose when creating your function app in the Azure portal. This is the same as the --worker-runtime
option when using the func init
command in Azure Functions Core Tools.
Language | Runtime stack | Linux | Windows | In-portal editing |
---|---|---|---|---|
C# (isolated worker model) | .NET | ✓ | ✓ | |
C# (in-process model) | .NET | ✓ | ✓ | |
C# script | .NET | ✓ | ✓ | ✓ |
JavaScript | Node.js | ✓ | ✓ | ✓ |
Python | Python | ✓ | X | ✓ |
Java | Java | ✓ | ✓ | |
PowerShell | PowerShell Core | ✓ | ✓ | ✓ |
TypeScript | Node.js | ✓ | ✓ | |
Go/Rust/other | Custom Handlers | ✓ | ✓ |
For more information on operating system and language support, see Operating system/runtime support.
When in-portal editing isn't available, you must instead develop your functions locally.
To learn more about how to maintain full-support coverage while running your functions in Azure, see our article.
Language major version support
Azure Functions provides a guarantee of support for the major versions of supported programming languages. For most languages, there are minor or patch versions released to update a supported major version. Examples of minor or patch versions include such as Python 3.9.1 and Node 14.17. After new minor versions of supported languages become available, the minor versions used by your functions apps are automatically upgraded to these newer minor or patch versions.
Note
Because Azure Functions can remove the support of older minor versions at any time after a new minor version is available, you shouldn't pin your function apps to a specific minor/patch version of a programming language.
Custom handlers
Custom handlers are lightweight web servers that receive events from the Azure Functions host. Any language that supports HTTP primitives can implement a custom handler. This means that custom handlers can be used to create functions in languages that aren't officially supported. To learn more, see Azure Functions custom handlers.
Language extensibility
Starting with version 2.x, the runtime is designed to offer language extensibility. The JavaScript and Java languages in the 2.x runtime are built with this extensibility.
ODBC driver support
This table indicates the ODBC driver support for your Python functions:
Driver version | Python version |
---|---|
ODBC driver 18 | ≥ Python 3.11 |
ODBC driver 17 | ≤ Python 3.10 |