Requisits previs
Afegiu el feed de productes .NET al sistema
Instal·leu l'últim SDK de .NET amb YUM
Creeu una aplicació web .NET Core
(Opcional): Configura el supervisor per mantenir la teva aplicació web .NET Core en línia
(Opcional): instal·leu Nginx com a servidor intermediari invers
Configura les regles del tallafoc
.NET Core és un marc de desenvolupament multiplataforma de codi obert redissenyat mantingut per Microsoft i la comunitat .NET en constant creixement. Amb l'ajuda de .NET Core, els desenvolupadors poden crear fàcilment aplicacions modernes d'alt rendiment en tot tipus de plataformes.
En aquest article, us mostraré com instal·lar .NET Core en una instància de servidor CentOS 7 i després desplegar una aplicació web .NET Core funcional completa.
Requisits previs
Afegiu el feed de productes .NET al sistema
Com a marc de desenvolupament multiplataforma, .NET Core proporciona binaris precompilats per a diversos sistemes operatius. A CentOS 7, podeu configurar un repositori .NET YUM signat oficialment executant les ordres següents com a usuari sudo:
sudo rpm --import https://packages.microsoft.com/keys/microsoft.asc
sudo sh -c 'echo -e "[packages-microsoft-com-prod]\nname=packages-microsoft-com-prod \nbaseurl= https://packages.microsoft.com/yumrepos/microsoft-rhel7.3-prod\nenabled=1\ngpgcheck=1\ngpgkey=https://packages.microsoft.com/keys/microsoft.asc" > /etc/yum.repos.d/dotnetdev.repo'
Instal·leu l'últim SDK de .NET amb YUM
Tenint el repositori .NET YUM al seu lloc, instal·leu el darrer SDK de .NET, inclòs .NET Core i altres dependències, a la vostra màquina:
sudo yum update -y
sudo yum install libunwind libicu -y
sudo yum install dotnet-sdk-2.1.4 -y
Per confirmar el resultat, podeu crear i executar una aplicació .NET Core de demostració "Hello World":
cd
dotnet new console -o helloworldApp
cd helloworldApp
dotnet run
L' dotnet new console -o helloworldAppordre crearà un directori anomenat helloworldAppal vostre directori d'inici i després utilitzarà la consoleplantilla per generar fitxers d'aplicacions al directori acabat de crear.
En executar l' dotnet runordre, veureu el Hello World!missatge a la consola.
Creeu una aplicació web .NET Core
Ara, creeu i executeu una aplicació .NET Core del tipus razor. Només recordeu que "Razor Pages" és una nova plantilla d'aplicació de .NET Core MVC que està dissenyada per a escenaris orientats a pàgines:
cd
dotnet new razor -o myfirstwebapp
cd myfirstwebapp
dotnet run
En executar l' dotnet runordre anterior, iniciareu una aplicació web .NET Core escoltant a: http://localhost:5000.
Si voleu confirmar que l'aplicació web està en funcionament, tot i que es troba en una instància de servidor sense GUI, encara podeu obrir una nova consola de terminal i introduir-la curl http://localhost:5000per veure el codi font de la pàgina d'inici de l'aplicació web.
Després, podeu prémer CTRL+ Cper tancar l'aplicació web .NET Core.
Per materialitzar la vostra aplicació web, heu d'editar fitxers dins del directori de l'aplicació. Podeu obtenir més detalls a la pàgina oficial del document .NET .
Un cop fetes totes les tasques de desenvolupament, podeu utilitzar les ordres següents per publicar la vostra aplicació web:
cd ~/myfirstwebapp
dotnet publish
Podeu trobar l'aplicació web publicada al ~/myfirstwebapp/bin/Debug/netcoreapp2.0directori.
(Opcional): Configura el supervisor per mantenir la teva aplicació web .NET Core en línia
Es produeixen bloquejos de processos. Per mantenir la vostra aplicació web en línia, és una bona idea tenir una eina de gestió de processos, com ara Supervisor, per supervisar i reiniciar els processos de l'aplicació web bloquejats.
A CentOS 7, podeu instal·lar Supervisor mitjançant YUM:
sudo yum install supervisor -y
A continuació, heu de configurar un fitxer de configuració de Supervisor dedicat per a la vostra aplicació web:
cd /etc/supervisord.d
sudo vi myfirstwebapp.conf
Omple el fitxer:
[program:myfirstwebapp]
command=dotnet myfirstwebapp.dll
directory=/home/sudouser/myfirstwebapp/bin/Debug/netcoreapp2.0/
environment=ASPNETCORE__ENVIRONMENT=Production
user=root
stopsignal=INT
autostart=true
autorestart=true
startsecs=1
stderr_logfile=/var/log/myfirstwebapp.err.log
stdout_logfile=/var/log/myfirstwebapp.out.log
Desa i surt:
:wq!
A continuació, heu de modificar el supervisordfitxer de configuració predeterminat per incloure el fitxer de configuració que hem creat:
sudo cp /etc/supervisord.conf /etc/supervisord.conf.bak
sudo vi /etc/supervisord.conf
Busca l'última línia:
files = supervisord.d/*.ini
Substituïu-lo:
files = supervisord.d/*.conf
Desa i surt:
:wq!
Inicieu el Supervisor i configureu-lo perquè s'iniciï automàticament a l'inici del sistema:
sudo systemctl start supervisord.service
sudo systemctl enable supervisord.service
Carregueu la nova configuració del supervisor:
sudo supervisorctl reread
sudo supervisorctl update
Ara, podeu utilitzar l'ordre següent per mostrar l'estat de l'aplicació:
sudo supervisorctl status
La sortida tindrà el següent aspecte:
myfirstwebapp RUNNING pid 3925, uptime 0:08:45
A continuació, podeu provar de matar el procés de l'aplicació especificant el pid 3925:
sudo kill -s 9 3925
Espereu una estona i torneu a comprovar l'estat:
sudo supervisorctl status
Aquesta vegada, la sortida indicarà que l'aplicació es va trencar i es va iniciar automàticament:
myfirstwebapp RUNNING pid 3925, uptime 0:00:06
(Opcional): instal·leu Nginx com a servidor intermediari invers
Per tal de facilitar l'accés dels visitants, podeu instal·lar Nginx com a servidor intermediari invers per passar trànsit web al port 5000.
Instal·leu Nginx mitjançant YUM:
sudo yum install nginx -y
Editeu el fitxer de configuració predeterminat de Nginx de la següent manera:
sudo cp /etc/nginx/nginx.conf /etc/nginx/nginx.conf.bak
sudo vi /etc/nginx/nginx.conf
Cerqueu el segment següent dins del http {}segment:
location / {
}
Inseriu sis línies de configuració de proxy invers entre les claus tal com es mostra a continuació:
location / {
proxy_pass http://127.0.0.1:5000;
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
Desa i surt:
:wq!
Inicieu el servei Nginx i, a continuació, configureu-lo perquè s'iniciï a l'inici del sistema:
sudo systemctl start nginx.service
sudo systemctl enable nginx.service
Configura les regles del tallafoc
Abans que els visitants puguin accedir a l'aplicació web .NET Core als ports 80i 443, heu de modificar les regles del tallafoc tal com es mostra a continuació:
sudo firewall-cmd --zone=public --permanent --add-service=http
sudo firewall-cmd --zone=public --permanent --add-service=https
sudo firewall-cmd --reload
Això completa la configuració de l'aplicació. Ara ja esteu preparat per navegar per la vostra aplicació web .NET Core a http://203.0.113.1.