把.net Core 專案遷移到VS2019 for MAC
VS2019 for MAC已經發布很長時間了,本以為專案移過去很麻煩,一直沒有動作,最近呆家裡快發黴了,決定研究研究,沒想到一句程式碼都不需要動,直接完功,這下可以生產了。同學們可以放心整了。
本次平臺的需求:
MAC OS : mac OS Catalina 10.15.3
VS 2019 : VS for Mac community 8.4.8
.net Core : Core 3.1
Sql Server : Docker Sql Server 2019
原平臺:
windows 10+vs2019 community+ core3.1 + sql server 2019
=========================
一、安裝VS 2019
下地地址:https://visualstudio.microsoft.com/zh-hans/downloads/
這裡不管你下載的是專業版,社群版,還是企業版,安裝完成都是社群版,用你的ID登陸後,才會改變版本
安裝很快完成,上手基本沒有難度,和win版一樣,宇宙最強IDE
測試新建一個專案執行,沒有問題。可是之前的專案是sql server 的。於是開始使用Docker
Docker下載地址:https://www.docker.com
二、下載Docker Desktop for MAC 並 安裝執行
配置國內映象源:開啟Docker 偏好設定,在Docker Engine新增地址就可以
(如果不配置那速度直接無法忍受,3k/s下載,我配置了一個阿里雲的,還可以。)
阿里雲容器映象控制檯:進入後,最下面有個映象加速器,會給你一個加速地址。
三、使用Docker
使用Docker 時可以先了解一下常用的命令,這樣可以更加快速
開啟OS 控制檯並在Docker 中開啟Docker Hub
在搜尋裡查詢Sql Server
進入頁面可以看到微軟官方的配置說明和一些版本說明
1.在控制檯輸入:
docker pull mcr.microsoft.com/mssql/server:2019-latest
開始下載映象了,等待完成(好像之前配置的加速對mcr.microsoft.com沒反應,我這裡一直很慢。不知到多會了,反正晚上睡覺去了,第二天早上好了,看了下1.5G左右,下了很長時間。同樣的,安裝mysql只要幾十秒就完成了)
2.檢視映象輸入:docker images
3.執行sql server
控制檯輸入run:(注意一下:這裡密碼必須是強密碼,不然會執行不起來)
docker run -e 'ACCEPT_EULA=Y' -e 'SA_PASSWORD=Admin123456' -p 1433:1433 -d mcr.microsoft.com/mssql/server:2019-latest
控制檯輸入ps檢視執行狀態:
docker ps
現在看到已經執行起來了。OK,開始get專案
四、遷移專案
1.開啟專案或從git下載自己的專案
2.開啟後會還原包,直到還原完成
3.開啟專案的appsettings.json檔案配置和Sql的連結檔案:
{ "ConnectionStrings": { "DefaultConnection": "Server=.;Database=aspnet-AquaWeb;User ID=SA;Password=Admin123456;MultipleActiveResultSets=true", "conn": "Server=.;Database=aspnet-AquaWeb-conn;User ID=SA;Password=Admin123456;MultipleActiveResultSets=true" }, "Logging": { "LogLevel": { "Default": "Warning" } }, "AllowedHosts": "*" }
4.生成執行一下
前方高能,注意,是一句程式碼都沒有改。執行一切正常,提示遷移資料庫後,點一下就直接進入了。
使用者管理用的是identity基礎上做了升級,完全正常。
登陸到後臺後把系統認成了windows19,硬碟容量是用WIM,所以認不到正常,webAPI正常,SignalR正常(因為使用者統計是SignalR做的)
至此完成遷移。寫這個記錄一下二天裡爬過的坑,以防大家入坑。