Docker部署MySQL,部署项目到数据库

原文链接:docker部署mysql数据库,部署项目到数据库

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

img

-p 宿主机的 3306 端口对应容器中的 3306 端口, -v 数据卷 -d 守护式启动

3.通过navicat连接容器中的mysql 5.7数据库

通过 ifconfig -a 查询ip地址

img

这时候,我们通过 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.交互式进程进入容器,找到默认配置复制下来

img

然后进入 /etc/mysql/mysql.conf.d 目录下修改配置文件 mysqld.cnf

输入命令 echo "max_allowed_packet= 128M" >>mysqld.cnf

使得允许的最大sql文件为128M。

5.重启mysql容器

img

这是可以成功导入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或者容器名称

发表评论