Instalación del SDK y el entorno de ejecución de .NET en SLES
.NET es compatible con SLES. En este artículo se describe cómo instalar .NET en SLES.
Instale el SDK (que incluye el entorno de ejecución) si quiere desarrollar aplicaciones .NET. O bien, si solo necesita ejecutar aplicaciones, instale el entorno de ejecución. Si va a instalar el entorno de ejecución, se recomienda instalar el entorno de ejecución de ASP.NET Core, ya que incluye los de .NET y ASP.NET Core.
Use los comandos dotnet --list-sdks
y dotnet --list-runtimes
para ver qué versiones están instaladas. Para obtener más información, vea Cómo comprobar que .NET Core ya está instalado.
Distribuciones admitidas
En la tabla siguiente se muestra una lista de las versiones de .NET compatibles actualmente en SLES 12 SP2 y SLES 15. Estas versiones siguen siendo compatibles hasta que la versión de .NET llegue al final del soporte técnico o ya no se admita la versión de SLES.
SLES | .NET |
---|---|
15 | 7, 6 |
12 SP2 | 7, 6 |
Las versiones siguientes de .NET ya ❌ no se admiten:
- .NET 5
- .NET Core 3.1
- .NET Core 3.0
- .NET Core 2.2
- .NET Core 2.1
- .NET Core 2.0
Instalación de versiones preliminares
Las versiones preliminares y candidatas para lanzamiento de .NET no están disponibles en los repositorios de paquetes. Puede instalar las versiones preliminares y versiones candidatas para lanzamiento de .NET de una de las formas siguientes:
Eliminación de versiones preliminares
Cuando se usa un administrador de paquetes para administrar la instalación de .NET, es posible que se produzca un conflicto si previamente se ha instalado una versión preliminar. El administrador de paquetes puede interpretar la versión que no es preliminar como una versión anterior de .NET. Para instalar la versión que no es preliminar, desinstale primero las versiones preliminares. Para obtener más información sobre cómo desinstalar .NET, vea Procedimiento para quitar el entorno de ejecución y el SDK de .NET.
SLES 15
Antes de instalar .NET, ejecute los siguientes comandos para agregar la clave de la firma del paquete de Microsoft a la lista de claves de confianza y agregar el repositorio de paquetes de Microsoft. Abra un terminal y ejecute los comandos siguientes:
sudo rpm -Uvh https://packages.microsoft.com/config/sles/15/packages-microsoft-prod.rpm
Actualmente, el paquete de instalación del repositorio de Microsoft de SLES 15 instala el archivo microsoft-prod.repo en el directorio incorrecto, lo que impide que zypper pueda encontrar los paquetes de .NET. Para corregir este problema, cree un symlink en el directorio apropiado.
sudo ln -s /etc/yum.repos.d/microsoft-prod.repo /etc/zypp/repos.d/microsoft-prod.repo
Instalación del SDK
El SDK de .NET permite desarrollar aplicaciones con .NET. Si instala el SDK de .NET, no necesita instalar el entorno de ejecución correspondiente. Para instalar el SDK de .NET, ejecute el comando siguiente:
sudo zypper install dotnet-sdk-6.0
Instalación de la instancia en tiempo de ejecución
El entorno de ejecución de ASP.NET Core le permite ejecutar aplicaciones creadas con .NET en las que no se ha proporcionado el entorno de ejecución. El comando siguiente instala ASP.NET Core Runtime, que es el runtime más compatible con .NET. Ejecute el comando siguiente en el terminal:
sudo zypper install aspnetcore-runtime-6.0
Una alternativa al entorno de ejecución de ASP.NET Core es instalar el de .NET, que no incluye compatibilidad con ASP.NET Core; en el comando anterior, reemplace aspnetcore-runtime-6.0
por dotnet-runtime-6.0
:
sudo zypper install dotnet-runtime-6.0
SLES 12
.NET necesita SP2 como mínimo para la familia SLES 12.
Antes de instalar .NET, ejecute los siguientes comandos para agregar la clave de la firma del paquete de Microsoft a la lista de claves de confianza y agregar el repositorio de paquetes de Microsoft. Abra un terminal y ejecute los comandos siguientes:
sudo rpm -Uvh https://packages.microsoft.com/config/sles/12/packages-microsoft-prod.rpm
Instalación del SDK
El SDK de .NET permite desarrollar aplicaciones con .NET. Si instala el SDK de .NET, no necesita instalar el entorno de ejecución correspondiente. Para instalar el SDK de .NET, ejecute el comando siguiente:
sudo zypper install dotnet-sdk-6.0
Instalación de la instancia en tiempo de ejecución
El entorno de ejecución de ASP.NET Core le permite ejecutar aplicaciones creadas con .NET en las que no se ha proporcionado el entorno de ejecución. El comando siguiente instala ASP.NET Core Runtime, que es el runtime más compatible con .NET. Ejecute el comando siguiente en el terminal:
sudo zypper install aspnetcore-runtime-6.0
Una alternativa al entorno de ejecución de ASP.NET Core es instalar el de .NET, que no incluye compatibilidad con ASP.NET Core; en el comando anterior, reemplace aspnetcore-runtime-6.0
por dotnet-runtime-6.0
:
sudo zypper install dotnet-runtime-6.0
Procedimiento para instalar otras versiones
Todas las versiones de .NET están disponibles para la descarga en https://dotnet.microsoft.com/download/dotnet, pero requieren la instalación manual. Puede probar y usar el administrador de paquetes para instalar una versión diferente de .NET. Sin embargo, es posible que la versión solicitada no esté disponible.
Los paquetes agregados a las fuentes del administrador de paquetes se denominan con un formato susceptible de intrusiones, como, por ejemplo: {product}-{type}-{version}
.
product
Tipo de producto .NET que se va a instalar. Las opciones válidas son:- dotnet
- aspnetcore
type
Elige el SDK o el entorno de ejecución. Las opciones válidas son:- sdk (solo disponible para el producto dotnet)
- motor en tiempo de ejecución
version
Versión del SDK o del entorno de ejecución que se va a instalar. En este artículo se proporcionarán siempre las instrucciones para la última versión admitida. Las opciones válidas son cualquier versión de lanzamiento, como las siguientes:- 7.0
- 5.0
- 3.1
- 2.1
Es posible que el SDK o el entorno de ejecución que intenta descargar no esté disponible para su distribución de Linux. Para obtener una lista de las distribuciones admitidas, vea Instalación de .NET en Linux.
Ejemplos
- Instalación del entorno de ejecución de ASP.NET Core 7.0:
aspnetcore-runtime-7.0
- Instalación del entorno de ejecución de ASP.NET Core 2.1:
dotnet-runtime-2.1
- Instalación del SDK de .NET 5:
dotnet-sdk-5.0
- Instalación del SDK de .NET Core 3.1:
dotnet-sdk-3.1
Falta el paquete
Si la combinación de paquete y versión no funciona, no está disponible. Por ejemplo, no hay un SDK de ASP.NET Core; los componentes del SDK se incluyen en el SDK de .NET. El valor aspnetcore-sdk-7.0
es no es correcto y debe ser dotnet-sdk-7.0
. Para obtener una lista de las distribuciones de Linux compatibles con .NET, vea Dependencias y requisitos de .NET.
Solución de problemas del administrador de paquetes
En esta sección se proporciona información sobre los errores comunes que puede obtener al usar el administrador de paquetes para instalar .NET.
No se pudo capturar el elemento
Al instalar el paquete de .NET, puede ver un error similar a signature verification failed for file 'repomd.xml' from repository 'packages-microsoft-com-prod'
. En términos generales, este error significa que la fuente de paquetes para .NET se está actualizando con versiones de paquetes más recientes y que debe volver a intentarlo más tarde. Durante una actualización, la fuente de paquetes no debe estar disponible durante más de 2 horas. Si recibe este error continuamente durante más de 2 horas, abra una incidencia en https://github.com/dotnet/core/issues.
Dependencias
Al realizar la instalación con un administrador de paquetes, estas bibliotecas se instalan automáticamente. Pero si instala manualmente .NET o publica una aplicación independiente, deberá asegurarse de que estas bibliotecas estén instaladas:
- krb5
- libicu
- libopenssl1_1
Si la versión de OpenSSL del entorno de tiempo de ejecución de destino es 1.1 o más reciente, deberá instalar compat-openssl10.
Para obtener más información sobre las dependencias, vea Aplicaciones de Linux independientes.
Si la aplicación de .NET usa el ensamblado System.Drawing.Common, también será necesario instalar libgdiplus. Dado que System.Drawing.Common ya no se admite en Linux, solo funciona en .NET 6 y requiere que se establezca el conmutador de configuración en tiempo de ejecución System.Drawing.EnableUnixSupport
.