1.Create a new project using .NET5.
For example: my project is Test20221123.
2.Add a Dockerfile in this project, the file contents as below:
bash
FROM harbor.xxx.com/dotnet/aspnet:5.0
MAINTAINER XXX
ENV ASPNETCORE_ENVIRONMENT=Development
ENV TZ=Asia/Shanghai
ENV LANG=en_US.UTF-8
WORKDIR /app
#RUN dotnet restore
#RUN dotnet publish -c Release -o out -r linux-x64
RUN sed -i 's/DEFAULT@SECLEVEL=2/DEFAULT@SECLEVEL=1/g' /etc/ssl/openssl.cnf
RUN sed -i 's/TLSv1.2/TLSv1/g' /etc/ssl/openssl.cnf
COPY ./out .
ENV ASPNETCORE_URLS http://0.0.0.0:80
ENTRYPOINT ["dotnet", "Test20221123.dll"]
3.Publish the project, please using the following command:
dotnet publish -c Release -o out -r linux-x64
cs
dotnet publish -c Release -o out -r linux-x64
4.Open you wsl and logon with administrator, then execute the commands as below:
bash
sudo service docker start
cd /mnt/d/SourceCode/GitLab/Test20221123
docker login -u "userid" -p "password" harbor.xxx.com
docker build -f Dockerfile -t "harbor.xxx.com/demo/my-app.job:develop-00001" .
docker push "harbor.xxx.com/demo/my-app.job:develop-00001"
docker logout "harbor.xxx.com"
5.Check the docker image which you just pushed on harbor.
6.Deploy a workload on rancher.
7.Troubleshooting
bash
7.1 show the error: 'x509: certificate signed by unknown authority'
echo -n | openssl s_client -showcerts -connect harbor.xxx.com:443 2>/dev/null | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p' > /etc/ssl/certs/harbor.xxx.com.crt