四十六、docker-compose部署

这篇具有很好参考价值的文章主要介绍了四十六、docker-compose部署。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一个项目肯定包含多个容器,每个容器都手动单独部署肯定费时费力。docker-compose可以通过脚本来批量构建镜像和启动容器,快速的部署项目。

使用docker-compose部署主要是编写docker-compose.yml脚本。

一、项目结构

不论是Dockerfile还是docker-compose.yml脚本的编写都依赖上下文,所以需要明确部署文件夹的项目结构。假设当前项目部署文件夹名为auto,那么它的结构如下:

四十六、docker-compose部署

二、安装

方法1:前提得安装了pip

pip install docker-compose

方法2:

(1)使用curl命令下载docker-compose二进制文件:

sudo curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

(2)为二进制文件添加可执行权限:

sudo chmod +x /usr/local/bin/docker-compose

(3)验证安装是否成功

docker-compose --version

三、把后端项目、nginx目录拉取过来

(1)获取我原来放在云服务器里manual文件夹中的后端项目git地址,然后在auto里面重新拉取代码并存房贷django_app这个目录下。

四十六、docker-compose部署

(2)在auto目录下新建一个目录nginx_docker。将原来在manual里面的nginx目录拷贝到当前auto目录里面的nginx_docker目录下。

cp -r /ck13/manual/nginx/* ./

(3)在auto目录下创建一个docker-compose.yaml

vim docker-compose.yml

(4)删掉auto/nginx_docker目录下的nginx.conf。剩余三个文件需要映射到nginx容器里.

四十六、docker-compose部署

这里可以参考看一下官方文档: docs.docker.com/reference/

# 指定版本
version: "3"
services:
  # 每个服务的名称就是启动后的容器的名字
  # 当使用docker-compose -p ck13 -d up 命令部署后, 这个服务的容器的默认名为 ck13_redis_1
  redis:
    # 启动这个容器需要用到的景象是什么
    image: redis:alpine
    # 重启策略
    restart: always
  mariadb:
    image: mariadb:latest
    restart: always
    # 启动容器时需要定义的环境变量
    environment:
      MARIADB_ROOT_PASSWORD: pythonvip
      MARIADB_DATABASE: lemontest
    # 挂载卷
    volumes:
      - mariadb:/var/lib/mysql
    ports:
      - "3306:3306"
  django_app:
    # 服务依赖,会等待对应的服务启动之后才会启动当前服务
    depends_on:
      - redis
      - mariadb
    # 如果需要在启动服务之前构建镜像
    # 指定构建目录,这个目录就是Dockerfile所在的目录
    # 它是一个相对路径,相对于当前的docker-compose.yml文件
    build: ./django_app
    # 如果有build指令, 那么image指令就是指定生成镜像取的名字
    image: ck13_django_app_img
    environment:
       ENV: production
    restart: always
    volumes:
      - app_logs:/app/logs
  nginx:
    depends_on:
      - django_app
    build: ./nginx_docker
    image: ck13_nginx_img
    restart: always
    # 端口映射
    # 宿主机端口:容器端口
    # TODO: 注意端口要用双引号包裹
    ports:
      - "9400:80"
      - "9500:81"


# 服务中定义的命名卷,必须在全局的volumes中声明一下
volumes:
  mariadb:
  app_logs:

因为容器名要改变,所以我们之前在django后端项目中配的一些路径啥的都不能用了。

这里修改了记得在云服务器当前项目文件夹中重新git pull拉取最新的代码。四十六、docker-compose部署

还有这里的配置文件也要改,修改default.conf文件。将proxy_pass改成上面docker-compose.yml中的服务名。

四十六、docker-compose部署

 四十六、docker-compose部署

nginx_docker目录下新增Dockerfile文件

四十六、docker-compose部署 

from nginx:alpine
  
COPY ./static /usr/share/nginx/html/static/
COPY ./dist/ /usr/share/nginx/html/dist/
COPY ./conf.d /etc/nginx/conf.d

VOLUME /var/log/
EXPOSE 80 81

 删除我之前手动部署的容器、镜像

docker stop ck13_nginx ck13_django ck13_db ck13_redis

docker rm ck13_nginx ck13_django ck13_db ck13_redis

在这个目录下去运行docker-compose命令。

docker-compose -p ck13 up -d

四十六、docker-compose部署

 或者可以用自动化部署脚本,放在你项目的同级目录里。

#! /bin/bash
project=ck13
delete() {
	# 删除操作
	echo "开始删除项目"
	echo "删除项目只会删除容器,不会删除卷"
	echo "要删除数据卷请手动删除"
	docker-compose -p $project down
}
deploy() {
	# 部署操作
	echo "开始部署项目"
	echo "注意重新部署项目会重新构建镜像!"
	docker-compose -p $project ps | grep -E "${project}_.*" &>/dev/null
	if (($? == 0)); then
		echo "已存在项目${project}!"
		read -p "要重新部署项目吗?(y/n)" confirm
		if [[ $confirm == "y" ]]; then
			delete
			docker-compose -p $project up -d --build
		fi
	else
		docker-compose -p $project up -d --build
	fi
}
restart() {
	# 重启操作
	echo "开始重启项目"
	docker-compose -p $project ps | grep -E "${project}_.*" &>/dev/null
	if (($? != 0)); then
		echo "不存在项目${project}"
	else
		docker-compose -p $project restart
	fi
}
close() {
	echo "开始暂停项目"
	docker-compose -p $project stop
}
start() {
	while true; do
		echo "接口自动化测试平台部署系统"
		select name in "部署项目" "重启项目" "暂停项目" "删除项目" "退出菜单"; do
			case $name in
			"部署项目")
				deploy
				break
				;;
			"重启项目")
				restart
				break
				;;
			"暂停项目")
				close
				break
				;;
			"删除项目")
				delete
				break
				;;
			"退出菜单")
				break
				;;
			esac
		done
		if [ $name = "退出菜单" ]; then
			break
		fi
	done
}
start

运行脚本

四十六、docker-compose部署

 四十六、docker-compose部署

 部署中如果有问题的话,可以使用如下命令去检查问题。文章来源地址https://www.toymoban.com/news/detail-418088.html

docker logs ck13_nginx_1

docker volume ls

# 查找日志路径
docker inspect ck13_log
# 
cd /var/lib/docker/volumes/ck13_log/_data/

到了这里,关于四十六、docker-compose部署的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Jenkins+Docker+Docker-Compose自动部署,SpringCloud架构公共包一个任务配置

    前言 Jenkins和docker的安装,随便百度吧,实际场景中我们很多微服务的架构,都是有公共包,肯定是希望一个任务能够把公共包的配置加进去,一并构建,ok,直接上干货。 Jenkins 全局环境安装 这里使用 clean package -Dmaven.test.skip=true 使用docker内部网络,分配ip,参考docker创建网

    2024年02月15日
    浏览(43)
  • 【nacos】【sentinel】【gateway】docker-compose安装及web项目部署

    【centos】【docker】安装启动 【docker-compose】安装使用 启动docker-compose配置文件

    2024年02月11日
    浏览(46)
  • 网络安全系列-四十一: arkime的docker-compose安装及可视化pcap文件示例

    有了待分析的pcap文件,如何针对pcap文件进行可视化展示,并对pcap文件中的流进行各种查询分析,查看联通图等? 本文基于arkime,来讲解如何基于docker快速搭建环境,并可视化pcap文件进行分析。 arkime(formerly Moloch) is a large-scale, open-source, indexed packet capture and search tool,详见介

    2023年04月08日
    浏览(41)
  • docker持久化部署vue前端nodejs后端项目-- 01. docker以及docker-compose在window以及linux的安装

    本章节主要来讲述docker desktop 界面版本使用以及docker-compose 的安装和使用 GIT地址:添加链接描述 docker 专栏:点击此处 章节 1 docker以及docker-compose在window以及linux的安装 2 项目对应的docker-compose结构 3 怎么将docker-compose项目部署到服务器上 4 配置服务器JENKINS环境 额外篇 章节

    2024年02月04日
    浏览(48)
  • docker-compose的部署

    目录 一、compose的概述 1.1 yaml的概述 1.2 yaml的数据结构 1.2.1 docker composeyml文件的常用手段 1.3 docker compose 1.4 yml文件编写  二、部署compose 2.1 下载docker-compose安装包  2.2 部署docker-compose 2.3 部署docker-compose 2.4 开启验证  三、compose编排安装tomcat容器 总结 compose是docker官网开发的,

    2024年02月01日
    浏览(51)
  • Docker-Compose编排与部署

    目录 Docker Compose Compose的优点 编排和部署 Compose原理 Compose应用案例 安装docker-ce 阿里云镜像加速器 安装docker-compose docker-compose用法 Yaml简介 验证LNMP环境          Docker Compose 的前身是 Fig,它是一个 定义及运行多个 Docker 容器的工具 。可以使用 YAML 文件来配置应用程序的服

    2024年02月14日
    浏览(47)
  • docker-compose部署milvus

    上一篇介绍了使用kubernetes来部署milvus,这篇介绍下使用docker-compose来部署milvus。 下载docker-compose 下载最新版的 docker-compose-linux-x86_64 在服务器上使用 安装docker-compose 将docker拷贝到/usr/local/bin目录下,重命名为 docker-compose 默认下载下来的文件只有读写权限,使用 chmod +x docker-

    2024年02月13日
    浏览(55)
  • docker-compose部署redis

    docker-compose是什么? Docker Compose是一个用于 定义和运行多个容器Docker应用程序的工具 。它允许您定义一组容器,这些容器组成一个完整的应用程序,且这些容器之间可以互相通信。通过Docker Compose,您可以使用一个单独的文件来定义应用程序的 服务、网络、卷等元素,并且可

    2024年02月12日
    浏览(34)
  • docker-compose部署mysql

    docker-compose 虽然docker部署环境比自己下载安装包要方便不少,但是docker的命令还有挂载目录在每次启动容器的时候都去找命令对使用者是很不友好的,而且有时候要启动多个容器的时候显然一个个的启动是很麻烦的。所以如果可以事先将\\\"启动脚本\\\"写好的话,之后就算虚拟机

    2024年02月02日
    浏览(42)
  • docker-compose部署Jenkins

    1、docker安装 1.1 配置docker-yum源 yum -y install yum-utils yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo 1.2 查看可选择的docker-ce版本 yum list docker-ce --showduplicates|sort -r 1.3安装指定版本docker yum -y install docker-ce-19.03.9 ps:如果安装docker-ce-19.03.9报错: package docker

    2024年02月02日
    浏览(61)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包