標籤:cache .net function os x directory linux 模式 base 複製
出處;ASP.NET Core 網站發布到Linux伺服器
長期以來,使用.NET開發的應用只能運行在Windows平台上面,而目前國內蓬勃發展的互連網公司由於成本的考慮,大量使用免費的Linux平台,這就使得.NET空有一身絕技但無法得到廣大的施展空間,.NET平台被認為只適合開發企業內部應用系統。
2016年6月27日,微軟正式發布.NET Core 1.0、ASP.NET 1.0和Entity Framework Core 1.0,通吃 Windows、OS X和Linux三大作業系統。.NET Core作為新一代跨平台、開源的.NET平台備受矚目,有人說,.NET程式員的春天來了。
本文將介紹如何把ASP.NET Core的網站發布到Linux伺服器上。
環境準備
本文用到的作業系統和軟體版本如下:
Visual Studio 2017企業版
.NET Core 1.1
CentOS 7 X64
建立發布ASP.NET Core網站項目
1.建立項目
開啟VS2017,建立項目,選擇ASP.NET Core Web應用程式(.NET Core)
選擇Web應用程式模板。
直接F5測試網站是否正常。
2.增加Url網址設定檔
項目預設使用http://localhost:5000的Url進行偵聽,我們可以增加一個設定檔來隨時修改Url地址。
在項目根目錄中增加一個hosting.json檔案,檔案內容如下(8080連接埠可以改成自己喜歡的):
{ "server.urls": "http://*:8080"}
編輯Program.cs檔案,修改為內容如下:
public static void Main(string[] args) { var config = new ConfigurationBuilder() .SetBasePath(Directory.GetCurrentDirectory()) .AddJsonFile("hosting.json", optional: true) .Build(); var host = new WebHostBuilder() .UseKestrel() .UseConfiguration(config) .UseContentRoot(Directory.GetCurrentDirectory()) .UseIISIntegration() .UseStartup<Startup>() .UseApplicationInsights() .Build(); host.Run(); }
3.發布項目
右鍵項目-發布,選擇檔案夾模式。
把發布的PublishOutput檔案夾壓縮成zip格式,上傳到CentOS伺服器。
安裝.NET Core
1.下載最新的.NET Core版本
官網:https://www.microsoft.com/net/download/linux
我使用的版本是dotnet-centos-x64.1.1.1.tar.gz。
2.上傳並解壓下載的安裝檔案。
$ # 建立dotnet檔案夾$ mkdir ~/dotnet$ # 複製dotnet安裝檔案到dotnet檔案夾下$ cp dotnet-centos-x64.1.1.1.tar.gz ~/dotnet$ # 解壓安裝檔案$ tar -xzf ~/dotnet/dotnet-centos-x64.1.1.1.tar.gz$ # 添加軟串連,可以在全域使用$ ln -s ~/dotnet/dotnet /usr/local/bin$ # 測試安裝是否成功,成功會顯示版本號碼$ dotnet –version
啟動網站
$ #解壓之前上傳的網站壓縮檔,如果沒有安裝unzip,運行yum install -y unzip zip安裝$ unzip ~/dotnet/PublishOutput.zip$ #先關閉防火牆$ systemctl stop firewalld.service$ #啟動網站$ cd PublishOutput$ dotnet TestAspNetCoreWeb.dll$ 如果報錯Failed to bind to CoreCLR,運行yum install -y libunwind
啟動成功,可以訪問http://192.168.57.7:8080開啟了(192.168.57.7是虛擬機器IP地址,本地訪問的話也可以使用localhost)。
安裝配置守護進程(Supervisor)
使用Supervisor對ASP.NET Core網站應用程式進行監控,使網站可以持續運行,不然退出Shell後網站就停止了。
$ # 安裝Supervisor$ yum install python-setuptools$ easy_install supervisor$ #配置Supervisor$ mkdir /etc/supervisor$ echo_supervisord_conf > /etc/supervisor/supervisord.conf
修改supervisord.conf檔案,將檔案最後的內容修改如下:
建立目錄conf.d,在目錄下建立檔案TestAspNetCoreWeb.conf
檔案內容如下:
[program:TestDotNetCoreWeb]command=dotnet TestAspNetCoreWeb.dll directory=~/dotnet/PublishOutputautorestart=truestderr_logfile=/var/log/TestDotNetCoreWeb.err.logstdout_logfile=/var/log/TestDotNetCoreWeb.out.log environment=ASPNETCORE_ENVIRONMENT=Production user=rootstopsignal=INT
運行supervisord並查看進程是否生效。
$ supervisord -c /etc/supervisor/supervisord.conf$ ps -ef | grep TestDotNetCoreWeb
設定檔如有修改,使用命令supervisorctl reload重新載入。
安裝配置Nginx
訪問 http://dl.fedoraproject.org/pub/
下載合適版本的epel,並上傳到伺服器。
如:http://dl.fedoraproject.org/pub/epel/7/x86_64/e/epel-release-7-9.noarch.rpm
$ #安裝epel$ rpm -ivh epel-release-7-9.noarch.rpm$ #安裝nginx$ yum install nginx$ #啟動nginx$ systemctl start nginx$ #將nginx添加至SELinux的白名單,否則會報502錯誤。$ yum install policycoreutils-python$ cat /var/log/audit/audit.log | grep nginx | grep denied | audit2allow -M mynginx$ semodule -i mynginx.pp$ #測試nginx是否正常$ curl http://127.0.0.1
修改設定檔/etc/nginx/nginx.conf中server部分為以下內容,配置Nginx偵聽之前的網站。
server { listen 80 ; location / { proxy_pass http://192.168.57.7:8080; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection keep-alive; proxy_set_header Host $host; proxy_cache_bypass $http_upgrade; } error_page 404 /404.html; location = /40x.html { } error_page 500 502 503 504 /50x.html; location = /50x.html { } }
$ #修改完後重新載入設定檔$ nginx -s reload
配置完成後即可使用http://192.168.57.7訪問網站。
ASP.NET Core 網站發布到Linux伺服器(轉)