前言
公司用的这个数据库服了, 又老,而且没玩过, 吐槽结束
经过了我大量从网上借鉴,并且自身反复试验之后, 一套可行的方案如下
项目结构
maven
sqlserver
这个依赖可以使用 jdk8 和11
注意:
- jdk11 我试验了多次 支持 jdk11.0.8 版本,还有一些小版本没测过(都是血泪史啊)
- 这个依赖在阿里的云效仓库可以搜到, https://developer.aliyun.com/mvn/search
- 如果你的mavan 文件无法导入, 可以现在云效仓库下载后本地导入
- 或者 maven 配置文件中 仓库地址 改为
https://maven.aliyun.com/repository/public
<dependency>
<groupId>com.microsoft.sqlserver</groupId>
<artifactId>sqljdbc4</artifactId>
<version>4.0.0</version>
</dependency>
我所有的 maven 配置
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.7.17</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.tk</groupId>
<artifactId>tk-oa-platform</artifactId>
<version>1.0.1</version>
<properties>
<java.version>11</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-validation</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
<version>5.8.16</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.5.2</version>
</dependency>
<!--sqlserver驱动的依赖包 对应jdk11.0.8 jdk8u131-->
<dependency>
<groupId>com.microsoft.sqlserver</groupId>
<artifactId>sqljdbc4</artifactId>
<version>4.0.0</version>
</dependency>
<!--swagger 接口文档-->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-boot-starter</artifactId>
<version>3.0.0</version>
</dependency>
<!--xxl-job-->
<!-- <dependency>-->
<!-- <groupId>com.xuxueli</groupId>-->
<!-- <artifactId>xxl-job-core</artifactId>-->
<!-- <version>2.4.0</version>-->
<!-- </dependency>-->
<!-- <dependency>-->
<!-- <groupId>org.springframework.boot</groupId>-->
<!-- <artifactId>spring-boot-starter-data-redis</artifactId>-->
<!-- </dependency>-->
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<excludes>
<exclude>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</exclude>
</excludes>
</configuration>
</plugin>
<plugin>
<groupId>com.spotify</groupId>
<artifactId>dockerfile-maven-plugin</artifactId>
<version>1.4.13</version>
<executions>
<execution>
<id>default</id>
<goals>
<goal>build</goal>
</goals>
</execution>
</executions>
<configuration>
<repository>${project.artifactId}</repository>
<tag>latest</tag>
<dockerfile>Dockerfile</dockerfile>
<contextDirectory>.</contextDirectory>
</configuration>
</plugin>
</plugins>
</build>
</project>
yaml
spring:
datasource:
driver-class-name: com.microsoft.sqlserver.jdbc.SQLServerDriver
url: jdbc:sqlserver://10.30.10.10:1433;DatabaseName=ecology
username: sa
password: xxxx
mybatis-plus:
configuration:
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
mapper-locations: classpath:mapper/*.xml
MapperConfig
@Configuration
@MapperScan(value = "com.tk.oa.mapper")
public class MapperConfig {
@Bean // 如果不适用分页插件, 则下面的代码不用加
public MybatisPlusInterceptor mybatisPlusInterceptor() {
MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor();
mybatisPlusInterceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.SQL_SERVER2005)); // 高版本使用SQL_SERVER
return mybatisPlusInterceptor;
}
}
idea 数据库链接工具
注意: 当第一次测试连接会报错, 报错会有一些启用选项 , 启用tsl1就行了,(具体名字忘记了…)
Dockerfile
另外送大家一个 Dockerfile 案例
# 基础镜像
FROM 17786925624/jdk:11.0.8
# 维护人
LABEL maintainer="shenchen<17786925624@163.com>"
# 创建目录
RUN mkdir -p /data/app
#指定挂载目录
VOLUME /data
# 拷贝项目jar
COPY target/*.jar /data/app/tk-oa-platform.jar
# 设置时区
ENV TZ=Asia/Shanghai
# 执行命令启动jar
ENTRYPOINT ["java","-jar","/data/app/tk-oa-platform.jar"]
CMD ["--spring.profiles.active=pro"]
我还特地jdk:11.0.8 做成镜像 上传到 仓库中,哈哈哈