微服务架构 ------ DockerCompose从安装到项目部署
作者:互联网
DockerCompose的目的:简化Docker的启动和停止流程,以及编排Docker启动服务与服务之间的关系
DockerCompose的安装:curl -L https://get.daocloud.io/docker/compose/releases/download/1.24.0/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
docker-compose version
curl -L https://github.com/docker/compose/releases/download/1.24.0/docker-compose-`uname -s`-`uname -m`>/usr/local/bin/docker-compose
docker-compose.yml文件的编写,跟springboot中配置文件编写的格式一样,只是在写yml文件的时候不能使用tab键缩进,不信可以试试
写了一个简单的tomcat的配置启动配置文件
version: '3.1' services: tomcat: restart: always image: tomcat container_name: tomcat ports: - 8080:8080
启动命令:在当前文件夹下执行 docker-compose up 就能启动tomcat -d 后台运行
停止命令:docker-compose down 该命令会停止容器 并且 清除以docker-compose形式启动的容器的记录
原样粘贴命令 :vi 某个文件之后 :set paste 再输入i 就能按照复制的格式原样粘贴
下面的操作都是在 /usr/local/ 下面的文件夹下操作的,遵循linux文件夹工作范围规定 如果你不想在该文件夹下 换其他地方也无所谓
部署tomcat
1.docker-compose.yml
version: '3.1' services: tomcat: restart: always image: tomcat container_name: tomcat ports: - 8080:8080 volumes: - ./webapps:/usr/local/tomcat/webapps environment: TZ: Asia/Shanghai
2.运行 docker-compose up -d
这时在你所在的目录下会生成一个文件夹 webapps ,这个文件夹叫做 数据卷 ,这个位置与容器中的
/usr/local/tomcat/webapps 位置共享内存,也就是说两者的文件夹下的文件内容都是一致的,这样就不用再担心容器关闭的时候,应用数据持久化的问题
即使容器删除这块的数据依然会保留
部署mysql
1.docker-compose.yml
version: '3.1' services: db: # 目前 latest 版本为 MySQL8.x image: mysql restart: always environment: MYSQL_ROOT_PASSWORD: 123456 command: --default-authentication-plugin=mysql_native_password --character-set-server=utf8mb4 --collation-server=utf8mb4_general_ci --explicit_defaults_for_timestamp=true --lower_case_table_names=1 ports: - 3306:3306 volumes: - ./data:/var/lib/mysql # MySQL 的 Web 客户端 adminer: image: adminer restart: always ports: - 8080:8080
2.同tomcat一样,docker会在本地创建一个与容器中数据共享的存储空间
至此tomcat和mysql已经部署完成,至于如何部署项目,我想就不用我多说了吧 ?
简单说一下:首先把项目打好的war包解压到tomcat生成的webapps文件夹下删除多余的文件, 将数据库初始化语句和历史数据执行导入,启动两个容器就可以了 。
标签:compose,架构,DockerCompose,tomcat,部署,文件夹,usr,docker,local 来源: https://www.cnblogs.com/zmeRecord/p/11807018.html