logo 范 · 拾光录
网址收集 关于作者 Github Gitee
杂文随笔5
Hexo博客:基础使用Hexo博客:Next主题Hexo博客:Next进阶使用Hexo博客:Next高级配置基于Node的WIKI管理
前端知识16
HTML常用知识CSS常用知识CSS美化checkbox复选框JavaScript常用知识JavaScript格式化时间戳JavaScript窗口宽高处理JavaScript黑夜主题切换实现方案JavaScript数字转大写简易图片查看器TypeScript基础知识Threejs基础三要素Threejs网格辅助和轨道控制器Threejs物体绘制Electron基础使用Nodejs基础知识animate.css页面动画
Vue框架19
Vite的使用及扩展Vue3父子组件Vue3使用Marked解析MarkdownMermaid图表生成库初始化页面加载动画Axios表单提交二维码解决方案NProgress加载进度条Vue3动态菜单实现Vue3使用ECharts图表Vue3处理Excel导入导出keep-alive页面缓存及setup问题Element:文件上传Element:结合Pinia实现动态菜单Element:图片上传组件Element:自定义统一弹窗组件Element:表格自定义指令控制按钮显示(鉴权)可视化大屏使用缩放适配分辨率
UniApp15
UniApp的基础使用封装网络请求工具及文件上传uni-app的开发记录微信小程序分享原生文件上传Pinia取消滚动条(兼容小程序)tabbar消息数量显示scroll-view上滑到底部加载数据状态栏高度动态设配数据共享与传递uview-plus导航栏实现背景融合Wot UIWot UI实现顶部背景图融合uni-app x
Java基础知识10
基础知识面向对象Lambda表达式常用API常用知识积累try-with-resource注解反射多线程经纬度距离计算
SpringBoot31
application配置Maven创建聚合项目全局异常处理锁机制项目启动初始化数据方式邮件功能集成原生定时任务异步集成阿里云OSS阿里OSS预签名上传基于hutool读excelJSR303WebSocketWebSocket版AI接口流式调用Smart-Doc接口文档生成器application配置信息加密雪花算法工具AOP实现请求参数脱敏思路JWT生成Token及工具类SpringBoot默认JSON与对象转换若依框架:安装使用若依框架:优化和调整文件上传若依框架:管理后台页面优化若依框架:后端接口代码优化SpringAISpringBoot实现AI接口流式调用服务启动时创建MySQL连接自建项目工程树形结构处理工具微信支付代码微信手机号登录
SpringMVC14
跨域处理拦截器RESTful风格伪前后端分离Jackson转换器调整Thymeleaf基于拦截器做权限校验AOP打印接口请求响应日志AOP打印接口请求响应耗时文件上传和回显POST请求加解密实现(AES)POST请求加解密实现(RSA+AES)参数动态校验实现方案真实IP和归属地
MyBatis8
MyBatis基本使用与配置Mapper使用相关MaBatis多数据源配置MyBatisPlus数据统计类处理方案MyBatisPlus条件查询正向工程的实现(H2)mybatis-plus-join
SpringCloud15
Netflix:微服务与搭建Netflix:服务的消费与提供Netflix:EurekaNetflix:ActuatorNetflix:RibbonNetflix:FeignNetflix:HystrixNetflix:ZuulAlibaba:简介与搭建Alibaba:Nacos注册中心Alibaba:RibbonAlibaba:OpenFeignAlibaba:Nacos配置中心Alibaba:GetewayAlibaba:Sentinel
MySQL6
MySQL基础知识MySQL多表查询与事务MySQL常用函数及解决方案MySQL视图MySQL索引安装MySQL
Redis7
Redis介绍和安装Redis配置文件Redis持久化Redis集群Redis语法基础Redis相关问题及解决方案SpringBoot集成Redis使用记录
MongoDB10
Linux安装MongoDBMongoDB基础语法MongoTemplate及SpringBoot配置MongoTemplate中Update操作MongoTemplate中聚合查询MongoTemplate日期归档示例项目使用相关知识归纳地理位置存储与距离查询MongoDB副本集与事务获取类名和属性名工具类
其他数据库1
H2数据库
Python编程6
Python基础知识Python语法yolo目标检测OpenCV的使用及树莓派平台condauv
工具集合13
IDEAMavenGradleGitNginx安装Nginx配置VSCodeJMeter压测DockerOllamaRustFSPicGoObs录制
Linux知识11
Linux常用命令Jar启动脚本VirtualBox安装CentOSVirtualBox安装Ubuntu树莓派安装及使用frp内网穿透ArchLinux:基础系统安装ArchLInux:图形化界面安装ArchLinux:常用软件ArchLinux:深度优化ArchLinux:Niri
创意设计2
Blender:入门知识UI设计基础知识
AI相关9
Claude CodeHermes AgentOpenAI基本使用OpenAI工具调用OpenAI记忆管理OpenAI推理执行OpenAI开发框架Langchainllama.cpp

配置文件格式

Spring Boot的配置文件支持.properties.yml.yaml三种格式,依次优先级降低

多环境示例

# 端口
server:
  port: 8000

# 环境
spring:
  # test-测试,prod-正式
  profiles:
    active: test
  # 上传文件大小
  servlet:
    multipart:
      max-file-size: 10MB
      max-request-size: 10MB

# mybatis
mybatis:
  configuration:
    # 链接超时时间
    default-statement-timeout: 30
    # 开启驼峰命名规则映射(用于数据返回映射到实体类)
    map-underscore-to-camel-case: true

---
# 测试环境
spring:
  profiles: test
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/blog_fan?serverTimezone=GMT%2B8&characterEncoding=utf8
    username: root
    password: 123456

# 日志级别
logging:
  level:
    com.fan.blog: debug

# 文件保存路径
filesPath: 'D://P_files'

---
# 正式环境
spring:
  profiles: prod
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/blog_fan?serverTimezone=GMT%2B8&characterEncoding=utf8
    username: root
    password: 123456

# 日志级别
logging:
  level:
    com.fan.blog: error

# 文件保存路径
filesPath: '/home/files'
---

高版本多环境改动

---

spring:
  # 开发
  config:
    activate:
      on-profile: dev
  # 数据库
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://192.168.56.100:3306/fans?serverTimezone=GMT%2B8&characterEncoding=utf8
    username: authUser
    password: 123456

多环境文件拆分

application.yml配置

# 配置
spring:
  application:
    name: project-admin
  # 环境
  profiles:
    active: dev

application-dev.yml配置

# 配置
spring:
  config:
    activate:
      on-profile: dev

时间格式配置

spring:
  # 时间格式化
  jackson:
    date-format: yyyy-MM-dd HH:mm:ss
    time-zone: Asia/Shanghai

SpringBoot2.x启动执行SQL脚本

# SQL脚本
spring:
  sql:
    init:
      mode: always
      data-locations: classpath:table.sql

sql的书写方式

-- 测试
create table if not exists `test` (
    `id`   bigint primary key,
    `name` varchar(255)
);

-- 新增不存在字段暂时无法解决,存储过程运行报错

MySQL字段不存在则添加

MySQL需要利用存储过程实现

DROP PROCEDURE IF EXISTS pro_add_column;

DELIMITER $

CREATE PROCEDURE pro_add_column(
    IN tablename VARCHAR(50),
    IN colname VARCHAR(50),
    IN coltype VARCHAR(20),
    IN coldesc VARCHAR(50) )

BEGIN
	if not exists(select 1 from information_schema.`COLUMNS` where table_name=tablename and column_name=colname) then
		set @sqlStr = CONCAT('alter table ',tablename,' add ', colname, ' ',coltype,' ', ' COMMENT ',  coldesc);
prepare sqlStr from @sqlStr;
execute sqlStr;
end if;
END $

DELIMITER;

使用方式
--表名, 字段名, 字段类型, 注释
CALL pro_add_column('test_table', 'count', 'int default 0', '''数量''');

自定义启动Banner

SpringBoot Banner生成:在resources下新建banner.txt

nginx代理后真实IP获取

nginx配置

# 可以获取到客户端真实IP
proxy_set_header Host                           $host;
proxy_set_header X-Real-IP                      $remote_addr;
proxy_set_header X-Forwarded-For                $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto              $scheme;
proxy_redirect                                  off;

tomcat配置

# 端口
server:
  forward-headers-strategy: framework
  tomcat:
    remoteip:
      host-header: X-Real-IP
      protocol-header: X-Forwarded-Proto

获取配置文件中的配置项

在启动类里获取

@SpringBootApplication
public class MylslApplication {
 
    public static void main(String[] args) {
        ConfigurableApplicationContext context = SpringApplication.run(MylslApplication.class, args);
        System.err.println("local.ip=" + context.getEnvironment().getProperty("local.ip"));
    }
 
}

在类中利用Environment获取

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.core.env.Environment;
import org.springframework.stereotype.Component;
 
@Component
public class MyConfig {
 
    @Autowired
    private Environment env;
 
    public void show(){
        System.err.println("MyConfig---local.ip=" + env.getProperty("local.ip"));
    }
}

在类中利用@Value注解获取,直接赋值给属性

缺点,如果没有配置会报错

package com.lsl.mylsl;
 
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.core.env.Environment;
import org.springframework.stereotype.Component;
 
@Component
public class MyConfig {
 
    @Autowired
    private Environment env;
 
    @Value("${local.port}")
    private String localPort;
 
    public void show(){
        System.err.println("MyConfig---local.ip=" + env.getProperty("local.ip"));
        System.err.println("MyConfig---local.port=" + env.getProperty("local.port"));
    }
}

配置文件4级分类

解决不同人员对项目管理的需求,开发者无法知晓真正信息

多环境分组

日志分组和记录

日志的打印推荐分组配置

# 日志级别
logging:
  # 分组设置
  group:
    controller: com.fan.controller
    service: com.fan.service
    dao: com.fan.mapper
  # 级别指定
  level:
    root: warn
    controller: debug
    service: debug
    dao: warn
  # 滚动日志
  logback:
    rolling policy:
      max-file-size: 1MB
      file-name-pattern: server.%d{yyyy-MM-dd}.%i.log

优先获取系统变量

spring:
  datasource:
    username: ${DB_USER:root}

服务会先在系统环境变量中获取值,如果获取不到则使用默认值为root

日志

# 日志级别
logging:
  level:
    com.fan: debug
  file:
    # 位置和名称
    name: ./log/log.log
  logback:
    rolling policy:
      # 日志文件最大大小
      max-file-size: 10MB
      # 保留的旧日志文件数量
      max-history: 7

连接池配置

防止断开

  # 数据库
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://8.137.9.75:3306/school?serverTimezone=GMT%2B8&characterEncoding=utf8
    username: userxs
    password: xs0307
    hikari:
      # 连接超时
      connection-timeout: 10000
      # 最大连接数
      maximum-pool-size: 10
      # 最小连接数
      minimum-idle: 5
      # 10分钟
      idle-timeout: 600000
      # 30分钟
      max-lifetime: 1800000
      connection-test-query: SELECT 1
配置文件格式
多环境示例
高版本多环境改动
多环境文件拆分
时间格式配置
SpringBoot2.x启动执行SQL脚本
MySQL字段不存在则添加
自定义启动Banner
nginx代理后真实IP获取
获取配置文件中的配置项
在启动类里获取
在类中利用Environment获取
在类中利用@Value注解获取,直接赋值给属性
配置文件4级分类
多环境分组
日志分组和记录
优先获取系统变量
日志
连接池配置