Installing ASP.NET 5 On Linux ============================= By `Daniel Roth`_ .. contents:: In this article :local: :depth: 1 Install using prebuild binaries ------------------------------- Prebuild binaries for ASP.NET 5 are available (`.tar.gz `__) and can be installed as appropriate based on your system configuration. Alternatively you can use the .NET Version Manager (DNVM) to install ASP.NET 5 as described below. For either method of installation you will need to install the prerequisites for your specific distribution as described in the following sections. Installing on Ubuntu 14.04 -------------------------------------------- The following instructions were tested using Ubuntu 14.04. Other versions of Ubuntu and other Debian based distros are unlikely to work correctly. Install the .NET Version Manager (DNVM) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Use the .NET Version Manager (DNVM) to install different versions of the .NET Execution Environment (DNX) on Linux. 1. Install ``unzip`` and ``curl`` if you don't already have them:: sudo apt-get install unzip curl 2. Download and install DNVM:: curl -sSL https://raw.githubusercontent.com/aspnet/Home/dev/dnvminstall.sh | DNX_BRANCH=dev sh && source ~/.dnx/dnvm/dnvm.sh Once this step is complete you should be able to run ``dnvm`` and see some help text. Install the .NET Execution Environment (DNX) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ The .NET Execution Environment (DNX) is used to build and run .NET projects. Use DNVM to install DNX for `Mono `_ or .NET Core (see :doc:`choosing-the-right-dotnet`). **To install DNX for .NET Core:** 1. Install the DNX prerequisites:: sudo apt-get install libunwind8 gettext libssl-dev libcurl4-openssl-dev zlib1g libicu-dev uuid-dev 2. Use DNVM to install DNX for .NET Core:: dnvm upgrade -r coreclr **To install DNX for Mono:** 1. Install `Mono `__ via the ``mono-complete`` package. 2. Ensure that the ``ca-certificates-mono`` package is also installed as `noted `__ in the Mono installation instructions. 3. Use DNVM to install DNX for Mono:: dnvm upgrade -r mono By default DNVM will install DNX for Mono if no runtime is specified. .. note:: Restoring packages using DNX on Mono may fail with multiple canceled requests. You may be able to work around this issue by setting ``MONO_THREADS_PER_CPU`` to a larger number (ex. 2000). Install libuv ^^^^^^^^^^^^^ `Libuv `_ is a multi-platform asynchronous IO library that is used by :ref:`kestrel`, a cross-platform HTTP server for hosting ASP.NET 5 web applications. To build libuv you should do the following:: sudo apt-get install make automake libtool curl curl -sSL https://github.com/libuv/libuv/archive/v1.8.0.tar.gz | sudo tar zxfv - -C /usr/local/src cd /usr/local/src/libuv-1.8.0 sudo sh autogen.sh sudo ./configure sudo make sudo make install sudo rm -rf /usr/local/src/libuv-1.8.0 && cd ~/ sudo ldconfig .. note:: ``make install`` puts ``libuv.so.1`` in ``/usr/local/lib``, in the above commands ``ldconfig`` is used to update ``ld.so.cache`` so that ``dlopen`` (see ``man dlopen``) can load it. If you are getting libuv some other way or not running ``make install`` then you need to ensure that dlopen is capable of loading ``libuv.so.1``. Installing on CentOS 7 -------------------------------------------- The following instructions were tested using CentOS 7. Other versions of CentOS or other Red Hat based distros are unlikely to work correctly. Install the .NET Version Manager (DNVM) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Use the .NET Version Manager (DNVM) to install different versions of the .NET Execution Environment (DNX) on Linux. 1. Install ``unzip`` if you don't already have it:: sudo yum install unzip 2. Download and install DNVM:: curl -sSL https://raw.githubusercontent.com/aspnet/Home/dev/dnvminstall.sh | DNX_BRANCH=dev sh && source ~/.dnx/dnvm/dnvm.sh Once this step is complete you should be able to run ``dnvm`` and see some help text. Install the .NET Execution Environment (DNX) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ The .NET Execution Environment (DNX) is used to build and run .NET projects. Use DNVM to install DNX for `Mono `_ (see :doc:`choosing-the-right-dotnet`). .. note:: DNX support for .NET Core is not available for CentOS, Fedora and derivative in this release, but will be enabled in a future release. **To install DNX for Mono:** 1. Install `Mono `__ via the ``mono-complete`` package. 2. Ensure that the ``ca-certificates-mono`` package is also installed as `noted `__ in the Mono installation instructions. 3. Use DNVM to install DNX for Mono:: dnvm upgrade -r mono By default DNVM will install DNX for Mono if no runtime is specified. .. note:: Restoring packages using DNX on Mono may fail with multiple canceled requests. You may be able to work around this issue by setting ``MONO_THREADS_PER_CPU`` to a larger number (ex. 2000). Install Libuv ^^^^^^^^^^^^^ `Libuv `_ is a multi-platform asynchronous IO library that is used by :ref:`kestrel`, a cross-platform HTTP server for hosting ASP.NET 5 web applications. To build libuv you should do the following:: sudo yum install automake libtool wget wget http://dist.libuv.org/dist/v1.8.0/libuv-v1.8.0.tar.gz tar -zxf libuv-v1.8.0.tar.gz cd libuv-v1.8.0 sudo sh autogen.sh sudo ./configure sudo make sudo make check sudo make install ln -s /usr/lib64/libdl.so.2 /usr/lib64/libdl ln -s /usr/local/lib/libuv.so.1.0.0 /usr/lib64/libuv.so Using Docker ------------ The following instructions were tested with Docker 1.8.3 and Ubuntu 14.04. Install Docker ^^^^^^^^^^^^^^ Instructions on how to install Docker can be found in the `Docker Documentation `_. Create a Container ^^^^^^^^^^^^^^^^^^ Inside your application folder, you create a ``Dockerfile`` which should looks something like this:: # Base of your container FROM microsoft/aspnet:latest # Copy the project into folder and then restore packages COPY . /app WORKDIR /app RUN ["dnu","restore"] # Open this port in the container EXPOSE 5000 # Start application ENTRYPOINT ["dnx","-p","project.json", "web"] You also have a choice to use CoreCLR or Mono. At this time the ``microsoft/aspnet:latest`` repository is based on Mono. You can use the `Microsoft Docker Hub `_ to pick a different base running either an older version or CoreCLR. Run a Container ^^^^^^^^^^^^^^^ When you have an application, you can build and run your container using the following commands:: docker build -t yourapplication . docker run -t -d -p 8080:5000 yourapplication Related Resources ----------------- - :doc:`/tutorials/your-first-mac-aspnet` - :doc:`/fundamentals/index`