Przejdź do głównej zawartości

ASP.NET Core MVC - wdrożenie na Linuxie krok po kroku

Dzisiaj skupimy się na wdrożeniu aplikacji ASP.NET Core MVC.
Po przeczytaniu tego artykułu będziesz potrafił uruchomić swoją pierwszą aplikację ASP.NET Core na maszynie wirtualnej z systemem Ubuntu 14.


Załóżmy, że mamy nasza aplikację gotową i chcemy ją uruchomić.
Jak najłatwiej to zrobić? Podczas debugowania możemy roboczo wykorzystać Visual Studio do uruchomienia aplikacji na IIS Express.
Jednak w warunkach produkcyjnych kiedy chcemy wdrożyć aplikację na systemie Linux, musimy poszukać innego rozwiązania.
Dlaczego? Bo Linux nie będzie obsługiwał ani visual Studio ani IIS Express, ponadto jeśli korzystamy z Continuous Deployment, to chcemy wdrożenie robić z poziomu konsoli.
Jak pisałem w poprzednich postach, wraz z nadejściem ASP.NET Core MVC, mamy możliwość wdrażania aplikacji napisanych w C# na platformie Linux.
To niezwykle istotne, bo przynosi ogromne korzyści, choćby dlatego, że ceny hostingu są kilka razy niższe dla maszyn z Linuxem niż z Windowsem.

1) Framework-dependent deployments (FDD) - ta opcja wymaga aby na maszynie docelowej był zainstalowany dotnet core.
2) Self-contained deployments (SCD) - ta opcja nie wymaga aby dotnet był zainstalowany na docelowej maszynie.

Ja korzystam aktualnie z opcji FDD, uprzednio instalując dotnet framework na maszynie wirtualnej ale gdybym miał dużo serwerów produkcyjnych to poważnie rozważyłbym opcję SCD.
Dzięki temu zaoszczędziłbym mnóstwo czasu, bo nie musiałbym instalować dotnet frameworka na każdej z maszyn.
Gdyby ktoś był zainteresowany instalacją dotnet core na systemie Ubuntu 14 to instalacja sprowadza się do wykonania poleceń w konsoli:
sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv-keys 417A0893
sudo apt-get update
sudo apt-get install dotnet-dev-1.0.1

Po zakończeniu instalacji możemy upewnić się, że wszystko działa wywołując polecenie:
dotnet

Przypomnę, że aplikacja Perfect Life składa się z 2 części:
- aplikacja mobilna opracowana w Xamarin Forms - uruchamiana na telefonie z Androidem(w przyszłości także na iOS)
- aplikacja serwerowa, web service, opracowana w ASP.NET Core MVC, która jest uruchamiana na serwerze z systemem operacyjnym Linux

Zapewne każdy inżynier potwierdzi moje słowa, że zadania żmudne, które są podatne na błędy ludzkie należy automatyzować.
Zrobiłem to również w przypadku wdrożenia, które dzięki Visual Stuudio Team Services jest procesem w pełni automaatycznym. A działa to w następujący sposób:

Wdrożenie aplikacji serwerowej odbywa się za pomocą VSTS(visualstudio.com), gdzie stworzyłem definicję builda. Każdy build jest wyzwalany w momencie gdy wykonam polecenie: git push origin master. Wtedy moje najnowsze zmiany trafiają do githuba. W cigu kilku sekund VSTS zostaje powiadomiony przez githuba o nowych zmianach, i rozpoczyna się budowanie projektu za pomocą polecenia dotnet publish.
W wyniku otrzymujemy jeden folder ze skompilowaną wersją naszej aplikacji w postaci pliku .dll oraz wszystkie zależnośći, czyli biblioteki, które wykorzystuje nasza aplikacja.
Taki folder VSTS kopiuje na docelową maszynę wirtualną z systemem Ububtu 14, a następnie uruchamia poleceniem: sudo nohup dotnet .dll kestrel > /dev/null 2>&1 &
Oczywiście testowo możemy zalogować się na tę maszynę za pomocą programu PUTTY, który jest klientem SSH instalowanym na Windowsie i uruchomić krótsze polecenie:
dotnet .dll
Jednak wtedy po zakończeniu sesji Putty zamknie połączenie i nasza aplikacja ASP.NET Core MVC się wyłączy.
Dlatego polecam stosować tę dłuższą wersję polecenia, która uruchamia proces w tle i możemy bezpiecznie zamknąć sesję SSH a serwer będzie działać dalej.

Zachęcam wszystkich programistów .NET do eksperymentów z ASP.NET Core już teraz, bo warto go znać.
Wiem, ze nowe aplikacje już powstają w ASP.NET Core. Spodziewam się również, że coraz częściej będziemy spotykali się migracjami starych projektów do najnowszej wersji .NET Core.
Jako źródło wiedzy o ASP.NET MVC Core najlepsza na początek będzie książką Adama Freemana: http://www.apress.com/us/book/9781484203989



Zachęcam do lektury.

Komentarze

  1. No to grubo, że można już odpalać serwisy webowe w technologiach Microsoftowych w linuxie. Kto by pomyślał.

    OdpowiedzUsuń

Prześlij komentarz

Popularne posty z tego bloga

Unleash the power of ChatGPT in your C# applications with NGpt - C# OpenAI GPT client

Meet NGpt - OpenAI GPT C# client library that will make your conversations with ChatGPT a breeze! Have you ever been struggling building your own smart AI application in C#? Well, now you can use ChatGpt inside your application! Introducing NGpt, the powerful .NET library that lets you integrate ChatGPT seamlessly into your C# applications. No more nigts spent on building your own AI solitions, no more convoluted logic and building complex business rules - just pure AI bliss. In this blog post, we'll dive into the wonderful world of NGpt and show you how easy it is to use. You might even find a few laughs along the way. The Magic of NGpt NGpt is a transient fault-tolerant .NET 6 OpenAI client that simplifies ChatGPT integration for C# developers. It's like your friendly neighborhood Spider-Man - always there to help you out when you need it most. With just your OpenAI API key, you can start coding AI applications in C# faster than you can say "Peter Parker." Let&

Specflow czyli BDD w praktyce

Dzisiaj pokażę w praktyce w jaki sposób zbieram wymagania korzystając z narzędzia Specflow. Na początku przypomnę nasze historie użtkownika. Potem skonfigurujemy dodatek Specflow Visual Studio. Na końcu pokażę jak wygląda język Gherkin i zaimplementujemy pierwszą historię użytkownika US1. Oto lista funkcjonalności, które będę implementował w aplikacji Perfect Life: US1: Jako użytkownik aplikacji mobilnej chcę ekran logowania aby mieć możliwość zapisywania swoich postępów US2: Jako użytkownik aplikacji mobilnej chcę mieć kalkulator wskaźnika BMI aby móc mierzyć poziom swojej kondycji US3: Jako użytkownik aplikacji mobilnej chcę widzieć wykresy aby móc wizualnie interpretować swoje postępy US4: Jako użytkownik aplikacji mobilnej chcę mieć możliwość rozwiązania quizu, żeby zbadać wskaźnik Body Age US5: Jako użytkownik aplikacji mobilnej chcę pobierać pliki PDF aby mieć dostęp do planów dietetycznych US6: Jako administrator aplikacji chcę zapisywać dane telemetryczne aby móc an

How to call webAPI service in Xamarin?

In the last few weeks I worked on the web service written in ASP.NET Core. I had a plan to connect the Xamarin application to this web service. Today I'll show you how you can connect your Xamarin app to web service located anywhere in the cloud. First we need to have a web service deployed, which is our server-side part of the system. I describe how to create a web service in ASP.NET COre in my previous post: . Today I'll demonstrate how it works from client perspective, in our case it's Xamarin.Forms application but web application or desktop application can use exactly the same code. This is the great benefit of using C# language - we can use the same code on multiple platforms. OK, I bet you're interested in the code. Let's jump to the code. This is the final version of the client class that I can use to save and retrieve data from web service: The class design is straightforward. It has 2 public methods which encapsulate 2 functionalities: adding s