使用Docker配置,创建,运行镜像文件

1,创建镜像文件前准备

	# 使用基础镜像
	FROM alpine:latest

	# 设置工作目录
	WORKDIR /app

	# 复制应用程序文件到镜像中
	COPY . .

	# 暴露容器的端口 不会自动将容器的端口映射到宿主机上  docker run -d -p <宿主机端口>:7080 <镜像名称>
	EXPOSE 7080

	# 定义容器启动时执行的命令
	CMD ["./gift-panel","-DserverId=600","-DserviceCenter=127.0.0.1","-Dnamespace=gs-test","-DserverPort=7080"]

	# 安装 tzdata 包
	RUN apk update && apk add --no-cache tzdata

	# 设置时区
	ENV TZ=Asia/Shanghai
	RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone

2,执行创建镜像命令

1,创建镜像命令
docker build -t godemo .

2,查看镜像文件命令
docker images

这个命令用于列出本地主机上的所有 Docker 镜像。执行 docker images 命令后,将会显示出镜像的仓库名称、标签、镜像 ID、创建时间和大小等信息。

示例输出可能如下所示:
REPOSITORY    TAG       IMAGE ID       CREATED        SIZE
ubuntu        latest    0123456789ab   2 weeks ago    64.2MB
nginx         latest    cdef01234567   3 months ago   132MB

3,启动镜像文件

这个命令用于在后台运行一个名为 "godemo" 的容器,并将容器内部的端口 7080 映射到主机的端口 7080 上。
在这个命令中,--name godemo 指定了容器的名称为 "godemo",-p 7080:7080 指定了端口映射,将容器内部的端口 7080 映射到主机的端口 7080 上,-d 参数表示在后台运行容器,godemo 是要运行的镜像名称。
(主机的端口 )7080:7080(容器内部的端口)

docker run  --name godemo -p 7080:7080 -d godemo

4,列出正在运行的容器

docker ps

这个命令用于列出正在运行的容器。执行 docker ps 命令后,将会显示出容器的相关信息,如容器 ID、镜像名称、创建时间、状态等。

示例输出可能如下所示:

CONTAINER ID   IMAGE          COMMAND       CREATED         STATUS         PORTS      NAMES
abcdef123456   nginx:latest   "nginx -g ..."  2 hours ago    Up 2 hours    80/tcp     webserver
123456789abc   mysql:latest   "mysqld"      3 days ago      Up 3 days

5,停止镜像服务 在这个命令中,godemo 是要停止的容器的名称。

docker stop godemo

6,删除容器

docker rm godemo

7,查询启动容器log

docker logs godemo

8,日志保存到所在服务器

docker logs godemo > /data/application/gs/giftpanel/docker_log.out	

9,如果镜像包有问题删除不掉或者网络问题,查看以下命令

#docker ps -a 命令来列出所有的容器,确认一下是否存在名为 "godemoxx" 的容器
docker ps -a 

#拿到CONTAINER ID,执行停止
docker stop 3d8dc85f2e16

#docker rm 用于**删除容器**。在你的命令中,docker rm 3d8dc85f2e16 将会删除 ID 为 3d8dc85f2e16 的容器。
docker rm 3d8dc85f2e16

#docker rmi 用于**删除镜像**
docker rmi 3d8dc85f2e16

#docker rmi -f 用于强制**删除镜像**
docker rmi -f 3d8dc85f2e16

这个命令会列出容器内部正在监听的端口,确保19999端口已经在容器内部正常监听。
docker exec -it gx netstat -tuln

查看容器内部端口与暴露端口的映射情况
docker port gx

进入容器
docker exec -it 容器ID /bin/sh

尝试将容器的启动命令改为交互式模式,这样可以查看启动过程中的详细输出信息
docker run -it 镜像名称 /bin/sh
  • 8
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Docker Swarm是Docker的原生集群管理工具,可以用于在多个主机上运行和管理容器Dockerfile是一种用于定义Docker镜像构建过程的文本文件。 使用Docker Swarm时,可以使用Dockerfile创建镜像,但其实创建镜像的过程与在单个主机上创建镜像的过程非常相似。主要的区别是,在Swarm中创建镜像将会在整个集群中被使用,而非仅限于单个主机。 首先,在Swarm集群的主节点上创建一个Dockerfile,该文件包含了构建镜像的指令和配置。以一个简单的Node.js应用为例,可以定义如下的Dockerfile: ``` FROM node:14-alpine WORKDIR /app COPY package*.json ./ RUN npm install COPY . . EXPOSE 3000 CMD [ "npm", "start" ] ``` 然后,在主节点的终端中,使用`docker build`命令来构建镜像。例如,使用以下命令创建一个名为`my-app`的镜像: ``` docker build -t my-app . ``` 接下来,使用`docker push`命令将构建好的镜像推送到Docker镜像仓库。例如,可以推送到Docker Hub: ``` docker push username/my-app ``` 最后,在Swarm集群的其他节点上使用`docker service`命令来创建服务,并使用先前构建的镜像作为服务的副本。例如,使用以下命令创建一个名为`my-app`的服务: ``` docker service create --name my-app --replicas 3 username/my-app ``` 这将在集群的多个节点上运行三个容器的副本,以提供高可用性和负载均衡的服务。 通过以上步骤,我们可以使用Dockerfile在Docker Swarm集群中创建镜像,并在集群中运行多个容器的副本来提供服务。这种方式使得应用程序可以更加灵活地在集群中运行,并可以根据需要进行扩展和管理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值