新项目,发现有使用CommandLineRunner ,故百度搜索一下用法以及使用场景,特记之。
两者功能相同,都是在Spring容器初始化完毕之后执行起run方法,不同之处参数不一样。
CommandLineRunner 的run方法参数是String…args,直接传入字符串;
ApplicationRunner 的run方法参数数ApplicationArguments ,对参数进行了封装。
执行顺序CommandLineRunner 在前,ApplicationRunner在后
参考:https://blog.csdn.net/lk142500/article/details/90270592
遇到问题:
1.项目启动,数据库链接超时
自己马虎造成的问题,sqlserver默认端口是1433,写成1443,所以链接失败
2.console提示如下错误:TLSv1 was negotiated. Please update server and client to use TLSv1.2 at minimum.
网上有人说是因为mssql-jdbc版本问题,
到maven 仓库找一个低版本的试试,发现可以解决问题
3.做了实验,在StartInitService2中添加了一个sleep(10000)的操作,发现AppApplication - after 是要等到这个sleep执行完成,后才打印,所以万一StartInitService2 执行时间更长,或者期间有报错,是否就影响到了主程序的运行?带着疑问继续探索…
现在做以下修改:故意抛出一个异常。
发现,在未执行到除0之前,访问项目是可以正常的,但是当系统出现java.lang.ArithmeticException: / by zero异常后,项目就不能正常访问了,同时StartInitService和AppApplication - after也不能正常打印。
总结:如果要使用CommandLineRunner 或 ApplicationRunner ,一定要慎重,要不然就会影响项目的运行。