写在前面

在前段时间尝试过用Jenkins来进行asp.net core 程序在IIS上面的自动部署。大概的流程是Jenkins从git上获取代码

graph LR
Jenkins从git上获取代码-->Jenkins本地Restore,Build,Publish
Jenkins本地Restore,Build,Publish-->停掉IIS站点
停掉IIS站点-->推送发布好的文件到服务器
推送发布好的文件到服务器-->启动IIS站点

最开始Jenkins是放在Ubuntu的Docker中,但是由于Powershell执行的原因,就把Jenkins搬到了windows上。因为我们网站的部署需要停掉IIS站点,所以需要Powershell来远程操作服务器(上传文件,停止站点,启动站点),也很顺利的利用WinRM+Powershell脚本实现了上面的功能,但是最后在实际使用中发现,脚本停止站点偶尔会有是假状态,进行Copy文件还总是会因为占用而失败,所以还是只能手动去停止站点,这样就没有达到一键化的目的,所以就有了用Docker来镜像。

Docker Image

.net core对Docker是大力支持了,在Core之前,我就特别羡慕我在Docker中使用一些工具的体验–一行指令就可以工具自动安全完整了,不用费力进行环境配置,而且对系统的入侵特别少。所以Core出来之后,我就一直会尝试在Docker中运行Core程序 但是一直没敢上正式环境,正好现在遇到自动化部署的问题,就打算先从测试环境开始,把Docker环境一步步的能应用到正式环境上。大概的流程是这样的:

graph LR
Jenkins从git上获取代码或者钩子触发-->通过DockerFile构建镜像
通过DockerFile构建镜像-->推送镜像到远程仓库
graph LR
推送镜像到远程仓库-->服务器从远程仓库获取镜像
服务器从远程仓库获取镜像-->服务器停止并删除上一个版本容器
服务器停止并删除上一个版本容器-->run或者通过docker-compose运行新容器

Jenkins安装

Docker安装Jenkins可以直接到store.docker.com上搜索Jenkins的镜像然后run容器就行了唯一要注意的是要让容器中的Jenkins共用宿主机的Docker环境,命令如下

docker run --memory 1.5G  --name ContainerName -p 18181:8080 -p 50000:50000 -u root -d --env JAVA_OPTS="-Xms256m -Xmx512m  -XX:MaxNewSize=256m"  -v /var/run/docker.sock:/var/run/docker.sock  -v /usr/bin/docker:/usr/bin/docker  -v /home/buxiaoxia/software/jenkins:/var/jenkins_home -v /usr/lib/x86_64-linux-gnu/libltdl.so.7:/usr/lib/x86_64-linux-gnu/libltdl.so.7 jenkins/jenkins:lts

后面的-v是用来指定宿主机的文件/文件夹挂载到宿主机的指定路径上面,这里主要是用来挂载宿主机的Docker环境。当容器启动完成之后,我们可以用命令

docker exec -it containerid /bin/bash

进入容器中,执行docker ps的命令试试是否能执行成功。

Jenkins Job

当容器运行好之后,进行一些初始化的工作之后,我们就可以开始建立的部署Job了

源代码管理中配置我们Git的地址

然后就是构建命令直接用执行Shell

#!/bin/bash
# 获取短版本号来用Image的版本号

GITHASH=`git rev-parse --short HEAD`
docker build -t {imagename}:$GITHASH -f {DockerFile-PWD} {镜像的初始目录}

这里就是在构建我们的Image了
然后接下来就是推送当前构建的Image到远程仓库,再在构建后去执行远程连接到需要发布的服务器根据版本号获取到需要部署的镜像进行run就行,因为我当前都在测试环境 所以就直接在本地执行镜像的run了。

docker stop {containername}} #停掉原来的容器
docker rm {containername}   #删除原来
docker run -p 9526:80 -d -e ASPNETCORE_ENVIRONMENT='Development' -v /Path/Path/Logs:/app/App_Data/Logs --restart always --name {containername} {imagename}:$GITHASH

这样就基本实现了一键化部署了,当然还是有很多需要优化的地方,接下来我在使用的过程中如果遇到用着不顺的或者是你们有不顺的地方我们在来解决下。

写在最后

DockerFile

最开始构建asp.net core 2.1版本的镜像的时候,运行总是会找不到dotnet sdk,最后就只有在DockerFile中添加了一层 文件内容如下
“`
FROM microsoft/dotnet:2.1-sdk AS build
WORKDIR /app

拷贝所有文件到环境中,并进行restore,build and release

COPY . .
RUN dotnet restore
RUN dotnet build
WORKDIR /app/src/Path
RUN dotnet publish -c Release -o out

FROM microsoft/dotnet:2.1-aspnetcore-runtime AS runtime
WORKDIR /app
COPY –from=build /app/src/Path/out ./ 把发布好的文件拷贝到镜像中
Copy –from=build /app/src/Path/bin/Debug/netcoreapp2.1/XXX.xml ./ #把Swagger使用的xml拷贝到目录中

EXPOSE 80
RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime #时区的本地化
RUN echo ‘Asia/Shanghai’ >/etc/timezone
ENTRYPOINT [“dotnet”, “project.dll”] # 启动程序

<p>---恢复内容结束---</p># 写在前面 在前段时间尝试过用Jenkins来进行asp.net core 程序在IIS上面的自动部署。大概的流程是Jenkins从git上获取代码
graph LR
Jenkins从git上获取代码–>Jenkins本地Restore,Build,Publish
Jenkins本地Restore,Build,Publish–>停掉IIS站点
停掉IIS站点–>推送发布好的文件到服务器
推送发布好的文件到服务器–>启动IIS站点






最开始Jenkins是放在Ubuntu的Docker中,但是由于Powershell执行的原因,就把Jenkins搬到了windows上。因为我们网站的部署需要停掉IIS站点,所以需要Powershell来远程操作服务器(上传文件,停止站点,启动站点),也很顺利的利用WinRM+Powershell脚本实现了上面的功能,但是最后在实际使用中发现,脚本停止站点偶尔会有是假状态,进行Copy文件还总是会因为占用而失败,所以还是只能手动去停止站点,这样就没有达到一键化的目的,所以就有了用Docker来镜像。

### Docker Image
.net core对Docker是大力支持了,在Core之前,我就特别羡慕我在Docker中使用一些工具的体验--一行指令就可以工具自动安全完整了,不用费力进行环境配置,而且对系统的入侵特别少。所以Core出来之后,我就一直会尝试在Docker中运行Core程序 但是一直没敢上正式环境,正好现在遇到自动化部署的问题,就打算先从测试环境开始,把Docker环境一步步的能应用到正式环境上。大概的流程是这样的:

graph LR
Jenkins从git上获取代码或者钩子触发–>通过DockerFile构建镜像
通过DockerFile构建镜像–>推送镜像到远程仓库


graph LR
推送镜像到远程仓库–>服务器从远程仓库获取镜像
服务器从远程仓库获取镜像–>服务器停止并删除上一个版本容器
服务器停止并删除上一个版本容器–>run或者通过docker-compose运行新容器

### Jenkins安装
Docker安装Jenkins可以直接到store.docker.com上搜索Jenkins的镜像然后run容器就行了唯一要注意的是要让容器中的Jenkins共用宿主机的Docker环境,命令如下

docker run –memory 1.5G –name ContainerName -p 18181:8080 -p 50000:50000 -u root -d –env JAVA_OPTS=”-Xms256m -Xmx512m -XX:MaxNewSize=256m” -v /var/run/docker.sock:/var/run/docker.sock -v /usr/bin/docker:/usr/bin/docker -v /home/buxiaoxia/software/jenkins:/var/jenkins_home -v /usr/lib/x86_64-linux-gnu/libltdl.so.7:/usr/lib/x86_64-linux-gnu/libltdl.so.7 jenkins/jenkins:lts

后面的-v是用来指定宿主机的文件/文件夹挂载到宿主机的指定路径上面,这里主要是用来挂载宿主机的Docker环境。当容器启动完成之后,我们可以用命令

docker exec -it containerid /bin/bash

进入容器中,执行docker ps的命令试试是否能执行成功。
### Jenkins Job
当容器运行好之后,进行一些初始化的工作之后,我们就可以开始建立的部署Job了
![image](E8AC725CE22C412F86B8F8E22F52C9AC)

源代码管理中配置我们Git的地址
![image](07116E67DCFC49AFB67AABB9F8662713)

然后就是构建命令直接用执行Shell

!/bin/bash

获取短版本号来用Image的版本号

GITHASH=git rev-parse --short HEAD
docker build -t {imagename}:$GITHASH -f {DockerFile-PWD} {镜像的初始目录}

这里就是在构建我们的Image了
然后接下来就是推送当前构建的Image到远程仓库,再在构建后去执行远程连接到需要发布的服务器根据版本号获取到需要部署的镜像进行run就行,因为我当前都在测试环境 所以就直接在本地执行镜像的run了。

docker stop {containername}} #停掉原来的容器
docker rm {containername} #删除原来
docker run -p 9526:80 -d -e ASPNETCORE_ENVIRONMENT=’Development’ -v /Path/Path/Logs:/app/App_Data/Logs –restart always –name {containername} {imagename}:$GITHASH


这样就基本实现了一键化部署了,当然还是有很多需要优化的地方,接下来我在使用的过程中如果遇到用着不顺的或者是你们有不顺的地方我们在来解决下。

# 写在最后
### DockerFile
最开始构建asp.net core 2.1版本的镜像的时候,运行总是会找不到dotnet sdk,最后就只有在DockerFile中添加了一层 文件内容如下

FROM microsoft/dotnet:2.1-sdk AS build
WORKDIR /app

拷贝所有文件到环境中,并进行restore,build and release

COPY . .
RUN dotnet restore
RUN dotnet build
WORKDIR /app/src/Path
RUN dotnet publish -c Release -o out

FROM microsoft/dotnet:2.1-aspnetcore-runtime AS runtime
WORKDIR /app
COPY –from=build /app/src/Path/out ./ 把发布好的文件拷贝到镜像中
Copy –from=build /app/src/Path/bin/Debug/netcoreapp2.1/XXX.xml ./ #把Swagger使用的xml拷贝到目录中

EXPOSE 80
RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime #时区的本地化
RUN echo ‘Asia/Shanghai’ >/etc/timezone
ENTRYPOINT [“dotnet”, “project.dll”] # 启动程序

“`

版权声明:本文为rstar原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/rstar/p/9983438.html