在windows下使用docker,我们选择docker desktop这个软件,非常方便。
docker desktop介绍及安装docker desktop是适用于mac、linux或windows环境的一键安装应用程序,使您能够构建和共享容器化应用程序和微服务。它提供了一个简单的gui(图形用户界面),允许您直接从机器管理容器、应用程序和图像。docker desktop既可以单独使用,也可以作为cli的补充工具。docker desktop减少了在复杂设置上花费的时间,因此您可以专注于编写代码。它负责端口映射、文件系统问题和其他默认设置,并定期更新错误修复和安全更新。安装docker desktop后,默认安装了以下组件:

(资料图片)
docker desktop可与您选择的开发工具和语言配合使用,并使您能够访问docker hub中的大量认证图像和模板库。这使开发团队能够扩展他们的环境,以便使用安全的存储库快速自动构建、持续集成和协作。pg电子赏金女王模拟器试玩官网地址
项目编译发布项目运行框架为.net6.0,运行环境为linux-x64
dockerfile内容及国内镜像源dockerfile是用来构建docker镜像的构建文件,它其实就像一个脚本文件,里面可以执行一些命令,通过它就可以指定或下载构建的镜像所需要的一些组件,然后打包成镜像文件。下面是本教程使用的dockerfile脚本文件内容,指定了使用asp.net6.0的运行时环境,并且在镜像系统的5000端口上提供http服务。同时更新sources.list使用国内镜像源,这里没有用阿里的镜像源,因为测试过程中阿里的镜像源在apt-get install -y libgdiplus的时候会提示找不到这个组件(坑)。因为使用的有基于system.drawing绘制的验证码图片,所以需要在构建的时候把libgdiplus组件引用到镜像文件中,最后把镜像系统中的时区改成亚洲的时区。
from mcr.microsoft.com/dotnet/aspnet:6.0 as baseworkdir /whitelistexpose 5000copy . .run touch /etc/apt/sources.listrun echo "" > /etc/apt/sources.list \ && echo "deb http://mirrors.163.com/debian/ buster main non-free contrib" >> /etc/apt/sources.list \ && echo "deb http://mirrors.163.com/debian/ buster-updates main non-free contrib" >> /etc/apt/sources.list \ && echo "deb http://mirrors.163.com/debian/ buster-backports main non-free contrib" >> /etc/apt/sources.list \ && echo "deb-src http://mirrors.163.com/debian/ buster main non-free contrib" >> /etc/apt/sources.list \ && echo "deb-src http://mirrors.163.com/debian/ buster-updates main non-free contrib" >> /etc/apt/sources.list \ && echo "deb-src http://mirrors.163.com/debian/ buster-backports main non-free contrib" >> /etc/apt/sources.list \ && echo "deb http://mirrors.163.com/debian-security/ buster/updates main non-free contrib" >> /etc/apt/sources.list \ && echo "deb-src http://mirrors.163.com/debian-security/ buster/updates main non-free contrib" >> /etc/apt/sources.listenv tz=asia/shanghairun apt-get update -y #run apt-get upgrade -yrun apt-get install -y libgdiplusrun apt-get cleanrun ln -s /usr/lib/libgdiplus.so /usr/lib/gdiplus.dllrun ln -fs /usr/share/zoneinfo/${tz} /etc/localtime \ && echo ${tz} > /etc/timezoneenv aspnetcore_urls http:// :5000entrypoint ["dotnet", "whitelist.dll"]同时可以添加.dockerignore文件来排除一些不需要打包到镜像里的文件,比如忽略到bin或者obj目录里的文件。[b|b]in [o|o]bj最后,千万不要忘记把wwwroot复制到发布的目录中,要不然访问的时候会没有样式。以上dockerfile中的有些脚本命令可合并成一行。
把dockerfile和.dockerignore文件复制到发布目录中,然后运行powshell,cd命令到发布目录(本文使用目录为bin\release\net6.0\linux-x64)。然后执行打包命令docker build --tag whitelist:1.0 .
如一切正常,按上图的进度执行完成后,就可以在docker desktop中看到打包的镜像文件。
docker desktop中的linux系统我们点击镜像的运行按钮,填写好镜像名称,绑定端口(本机通过此端口用浏览器可以访问到容器内的服务),绑定的本地文件夹(可选)和其它参数(可选)后点击run按钮,如果没有端口冲突和名称冲突,就会得到一个运行成功的容器。我们可以进入到容器的操作系统中查看一下系统信息。
cat /etc/issuedebian gnu/linux 10
cat /proc/versionlinux version 5.15.90.1-microsoft-standard-wsl2 (oe-user@oe-host) (x86_64-msft-linux-gcc (gcc) 9.3.0, gnu ld (gnu binutils) 2.34.0.20200220)
现在我们已经得到了一个基于docker desktop在windows系统上构建的镜像文件,在使用中,我们需要把这个镜像运行在linux系统中(比如centos),所以需要把镜像导出来进行分发(这里使用的是本地导出,不是导出到云镜像服务器)。在windows系统的powershell中执行下面命令,把镜像(whitelist):tag名(1.0)导出到本地的d盘,文件名是whitelist.tar,docker save -o d:\whitelist.tar whitelist:1.0
首先安装一下docker所依赖的组件yum install -y yum-untils device-mapper-persistent-data lvm2
然后配置数据源为国内的阿里云数据源yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
安装dockeryum install docker-ce
启动dockersystemctl start docker
设置docker为开机自启systemctl enable docker
查看docker的版本信息docker --versiondocker version 24.0.2, build cb74dfc
查看当前docker中的镜像docker images这里看到,目前docker中没有任何镜像
把镜像文件上传到/usr/data目录下,然后执行导入镜像的命令docker load -i /usr/data/whitelist.tar 导入成功后,再查看docker中的镜像,就会看到我们刚导入的镜像文件了。
随后我们执行运行镜像的命令,把centos系统的8080端口和容器的5000端口做映射。docker run -d -p 8080:5000 --name whitelist whitelist:1.0运行成功后会返回一个类似guid的容器编号,然后我们可以查看一下当前运行的容器。docker ps如果防火墙没有放行8080端口,可用以下命令放开8080端口。firewall-cmd --zone=public --add-port=8080/tcp --permanentfirewall-cmd --reload
最后我们本机打开浏览器访问centos系统的ip并带上8080端口,就可看到我们从windows上打包的docker镜像已经成功运行在了centos系统的docker环境下了。
标签:
