系列文章
Docker系列1 - CentOS7 安装Docker
Docker系列2 - Docker常用命令
Docker系列3 - Docker文件系统及搭建Docker私服
Docker系列4 - 在Docker中测试MySQL主从数据库
Docker系列5 - 在Docker中测试Redis集群
Docker系列6 - Dockerfile简介
Docker系列7 - Docker网络模式
Docker Compose对Docker容器集群的快速编排
docker-compose.yml
定义一组关联的应用容器为一个项目
#安装
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
sudo chmod +x /usr/local/bin/docker-compose
docker-compose --version
#卸载Docker Compose
sudo rm /usr/local/bin/docker-compose
Docker Compose常用命令(在当前目录中需要有一个docker-compose.yml文件)
docker-compose up
#后台运行
docker-compose up -d
#停止和删除容器、网络、卷
docker-compose down
docker-compose ps
docker-compose top
docker-compose restart
docker-compose start
docker-compose stop
#检查docker-compose.yml有没有语法错误
docker-compose config
#有问题时输出错误
docker-compose config -q
docker-compose logs
docker-compose exec
使用Docker Compose部署SpringBoot项目
springboot源码地址:https://gitee.com/galen.zhang/docker-demo
数据库文件:data.sql
springboot应用中使用到了redis、mysql,在docker-compose.yml中定义容器一起启动
另外定义了一个自定义网络test_network,使3个容器使用同一个网络
- 下载源码,使用idea工具打包项目
- 在CentOS中新建一个文件夹project,上传docker-demo-0.0.1-SNAPSHOT.jar
- 上传项目中的docker-compose.yml、Dockerfile
#构建镜像
docker build -t docker-demo:1.0 .
#启动应用
docker-compose up -d
docker network ls
docker-compose ps
#传服务名
docker-compose logs mysql
docker-compose logs demoService
#连接mysql,创建数据库
docker exec -it project_mysql_1 /bin/bash
mysql -utest -p
#在docker-compose.yml文件中配置的mysql密码是 test123
show databases;
use user_db;
CREATE TABLE `t_user`
(
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`username` varchar(50) NOT NULL,
`password` varchar(50) NOT NULL,
`sex` tinyint(4) NOT NULL DEFAULT '0' COMMENT '性别 0:女 1:男',
`deleted` tinyint(4) UNSIGNED NOT NULL DEFAULT '0' COMMENT '删除标示 0:不删除 1:删除',
`create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建日期',
`update_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新日期',
PRIMARY KEY (`id`)
) ENGINE = InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COMMENT='用户表';
#创建表,调用接口测试
select * from t_user;
#换成CentOS的IP
http://192.168.99.200:8080/demo/user/save
http://192.168.99.200:8080/demo/user/getById?id=1
#查询数据是否插入成功
select * from t_user;
#关停并删除容器
docker-compose down
遇到的问题:
mysql -uroot -p
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
#mysql5.7 首次安装后,需要修改root的默认密码才能使用
https://blog.csdn.net/weixin_43972854/article/details/106712978
Docker-Compose安装、卸载、使用详解
https://www.jianshu.com/p/a49389497a0c
Docker安装mysql5.7报错 ERROR 1045 (28000): Access denied for user