普通视图

发现新文章,点击刷新页面。
昨天以前宋浩志的博客

ruoyi-vue项目集成flyway实现自动创建表

作者 宋浩志
2022年9月8日 13:39

添加flyway依赖

在根目录下pom.xml添加flyway依赖RuoYi-Vue\pom.xml

1
2
3
4
5
<dependency>
<groupId>org.flywaydb</groupId>
<artifactId>flyway-core</artifactId>
<version>7.15.0</version>
</dependency>

ruoyi-framework\pom.xml下引入

1
2
3
4
<dependency>
<groupId>org.flywaydb</groupId>
<artifactId>flyway-core</artifactId>
</dependency>

yaml配置

RuoYi-Vue\ruoyi-admin\src\main\resources\application.yml中添加以下配置

1
2
3
4
5
6
7
8
# 配置flyway数据版本管理
flyway:
enabled: true
baseline-on-migrate: true
clean-on-validation-error: false
sql-migration-prefix: V
sql-migration-suffixes: .sql
locations: classpath:db/migration

flyway.baseline-description对执行迁移时基准版本的描述.
flyway.baseline-on-migrate当迁移时发现目标schema非空,而且带有没有元数据的表时,是否自动执行基准迁移,默认false.
flyway.baseline-version开始执行基准迁移时对现有的schema的版本打标签,默认值为1.
flyway.check-location检查迁移脚本的位置是否存在,默认false.
flyway.clean-on-validation-error当发现校验错误时是否自动调用clean,默认false.
flyway.enabled是否开启flywary,默认true.
flyway.encoding设置迁移时的编码,默认UTF-8.
flyway.ignore-failed-future-migration当读取元数据表时是否忽略错误的迁移,默认false.
flyway.init-sqls当初始化好连接时要执行的SQL.
flyway.locations迁移脚本的位置,默认db/migration.
flyway.out-of-order是否允许无序的迁移,默认false.
flyway.password目标数据库的密码.
flyway.placeholder-prefix设置每个placeholder的前缀,默认${.
flyway.placeholder-replacementplaceholders是否要被替换,默认true.
flyway.placeholder-suffix设置每个placeholder的后缀,默认}.
flyway.placeholders.[placeholder name]设置placeholder的value
flyway.schemas设定需要flywary迁移的schema,大小写敏感,默认为连接默认的schema.
flyway.sql-migration-prefix迁移文件的前缀,默认为V.
flyway.sql-migration-separator迁移脚本的文件名分隔符,默认__
flyway.sql-migration-suffix迁移脚本的后缀,默认为.sql
flyway.tableflyway使用的元数据表名,默认为schema_version
flyway.target迁移时使用的目标版本,默认为latest version
flyway.url迁移时使用的JDBC URL,如果没有指定的话,将使用配置的主数据源
flyway.user迁移数据库的用户名
flyway.validate-on-migrate迁移时是否校验,默认为true.

创建目录

RuoYi-Vue\ruoyi-system\src\main\resources目录下创建db/migration目录,把若依若依提供的表结构sql文件复制到该文件夹,并且重命名。

文件命名规则:

  • 仅需要被执行一次的SQL命名以大写的”V”开头,V+版本号(版本号的数字间以”.“或”_“分隔开)+双下划线(用来分隔版本号和描述)+文件描述+后缀名。例如:V20201100__create_user.sqlV2.1.5__create_user_ddl.sqlV4.1_2__add_user_dml.sql

  • 可重复运行的SQL,则以大写的“R”开头,后面再以两个下划线分割,其后跟文件名称,最后以.sql结尾。(不推荐使用)比如:R__truncate_user_dml.sql

若依项目代码修改

全局搜索一下@PostConstruct,将代码中@PostConstruct注释掉,总共有三个文件需要修改SysJobServiceImpl,SysDictTypeServiceImpl,SysConfigServiceImpl

1
2
3
4
5
6
7
8
9
10
11
12
13
/**
* 项目启动时,初始化定时器 主要是防止手动修改数据库导致未同步到定时任务处理(注:不能手动修改数据库ID和任务组名,否则会导致脏数据)
*/
//@PostConstruct
public void init() throws SchedulerException, TaskException
{
scheduler.clear();
List<SysJob> jobList = jobMapper.selectJobAll();
for (SysJob job : jobList)
{
ScheduleUtils.createScheduleJob(scheduler, job);
}
}
1
2
3
4
5
6
7
8
/**
* 项目启动时,初始化字典到缓存
*/
//@PostConstruct
public void init()
{
loadingDictCache();
}
1
2
3
4
5
6
7
8
/**
* 项目启动时,初始化参数到缓存
*/
//@PostConstruct
public void init()
{
loadingConfigCache();
}

注释掉以后,我们把启动时初始化的操作移动到RuoYiApplication.java

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
package com.ruoyi;

import com.ruoyi.quartz.service.impl.SysJobServiceImpl;
import com.ruoyi.system.service.impl.SysConfigServiceImpl;
import com.ruoyi.system.service.impl.SysDictTypeServiceImpl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.CommandLineRunner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;

/**
* 启动程序
*
* @author ruoyi
*/
@SpringBootApplication(exclude = { DataSourceAutoConfiguration.class })
public class RuoYiApplication
implements CommandLineRunner {
@Autowired
private SysConfigServiceImpl configService;
@Autowired
private SysJobServiceImpl jobService;
@Autowired
private SysDictTypeServiceImpl dictTypeService;

public static void main(String[] args)
{
// System.setProperty("spring.devtools.restart.enabled", "false");
SpringApplication.run(RuoYiApplication.class, args);
System.out.println("(♥◠‿◠)ノ゙ 若依启动成功 ლ(´ڡ`ლ)゙ \n" +
" .-------. ____ __ \n" +
" | _ _ \\ \\ \\ / / \n" +
" | ( ' ) | \\ _. / ' \n" +
" |(_ o _) / _( )_ .' \n" +
" | (_,_).' __ ___(_ o _)' \n" +
" | |\\ \\ | || |(_,_)' \n" +
" | | \\ `' /| `-' / \n" +
" | | \\ / \\ / \n" +
" ''-' `'-' `-..-' ");
}

@Override
public void run(String... args) throws Exception {
configService.init();
jobService.init();
dictTypeService.init();
}
}

启动项目

代码编写好以后,我们在数据库中创建一个ry-vue的数据库,在RuoYi-Vue\ruoyi-admin\src\main\resources\application.yml下修改数据库连接和数据库密码等信息。

启动成功以后,我们会看到ry-vue的数据库中表结构已经创建完成。

参考

https://gitee.com/kidKing/ruoyi-docker-flyway

Docker常用命令记录

作者 宋浩志
2022年9月7日 10:30

本篇文章以安装MySQL数据库为例子,记录Docker常用命令

安装docker

1
yum install docker -y

docker容器互联

新建网络

1
docker network create my-net

列出所有网络

1
docker network ls

将容器连接到网络

1
docker network connect my-net mysql

断开容器的网络

1
docker network disconnect my-net mysql

删除一个或多个网络

1
docker network rm my-net

docker客户端

容器使用

搜索镜像

这里我们搜索mysql镜像

1
docker search mysql

获取MySQL镜像

下载需要的版本docker pull mysql:tag

tag代表版本号,没有代表是lastest

1
docker pull docker.io/mysql:5.7.26

列出本地镜像

1
docker images [OPTIONS] [REPOSITORY[:TAG]]

OPTIONS说明

  • -a :列出本地所有的镜像(含中间映像层,默认情况下,过滤掉中间映像层);

  • –digests :显示镜像的摘要信息;

  • -f :显示满足条件的镜像;

  • –format :指定返回值的模板文件;

  • –no-trunc :显示完整的镜像信息;

  • -q :只显示镜像ID。

创建 MySQL 数据目录

1
mkdir -p /opt/mysql

启动MySQL实例

1
docker run --name mysql -p 3306:3306 --privileged=true -v /opt/mysql/log:/var/log/mysql -v /opt/mysql/conf:/etc/mysql -v /opt/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --net my-net --restart=unless-stopped -d mysql:5.7.26

Tips

  • -e MYSQL_ROOT_PASSWORD=123456命令: 指定MySQL的登录密码为 123456

  • -v /opt/mysql/data:/var/lib/mysql 命令: 将宿主机的目录 /opt/mysql 挂载到容器内部的目录 /var/lib/mysql,默认情况下 MySQL 将向 /opt/mysql 写入其数据文件。

  • -v /opt/mysql/conf:/etc/mysql命令:MySQL配置文件存放位置

  • -v /opt/mysql/log:/var/log/mysql命令:MySQL日志文件

  • --net my-net命令: 将该容器加入到 my-net 网络,连接到 my-net 网络的任何其他容器都可以访问 mysql 容器上的所有端口。

  • --restart=unless-stopped命令:在容器退出时总是重启容器,但是不考虑在Docker守护进程启动时就已经停止了的容器

  • -d命令:表示后台运行

  • -p 3306:3306命令:端口映射

  • --privileged=true命令:container内的root拥有真正的root权限

查看docker容器运行情况

1
docker ps

查看所有的容器

1
docker ps -a

启动一个已停止的容器

1
docker start器id

停止一个容器

1
docker stop <容器 ID>

停止的容器可以通过 docker restart 重启:

1
docker restart <容器 ID>

进入MySQL容器

1
docker exec -it mysql /bin/bash

Tips

  • -i: 交互式操作。
  • -t: 终端。
  • mysql: mysql 镜像。
  • /bin/bash:放在镜像名后的是命令,这里我们希望有个交互式 Shell,因此用的是 /bin/bash。

退出容器

1
exit

参考

https://www.runoob.com/docker/docker-tutorial.html

https://docs.halo.run/getting-started/install/other/docker-mysql

https://www.yiibai.com/docker/docker-introduction.html

https://www.jianshu.com/p/68ec752f0454

❌
❌