docker部署mysql数据库
1.从阿里云加速网站上拉取mysql5.7.22的镜像
docker pull mysql:5.7.22
注意:当前版本mysql已经更新到8以上,新特性取消了MyISAM引擎(不支持事务),提升InnoDB引擎(支持事务)的速度,速度是5.6的2倍以上,而5.6不支持nosql,所以不要安装5.6的版本。
2.创建并运行docker容器,很明显要通过docker run命令实现
docker run -p 3306:3306 --name mysql \
-v /usr/local/docker/mysql/conf:/etc/mysql \
-v /usr/local/docker/mysql/logs:/var/log/mysql \
-v /usr/local/docker/mysql/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
-d mysql:5.7.22
-p 宿主机的 3306 端口对应容器中的 3306 端口, -v 数据卷 -d 守护式启动
3.通过navicat连接容器中的mysql 5.7数据库
通过 ifconfig -a
查询ip地址
这时候,我们通过 navicat 导入sql 文件,会报错,因为容器中的 mysql 配置中没有设置导入的最大的 SQL 脚本的大小,即如果是第一次运行该容器,该容器对应的宿主机的数据卷中没有任何对应的配置,所以应该先不绑定配置文件的数据卷,将配置文件修改后来 cp 到宿主机对应的数据卷目录中。
4.修改配置文件
1.删除旧的容器 docker rm -f mysql
,
2.删除配置的数据卷配置,新建新的容器
docker run -p 3306:3306 --name mysql \
-v /usr/local/docker/mysql/logs:/var/log/mysql \
-v /usr/local/docker/mysql/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
-d mysql:5.7.22
3.交互式进程进入容器,找到默认配置复制下来
然后进入 /etc/mysql/mysql.conf.d 目录下修改配置文件 mysqld.cnf
输入命令 echo "max_allowed_packet= 128M" >>mysqld.cnf
使得允许的最大sql文件为128M。
5.重启mysql容器
这是可以成功导入sql文件。
问题:这个时候配置文件是在容器中,所以要将文件cp到宿主机中。
6.将配置文件复制到宿主机中
切换到 cd /user/local/docker/mysql/conf/mysql
目录下
docker cp mysql:/etc/mysql
复制文件到当前目录下
mv *.* ..
将所有文件移动到上级目录下
docker rm -fr mysql
删除此时已空的文件夹。
7.此时可以使用数据卷来更新配置了,删除容器,重新run容器。发现可以连接数据库
部署项目到容器数据库
将war包添加到宿主机中的一个文件目录下,作为数据卷的挂载。
可以使用Xmanager中的Xftp工具复制。
拉取tomcat镜像,docker pull tomcat
以守护式运行容器,并进行数据卷的挂载,我的 war 包在 /usr/local/javajar/shopplus 目录下面
docker run --name shopplus -p 8080:8080 -v /usr/local/javajar/shopplus:/usr/local/tomcat/webapps -d tomcat
完全开放的防火墙的选项:--privileged=true
常见问题:404错误
/usr/local/tomcat/webapps 后面如果不加你的war名称(即项目名)的时候 ,访问你的 api 的时候需要带上你的项目名称。
docker logs -f 容器名
一直查看你的日志信息
连接数据库的500错误
项目中数据库的配置,你要通过tomcat连接mysql数据库,使用的ip为本地局域网中 mysql 容器中的 ip 地址。
查看容器 ip 方法为:docker inspect 容器id或者容器名称