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

docker部署mysql数据库,部署项目到数据库_第1张图片

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

docker部署mysql数据库,部署项目到数据库_第2张图片

然后进入 /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或者容器名称

 

你可能感兴趣的:(docker)