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

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

 

### 在Docker部署SpringBoot应用并连接数据库Docker部署SpringBoot应用并连接数据库的过程可以分为几个关键步骤,包括创建Docker镜像、运行容器以及配置数据库连接。以下是详细的教程: #### 1. 准备SpringBoot项目 确保SpringBoot项目已经正确配置,并且能够正常运行。项目的`application.properties`或`application.yml`文件中需要包含数据库连接的相关配置。例如: ```properties spring.datasource.url=jdbc:mysql://tz_mysql:3306/your_database_name?useSSL=false&serverTimezone=UTC spring.datasource.username=root spring.datasource.password=your_password spring.jpa.hibernate.ddl-auto=update ``` 上述配置指定了数据库的URL、用户名和密码,并启用了Hibernate的自动更新功能[^1]。 #### 2. 创建Dockerfile 在SpringBoot项目的根目录下创建一个名为`Dockerfile`的文件,内容如下: ```dockerfile # 使用官方的OpenJDK镜像作为基础镜像 FROM openjdk:17-jdk-slim # 设置工作目录 WORKDIR /app # 将构建好的SpringBoot jar包复制到容器中 COPY target/your-springboot-app.jar /app/app.jar # 暴露应用的端口 EXPOSE 8081 # 启动命令 ENTRYPOINT ["java", "-jar", "/app/app.jar"] ``` 此`Dockerfile`定义了如何将SpringBoot应用打包为Docker镜像。 #### 3. 构建Docker镜像 在项目根目录下执行以下命令来构建Docker镜像: ```bash docker build -t tz-docker-demo:0.0.1 . ``` 这将基于`Dockerfile`创建一个名为`tz-docker-demo:0.0.1`的Docker镜像[^1]。 #### 4. 启动MySQL容器 使用Docker启动一个MySQL容器,可以通过以下命令完成: ```bash docker run --name tz_mysql -e MYSQL_ROOT_PASSWORD=your_password -d mysql:latest ``` 此命令会启动一个名为`tz_mysql`的MySQL容器,并设置root用户的密码为`your_password`[^2]。 #### 5. 运行SpringBoot容器 使用以下命令运行SpringBoot应用容器,并将其与MySQL容器连接: ```bash docker run --rm -p 8081:8081 --name demo --link tz_mysql:tz_mysql tz-docker-demo:0.0.1 ``` 此命令将SpringBoot应用容器命名为`demo`,并将端口8081映射到主机,并通过`--link`参数将MySQL容器连接到应用容器[^1]。 #### 6. 验证部署 可以通过访问`http://localhost:8081`来验证SpringBoot应用是否成功运行。此外,还可以使用以下命令查看容器状态: ```bash docker ps ``` 如果一切正常,应该可以看到两个正在运行的容器:一个是MySQL容器,另一个是SpringBoot应用容器[^3]。 --- ### 注意事项 - 确保SpringBoot项目的依赖项已正确配置,尤其是与数据库相关的依赖。 - 如果项目中还涉及其他服务(如Redis),可以参考类似的步骤启动相应的Docker容器[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值