Introduction
The last ASP.NET version claim itself officially compatible with Mac and Linux in order to open web development of Microsoft sphere to new developer communities. Microsoft impulse, because of his last announcements, a crossplatform effort in the ASP.NET area. During this article, we are going to explore what is currently necessary to run an ASP.NET 5 website on Ubuntu.
data:image/s3,"s3://crabby-images/62738/62738dea73bea05c3981d587f63500e3cd80fed2" alt="The Ubuntu logo"
I wrote this article using the ASP.NET 5 beta2, so if you experience some inconveniences have a look at the Mark Rendle's article about what have changed for Linux in beta3.
Mono Project
The Mono Project, powered by Xamarin, is a project which tends to make the .NET Framework available to Microsoft’s foreign platforms. The “light” version of .NET, .NET Core, is not yet officially compatible with Mac and Linux, but it’s a matter of time. For this demonstration, we will use Mono to run our ASP.NET website on Ubuntu.
We will start by installing Mono. First of all, execute this command to add the Mono’s GPG key to the packages manager.
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 3FA7E0328081BFF6A14DA29AA6A19B38D3D831EF
data:image/s3,"s3://crabby-images/ef748/ef7483dd38bfeef962bd9dd538791f52cdb7c9b7" alt="image"
Then add the required repositories in the configuration file.
echo "deb http://download.mono-project.com/repo/debian wheezy main" | sudo tee /etc/apt/sources.list.d/mono-xamarin.list
echo "deb http://download.mono-project.com/repo/debian wheezy-apache24-compat main" | sudo tee -a /etc/apt/sources.list.d/mono-xamarin.list
Finally, install Mono.
sudo apt-get install mono-complete
data:image/s3,"s3://crabby-images/84dee/84dee4dfdc5f905af8e91766f28058499e1817d5" alt="image"
This procedure is also detailled here.
K*
You can launch ASP.NET 5 without using IIS nor Kestrel (the IIS Express equivalent for Mac and Linux). To do so, you need to use KVM. This CLI allow us to choose, site by site, the framework version we want to use. To install it, just run this command.
apt-get install curl
mkdir .kre
curl -sSL https:
data:image/s3,"s3://crabby-images/7255d/7255dbb0ce5114330b44aba092a811f2876f7119" alt="image"
Then run this update command.
kvm upgrade
data:image/s3,"s3://crabby-images/a42b1/a42b1849e71b4d311afbe93c448f599364005eda" alt="image"
This procedure can be found here too. We finally need to add Microsoft’s and Nuget’s specific HTTPS certificates to allow the dependencies resolving.
CERTMGR=/usr/local/bin/certmgr
sudo $CERTMGR -ssl -m https:
sudo $CERTMGR -ssl -m https:
sudo $CERTMGR -ssl -m https:
mozroots --import --sync
data:image/s3,"s3://crabby-images/eae75/eae754eeb8ae177e9d8096503f2536ba16a9bfe2" alt="image"
We can observe, using this command, the .NET Framework list which are available on this machine.
kvm list
data:image/s3,"s3://crabby-images/2f74d/2f74d594db804e9f25bafa7936b3e6946ccd80cd" alt="image"
Run the website
For this demonstration, we will use the official sample project HelloMvc available on GitHub.
![image_thumb[4]](http://www.codeproject.com/KB/aspnet/878984/ubuntu-startupclass.png)
We will start by resolving the project dependencies. Run the following command at the “project.json” file location.
kpm restore
data:image/s3,"s3://crabby-images/fc551/fc551c0a3f5110d9d550dddd97d1842329c782de" alt="image"
This process can take some time since it gather the dependencies of our project recursively.
At the moment, we will need to run our website using Kestrel, but this will not be necessary anymore when the final versions of .NET Core and ASP.NET 5 will be released. To run Kestrel on Linux for now, we need to apply a manual fix which consist in compiling the “libuv” package, thanks to Carolyn Van Slyck (make sure you already installed the “gyp” and “build-essential” packages).
data:image/s3,"s3://crabby-images/3fe5c/3fe5ccc5755524d4ff57b3238d85816cc8b10826" alt="image"
wget http:
tar -xvf libuv-v1.0.0-rc2.tar.gz
cd libuv-v1.0.0-rc2/
./gyp_uv.py -f make -Duv_library=shared_library
make -C out
sudo cp out/Debug/lib.target/libuv.so /usr/lib/libuv.so.1.0.0-rc2
sudo ln -s libuv.so.1.0.0-rc2 /usr/lib/libuv.so.1
We can now run our website using Kestrel.
k kestrel
data:image/s3,"s3://crabby-images/28024/28024e94fe17fbddc9adab18edc09dd6327c2be0" alt="image"
To access it, just browse this URL: http://localhost:5004
data:image/s3,"s3://crabby-images/908bd/908bdfb9477de17936f5c381d7b493f0326be5f5" alt="image"
Update the website
In order to show you that it is possible du develop an ASP.NET 5 website without Visual Studio, we are going to modify the home page of our project. Open the “View/Home/index.cshtml” file in the text editor you want.
data:image/s3,"s3://crabby-images/ca65c/ca65c8d86b690bcf0a33ee94f48533b13e5b0649" alt="image"
Update the title with “ASP.NET runs Great on Ubuntu !” and the result is available just refreshing your web browser, without compilation of website restart.
data:image/s3,"s3://crabby-images/34f3b/34f3b80e7641037476618ad06a4a98621041933c" alt="image"
To go further, if you work on Linux or Mac, I recommand you to use Sublime Text and to install the OmniSharp extension for an enhanced developer experience.
There are tools that can ease this kind of development on Linux. We are going to see that it is possible to configure our own file creation’s shell extensions through Nautilus, the default file manager on Ubuntu.
Nautilus
Firstly, we need to install the “nautilus-actions” package.
sudo apt-get install nautilus-actions
data:image/s3,"s3://crabby-images/30f12/30f12b76f62dbebd63c7ac0d1c096c788c4a5771" alt="image"
Then restart Nautilus and start Nautilus-Actions using the following command.
nautilus -q
nautilus-actions-config-tool
data:image/s3,"s3://crabby-images/25bfe/25bfee613462bc265bb706bcf21fcc6ed1820d1e" alt="image"
Yeoman
Yeoman is a CLI designed to improve web development on new file content initialization, Grunt task management, Bower package management, etc. To install it, after NodeJS and NPM, run the following command.
sudo apt-get install nodejs-legacy npm
sudo npm install -g yo generator-aspnet
data:image/s3,"s3://crabby-images/32e8d/32e8da92217fa4a4f44e434ef144bacff1aedb75" alt="image"
If everything went well, the “yo aspnet” command should print this prompt.
data:image/s3,"s3://crabby-images/00f69/00f69f3c73ecc7d7960be0d94689dcda2a6a87f1" alt="image"
Using Yeoman you can ask for multiple file type creations. This list if available through the following command.
yo aspnet -help
data:image/s3,"s3://crabby-images/e4ece/e4ece1545f48dddd58789ebf3098512b4eef8e30" alt="image"
For now, we will create a shortcut to create an MVC project.
data:image/s3,"s3://crabby-images/48789/4878951e214603f5070beba66d0204728fa17595" alt="image"
Then, fill the corresponding command.
data:image/s3,"s3://crabby-images/d2396/d23967248900f72aac5df4985ba659c7cce8b553" alt="image"
Finally, through the « Preferencies » menu, disable the default submenu creation.
data:image/s3,"s3://crabby-images/00832/00832bf06438d1057a35d9fe6881277d22b642cd" alt="image"
This new shortcut we just created is now available when you click right in the file explorer.
data:image/s3,"s3://crabby-images/96ca7/96ca77e1491c055ef321821ad103c05b2127dc50" alt="image"
When you need it, just follow the prompt.
data:image/s3,"s3://crabby-images/c9616/c9616f026cddfd765807ab67baf8df6b22113ea8" alt="image"
For more information on Nautilus-Actions, you can find it here. About Yeoman and ASP.NET, see the original article and the NPM package page. We are now getting further and create shortcuts for files that need user inputs.
We will focus on the MVC View creation. The corresponding command is this.
yo aspnet:MvcView <name>
Zenity
Zenity is a tool that you can use to print dialog windows from a shell script. It should be already installed if you use the last version of Ubuntu. If this is not the case, just run this command.
sudo apt-get update
sudo apt-get install zenity
If you run the next command, you should see an input popup asking for a filename.
zenity --title="Filename of your new MVC View" --entry
To redirect this input to our Yeoman command, nothing easier. Just use a variable to store this value and sent it as a parameter.
filename=$(zenity --title="Filename of your new MVC View" --entry) ; yo aspnet:MvcView "$filename"
data:image/s3,"s3://crabby-images/cb549/cb549eee49f68cccd6019a1ffc8f17956a0b2062" alt="image"
If we observe the file explorer, the new view was effectively created with the filename we specified in the dialog window.
data:image/s3,"s3://crabby-images/0f91e/0f91e4ba870b8c8cd4f0738c15b907f9f3a5e64b" alt="image"
We will create a script file “createMvcView.sh” wherein we will store the script we just built.
data:image/s3,"s3://crabby-images/1cd53/1cd53e3365aca0a6e3cc45b2869274cdbf57bc5a" alt="image"
Then we need to add the execution right to this file properties.
data:image/s3,"s3://crabby-images/98f23/98f23f9415ca17941a3d44f8d07fe32e84b07eca" alt="image"
As for the “new project” prompt, let’s create a new Nautilus-Actions command.
data:image/s3,"s3://crabby-images/2ba64/2ba64cf01abd80177b8cf29969056b09e93acab8" alt="image"
This time, we will specify the bash script’s path we just created.
data:image/s3,"s3://crabby-images/cbb1b/cbb1b3e05da7c4626622a734322cf413737b7e05" alt="image"
If we invoke the contextual menu of the file explorer, we can see our command.
data:image/s3,"s3://crabby-images/44624/44624adc434cd37f7baa2b47f6ff2736fa6970cc" alt="image"
You now have all the skills to add shortcuts to the other file type creations available through this Yeoman generator. To go further, I invite you to explore this GitHub repository which allow you to easily install a complete list of these shortcuts, using the principle we learnt, on Ubuntu.
We will now overview how to use NuGet, the packages manager usually integrated to Visual Studio, using command line.
Nuget CLI
data:image/s3,"s3://crabby-images/5010e/5010e6b737275ebd409510bb95e9f867eb76e7d4" alt="https://www.nuget.org/Content/Logos/nugetlogo.png"
You can install the NuGet CLI and authorize HTTPS access using the following command.
sudo apt-get install nuget mono-devels
mozroots --import --sync
You can then list all the packages available using this other one.
nuget list
data:image/s3,"s3://crabby-images/2fe48/2fe48bd3aabfee5c900762d7126a97856b4d19dc" alt="image"
Get Bootstrap
To add Bootstrap to your project from a NuGet package, just run this command at the location we created our application earlier, using “yo aspnet”.
nuget install bootstrap
data:image/s3,"s3://crabby-images/14327/14327fa64bd376601ae2b6f35391a8f576055e93" alt="image"
So we are able to use the same packages as in Visual Studio, except for the Mono and ASP.NET 5 compatibility, to develop using the .NET Framework. With .NET Core, this packages list should become more and more cross-platform.
Raspberry Pi
The Raspberry Pi is a microcomputer whose first model appeared in February 2012. Recently, the second version was released with very interesting characteristics for the same price of approximatively 40$: a 900MHz quad-core ARM Cortex-A7 CPU with 1GB RAM.
data:image/s3,"s3://crabby-images/8507a/8507a09ee45f78b964c77a4da6df46905ac82ccb" alt="model-b-plus"
Linux ARMv7
After several searches, I found an Ubuntu derived distribution compatible with the Raspberry. To install this image to your SD card, just follow this guide. When it’s done, let’s connect your Raspberry to power supply and plug a screen and a keyboard. The system already have a username / password: “linaro” / “linaro”.
data:image/s3,"s3://crabby-images/7b6e7/7b6e70568ac89268efea9f8b84fa64e4df3dff82" alt="image"
We are going to install Xfce, the Mozilla Firefox browser and the Gnome terminal, even if it is not essential, in order to have a more user friendly workspace. To do this, run the following command.
sudo apt-get install xfce4 firefox gnome-terminal
startxfce4
data:image/s3,"s3://crabby-images/be5da/be5daa2dc79be8d7f5254e341c33f72b087cb7af" alt="WP_20150217_21_12_15_Pro"
This installation should take several minutes to finally display a desktop environment.
data:image/s3,"s3://crabby-images/f7b37/f7b373db8d82c51906d1100f5ae44921b331aaae" alt="unnamed"
We will start by creating a new partition on the disk image we just installed (limited to 3Go), or we risk to encounter some space disk issues while we will install all our dependencies. We are going to use Gparted.
data:image/s3,"s3://crabby-images/771d9/771d9547e4d8e5d37b43dfcb227337b1509fa9cf" alt="image (1)"
ASP.NET 5
Since we already saw how to run ASP.NET 5 on Ubuntu, follow this script which you should run on the new partition we just created.
# MONO
sudo apt-get install build-essential
wget http:
tar -xvf mono-3.8.0.tar.bz2
cd mono-3.8.0/
./configure --prefix=/usr/local
make
sudo make install
# CERTIFICATES HTTPS
CERTMGR=/usr/local/bin/certmgr
sudo $CERTMGR -ssl -m https:
sudo $CERTMGR -ssl -m https:
sudo $CERTMGR -ssl -m https:
mozroots --import --sync
# K*
sudo apt-get install curl unzip gyp
mkdir .kre
curl -sSL https:
kvm upgrade
# LIBUV
wget http:
tar -xvf libuv-v1.0.0-rc2.tar.gz
cd libuv-v1.0.0-rc2/
./gyp_uv.py -f make -Duv_library=shared_library
make -C out
sudo cp out/Debug/lib.target/libuv.so /usr/lib/libuv.so.1.0.0-rc2
sudo ln -s libuv.so.1.0.0-rc2 /usr/lib/libuv.so.1
To check our installation went well, just run this command to list all the versions of the .NET Framework available.
kvm list
data:image/s3,"s3://crabby-images/0cec8/0cec848111332419cbb68486b9fc36cb93d90951" alt="image"
Mono Version
Exceptions may occurred due to the Mono version which could not be recent enough to run KVM, KPM or Kestrel. The exceptions I encountered are very several and various. If it happens, I recommend you to install the last version of Mono available on GitHub, compiling from the sources.
sudo apt-get install git autoconf libtool automake build-essential mono-devel gettext
PATH=$PREFIX/bin:$PATH
git clone https:
cd mono
./autogen.sh --prefix=$PREFIX
make
make install
Once you did that you should prefix all your commands by “LD_LIBRARY_PATH=$$path$$” where “$$path$$” is the last Mono installation directory, like bellow.
LD_LIBRARY_PATH=/etc kpm restore
LD_LIBRARY_PATH=/etc k kestrel
Run on the Raspberry
To get our MVC sample project, we are going to use the official GitHub one.
wget https:
unzip master.zip
Finally, run the following command through the HelloMvc location.
LD_LIBRARY_PATH=/etc kpm restore
LD_LIBRARY_PATH=/etc k kestrel
data:image/s3,"s3://crabby-images/34014/340145828dfba8dc35e97074a158074a445c732f" alt="unnamed"
Conclusion
As you can see, ASP.NET 5 was designed to be run on several platforms, and it’s already available on Alpha 3 version. As this, the Raspberry Pi greatly improved his performances and his compatibility due to his architecture.
Cross-platform is not yet available without Mono, because of the .NET Core Framework development still pending, but we can already see what ASP.NET 5 will look like on that platforms. Microsoft teams, .NET / ASP.NET / Visual Studio, realized a wonderful work in order to optimize and open .NET development to new frontiers.