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或者容器名称