Docker工作需要容器和镜像,它们是docker的基石
镜像是一个模板,是运行一个应用程序所需的文件
容器是由镜像所创建的,用以隔离不同的镜像中的应用程序,这样应用于应用之间就不会相互干扰
docker image ls / docker images
:查询所有的镜像docker pull
:从Docker Hub中下载镜像
docker rmi
:删除镜像
docker rmi -f $(docker images -q)
docker build
:创建自定义镜像docker run
:创建并允许一个容器docker create
:创建容器docker ps
:查询所有容器docker start
:启动镜像docker stop
:停止镜像docker logs
:查询容器的运行日志记录docker cp
:将文件复制到容器中docker diff
:查看容器文件的变化docker exec
:在容器中运行命令docker tag
:为镜像分配标记(命名)docker login/logout
:从镜像仓库中登陆或注销docker commit
:将修改的容器创建为镜像docker push
:将镜像发布到仓库中docker inspect
:查看容器的详细配置dockerfile只需要简单理解为描述docker镜像规则的描述文件
FROM mcr.microsoft.com/dotnet/core/sdk:3.1
COPY dist /app
WORKDIR /app
#指令是声明运行时容器提供服务端口,这只是一个声明,在运行时并不会因为这个声明应用就会开启这个端口的服务
EXPOSE 80/tcp
ENTRYPOINT ["dotnet", "ExampleApp.dll"]
打包asp.net core项目
将包压缩并发送到linux服务器中,并解压
压缩后文件如下:
执行创建自定义容器命令docker build [打包文件的路径] [-t 指定生成容器的名称] [-f 指定要执行的dockerfile名称]
ps:在docker里面镜像的名称不能有大写,只能用小写
上面我们进行了镜像的创建,下面学习容器的创建
创建容器docker create -p 外部端口:容器内部端口 -name 容器名 所要创建的容器(镜像名)
Ps:注意 这里有两个坑 :
一、部署asp.net core项目时,我们kestrel默认监听的是5000端口,并且只对允许使用localhost访问(即只有本机能访问),我们可以在program中如图中设置,外部计算机才能正常访问:
二、在项目部署到docker中时,在dockerfile中我们虽然声明监听的端口是80,但是我们kestrel监听的确是5000端口,此时,我们在宿主机映射端口时候,应该以kestrel监听的端口为准,否则将无法成功访问网页
启动容器 docker start 容器名
创建容器并运行 docker run [-d(表示后台运行)] [-p 宿主机端口:容器服务端口] [--rm(表示容器stop时,自动删除容器)] --nmae 容器名 镜像名
停止容器运行 docker stop 容器名
或 docker kill 容器名
(建议少用)
查看容器运行日志 docker logs [-f(表示实时查看日志)] 容器名称
原文:https://www.cnblogs.com/deehuang/p/14165971.html