member:启动成功,基本跑通
							parent
							
								
									625e62ef9d
								
							
						
					
					
						commit
						323d160d61
					
				|  | @ -37,6 +37,19 @@ spring: | |||
|           uri: grayLb://infra-server | ||||
|           predicates: # 断言,作为路由的匹配条件,对应 RouteDefinition 数组 | ||||
|             - Path=/admin/** | ||||
|         ## member-server 服务 | ||||
|         - id: member-admin-api # 路由的编号 | ||||
|           uri: grayLb://member-server | ||||
|           predicates: # 断言,作为路由的匹配条件,对应 RouteDefinition 数组 | ||||
|             - Path=/admin-api/member/** | ||||
|           filters: | ||||
|             - RewritePath=/admin-api/member/v3/api-docs, /v3/api-docs | ||||
|         - id: member-app-api # 路由的编号 | ||||
|           uri: grayLb://member-server | ||||
|           predicates: # 断言,作为路由的匹配条件,对应 RouteDefinition 数组 | ||||
|             - Path=/app-api/member/** | ||||
|           filters: | ||||
|             - RewritePath=/app-api/member/v3/api-docs, /v3/api-docs | ||||
|         ## bpm-server 服务 | ||||
|         - id: bpm-admin-api # 路由的编号 | ||||
|           uri: grayLb://bpm-server | ||||
|  | @ -85,6 +98,9 @@ knife4j: | |||
|       - name: infra-server | ||||
|         service-name: infra-server | ||||
|         url: /admin-api/infra/v3/api-docs | ||||
|       - name: member-server | ||||
|         service-name: member-server | ||||
|         url: /admin-api/member/v3/api-docs | ||||
|       - name: bpm-server | ||||
|         service-name: bpm-server | ||||
|         url: /admin-api/bpm/v3/api-docs | ||||
|  |  | |||
|  | @ -0,0 +1,19 @@ | |||
| ## AdoptOpenJDK 停止发布 OpenJDK 二进制,而 Eclipse Temurin 是它的延伸,提供更好的稳定性 | ||||
| ## 感谢复旦核博士的建议!灰子哥,牛皮! | ||||
| FROM eclipse-temurin:8-jre | ||||
| 
 | ||||
| ## 创建目录,并使用它作为工作目录 | ||||
| RUN mkdir -p /yudao-module-member-biz | ||||
| WORKDIR /yudao-module-member-biz | ||||
| ## 将后端项目的 Jar 文件,复制到镜像中 | ||||
| COPY ./target/yudao-module-member-biz.jar app.jar | ||||
| 
 | ||||
| ## 设置 TZ 时区 | ||||
| ## 设置 JAVA_OPTS 环境变量,可通过 docker run -e "JAVA_OPTS=" 进行覆盖 | ||||
| ENV TZ=Asia/Shanghai JAVA_OPTS="-Xms512m -Xmx512m" | ||||
| 
 | ||||
| ## 暴露后端项目的 48080 端口 | ||||
| EXPOSE 48087 | ||||
| 
 | ||||
| ## 启动后端项目 | ||||
| CMD java ${JAVA_OPTS} -Djava.security.egd=file:/dev/./urandom -jar app.jar | ||||
|  | @ -18,6 +18,18 @@ | |||
|     </description> | ||||
| 
 | ||||
|     <dependencies> | ||||
|         <!-- Spring Cloud 基础 --> | ||||
|         <dependency> | ||||
|             <groupId>org.springframework.cloud</groupId> | ||||
|             <artifactId>spring-cloud-starter-bootstrap</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.cloud</groupId> | ||||
|             <artifactId>yudao-spring-boot-starter-env</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- 依赖服务 --> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.cloud</groupId> | ||||
|             <artifactId>yudao-module-member-api</artifactId> | ||||
|  | @ -66,6 +78,24 @@ | |||
|             <artifactId>yudao-spring-boot-starter-redis</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- RPC 远程调用相关 --> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.cloud</groupId> | ||||
|             <artifactId>yudao-spring-boot-starter-rpc</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- Registry 注册中心相关 --> | ||||
|         <dependency> | ||||
|             <groupId>com.alibaba.cloud</groupId> | ||||
|             <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- Config 配置中心相关 --> | ||||
|         <dependency> | ||||
|             <groupId>com.alibaba.cloud</groupId> | ||||
|             <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- 消息队列相关 --> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.cloud</groupId> | ||||
|  | @ -90,6 +120,11 @@ | |||
|             <artifactId>yudao-spring-boot-starter-biz-ip</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- 监控相关 --> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.cloud</groupId> | ||||
|             <artifactId>yudao-spring-boot-starter-monitor</artifactId> | ||||
|         </dependency> | ||||
|     </dependencies> | ||||
| 
 | ||||
| </project> | ||||
|  |  | |||
|  | @ -0,0 +1,30 @@ | |||
| package cn.iocoder.yudao.module.member; | ||||
| 
 | ||||
| import org.springframework.boot.SpringApplication; | ||||
| import org.springframework.boot.autoconfigure.SpringBootApplication; | ||||
| 
 | ||||
| /** | ||||
|  * 项目的启动类 | ||||
|  * | ||||
|  * 如果你碰到启动的问题,请认真阅读 https://cloud.iocoder.cn/quick-start/ 文章
 | ||||
|  * 如果你碰到启动的问题,请认真阅读 https://cloud.iocoder.cn/quick-start/ 文章
 | ||||
|  * 如果你碰到启动的问题,请认真阅读 https://cloud.iocoder.cn/quick-start/ 文章
 | ||||
|  * | ||||
|  * @author 芋道源码 | ||||
|  */ | ||||
| @SpringBootApplication | ||||
| public class MemberServerApplication { | ||||
| 
 | ||||
|     public static void main(String[] args) { | ||||
|         // 如果你碰到启动的问题,请认真阅读 https://cloud.iocoder.cn/quick-start/ 文章
 | ||||
|         // 如果你碰到启动的问题,请认真阅读 https://cloud.iocoder.cn/quick-start/ 文章
 | ||||
|         // 如果你碰到启动的问题,请认真阅读 https://cloud.iocoder.cn/quick-start/ 文章
 | ||||
| 
 | ||||
|         SpringApplication.run(MemberServerApplication.class, args); | ||||
| 
 | ||||
|         // 如果你碰到启动的问题,请认真阅读 https://cloud.iocoder.cn/quick-start/ 文章
 | ||||
|         // 如果你碰到启动的问题,请认真阅读 https://cloud.iocoder.cn/quick-start/ 文章
 | ||||
|         // 如果你碰到启动的问题,请认真阅读 https://cloud.iocoder.cn/quick-start/ 文章
 | ||||
|     } | ||||
| 
 | ||||
| } | ||||
|  | @ -121,7 +121,7 @@ public class AppAuthController { | |||
|             description = "参考 https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/JS-SDK.html 文档") | ||||
|     public CommonResult<SocialWxJsapiSignatureRespDTO> createWeixinMpJsapiSignature(@RequestParam("url") String url) { | ||||
|         SocialWxJsapiSignatureRespDTO signature = socialClientApi.createWxMpJsapiSignature( | ||||
|                 UserTypeEnum.MEMBER.getValue(), url); | ||||
|                 UserTypeEnum.MEMBER.getValue(), url).getCheckedData(); | ||||
|         return success(AuthConvert.INSTANCE.convert(signature)); | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -0,0 +1,13 @@ | |||
| package cn.iocoder.yudao.module.member.framework.rpc.config; | ||||
| 
 | ||||
| import cn.iocoder.yudao.module.system.api.logger.LoginLogApi; | ||||
| import cn.iocoder.yudao.module.system.api.sms.SmsCodeApi; | ||||
| import cn.iocoder.yudao.module.system.api.social.SocialClientApi; | ||||
| import cn.iocoder.yudao.module.system.api.social.SocialUserApi; | ||||
| import org.springframework.cloud.openfeign.EnableFeignClients; | ||||
| import org.springframework.context.annotation.Configuration; | ||||
| 
 | ||||
| @Configuration(proxyBeanMethods = false) | ||||
| @EnableFeignClients(clients = {SmsCodeApi.class, LoginLogApi.class, SocialUserApi.class, SocialClientApi.class}) | ||||
| public class RpcConfiguration { | ||||
| } | ||||
|  | @ -0,0 +1,4 @@ | |||
| /** | ||||
|  * 占位 | ||||
|  */ | ||||
| package cn.iocoder.yudao.module.member.framework.rpc; | ||||
|  | @ -0,0 +1,37 @@ | |||
| package cn.iocoder.yudao.module.member.framework.security.config; | ||||
| 
 | ||||
| import cn.iocoder.yudao.framework.security.config.AuthorizeRequestsCustomizer; | ||||
| import cn.iocoder.yudao.module.system.enums.ApiConstants; | ||||
| import org.springframework.context.annotation.Bean; | ||||
| import org.springframework.context.annotation.Configuration; | ||||
| import org.springframework.security.config.annotation.web.builders.HttpSecurity; | ||||
| import org.springframework.security.config.annotation.web.configurers.ExpressionUrlAuthorizationConfigurer; | ||||
| 
 | ||||
| /** | ||||
|  * Member 模块的 Security 配置 | ||||
|  */ | ||||
| @Configuration("memberSecurityConfiguration") | ||||
| public class SecurityConfiguration { | ||||
| 
 | ||||
|     @Bean("payAuthorizeRequestsCustomizer") | ||||
|     public AuthorizeRequestsCustomizer authorizeRequestsCustomizer() { | ||||
|         return new AuthorizeRequestsCustomizer() { | ||||
| 
 | ||||
|             @Override | ||||
|             public void customize(ExpressionUrlAuthorizationConfigurer<HttpSecurity>.ExpressionInterceptUrlRegistry registry) { | ||||
|                 // Swagger 接口文档
 | ||||
|                 registry.antMatchers("/v3/api-docs/**").permitAll() // 元数据
 | ||||
|                         .antMatchers("/swagger-ui.html").permitAll(); // Swagger UI
 | ||||
|                 // Spring Boot Actuator 的安全配置
 | ||||
|                 registry.antMatchers("/actuator").anonymous() | ||||
|                         .antMatchers("/actuator/**").anonymous(); | ||||
|                 // Druid 监控
 | ||||
|                 registry.antMatchers("/druid/**").anonymous(); | ||||
|                 // RPC 服务的安全配置
 | ||||
|                 registry.antMatchers(ApiConstants.PREFIX + "/**").permitAll(); | ||||
|             } | ||||
| 
 | ||||
|         }; | ||||
|     } | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,4 @@ | |||
| /** | ||||
|  * 占位 | ||||
|  */ | ||||
| package cn.iocoder.yudao.module.member.framework.security.core; | ||||
|  | @ -1,8 +1,6 @@ | |||
| package cn.iocoder.yudao.module.member.mq.message.user; | ||||
| 
 | ||||
| import cn.iocoder.yudao.framework.mq.core.stream.AbstractStreamMessage; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| 
 | ||||
| import javax.validation.constraints.NotNull; | ||||
| 
 | ||||
|  | @ -12,8 +10,7 @@ import javax.validation.constraints.NotNull; | |||
|  * @author owen | ||||
|  */ | ||||
| @Data | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| public class UserCreateMessage extends AbstractStreamMessage { | ||||
| public class UserCreateMessage { | ||||
| 
 | ||||
|     /** | ||||
|      * 用户编号 | ||||
|  | @ -21,9 +18,4 @@ public class UserCreateMessage extends AbstractStreamMessage { | |||
|     @NotNull(message = "用户编号不能为空") | ||||
|     private Long userId; | ||||
| 
 | ||||
|     @Override | ||||
|     public String getStreamKey() { | ||||
|         return "member.create.send"; | ||||
|     } | ||||
| 
 | ||||
| } | ||||
|  |  | |||
|  | @ -1,31 +1,33 @@ | |||
| package cn.iocoder.yudao.module.member.mq.producer.user; | ||||
| 
 | ||||
| import cn.iocoder.yudao.framework.mq.core.RedisMQTemplate; | ||||
| import cn.iocoder.yudao.framework.mq.core.bus.AbstractBusProducer; | ||||
| import cn.iocoder.yudao.module.member.mq.message.user.UserCreateMessage; | ||||
| import lombok.extern.slf4j.Slf4j; | ||||
| import org.springframework.cloud.stream.function.StreamBridge; | ||||
| import org.springframework.stereotype.Component; | ||||
| 
 | ||||
| import javax.annotation.Resource; | ||||
| 
 | ||||
| /** | ||||
|  * 会员用户创建 Producer | ||||
|  * 会员用户 Producer | ||||
|  * | ||||
|  * @author owen | ||||
|  */ | ||||
| @Slf4j | ||||
| @Component | ||||
| public class UserCreateProducer { | ||||
| public class MemberUserProducer extends AbstractBusProducer { | ||||
| 
 | ||||
|     @Resource | ||||
|     private RedisMQTemplate redisMQTemplate; | ||||
|     private StreamBridge streamBridge; | ||||
| 
 | ||||
|     // TODO 芋艿:后续要在细看下;
 | ||||
|     /** | ||||
|      * 发送 {@link UserCreateMessage} 消息 | ||||
|      * | ||||
|      * @param userId 用户编号 | ||||
|      */ | ||||
|     public void sendUserCreateMessage(Long userId) { | ||||
|         redisMQTemplate.send(new UserCreateMessage().setUserId(userId)); | ||||
|         streamBridge.send("member-create-out-0",new UserCreateMessage().setUserId(userId)); | ||||
|     } | ||||
| 
 | ||||
| } | ||||
|  | @ -69,7 +69,7 @@ public class MemberAuthServiceImpl implements MemberAuthService { | |||
|         String openid = null; | ||||
|         if (reqVO.getSocialType() != null) { | ||||
|             openid = socialUserApi.bindSocialUser(new SocialUserBindReqDTO(user.getId(), getUserType().getValue(), | ||||
|                     reqVO.getSocialType(), reqVO.getSocialCode(), reqVO.getSocialState())); | ||||
|                     reqVO.getSocialType(), reqVO.getSocialCode(), reqVO.getSocialState())).getCheckedData(); | ||||
|         } | ||||
| 
 | ||||
|         // 创建 Token 令牌,记录登录日志
 | ||||
|  | @ -91,7 +91,7 @@ public class MemberAuthServiceImpl implements MemberAuthService { | |||
|         String openid = null; | ||||
|         if (reqVO.getSocialType() != null) { | ||||
|             openid = socialUserApi.bindSocialUser(new SocialUserBindReqDTO(user.getId(), getUserType().getValue(), | ||||
|                     reqVO.getSocialType(), reqVO.getSocialCode(), reqVO.getSocialState())); | ||||
|                     reqVO.getSocialType(), reqVO.getSocialCode(), reqVO.getSocialState())).getCheckedData(); | ||||
|         } | ||||
| 
 | ||||
|         // 创建 Token 令牌,记录登录日志
 | ||||
|  | @ -102,7 +102,7 @@ public class MemberAuthServiceImpl implements MemberAuthService { | |||
|     public AppAuthLoginRespVO socialLogin(AppAuthSocialLoginReqVO reqVO) { | ||||
|         // 使用 code 授权码,进行登录。然后,获得到绑定的用户编号
 | ||||
|         SocialUserRespDTO socialUser = socialUserApi.getSocialUser(UserTypeEnum.MEMBER.getValue(), reqVO.getType(), | ||||
|                 reqVO.getCode(), reqVO.getState()); | ||||
|                 reqVO.getCode(), reqVO.getState()).getCheckedData(); | ||||
|         if (socialUser == null) { | ||||
|             throw exception(AUTH_THIRD_LOGIN_NOT_BIND); | ||||
|         } | ||||
|  | @ -121,7 +121,7 @@ public class MemberAuthServiceImpl implements MemberAuthService { | |||
|     public AppAuthLoginRespVO weixinMiniAppLogin(AppAuthWeixinMiniAppLoginReqVO reqVO) { | ||||
|         // 获得对应的手机号信息
 | ||||
|         SocialWxPhoneNumberInfoRespDTO phoneNumberInfo = socialClientApi.getWxMaPhoneNumberInfo( | ||||
|                 UserTypeEnum.MEMBER.getValue(), reqVO.getPhoneCode()); | ||||
|                 UserTypeEnum.MEMBER.getValue(), reqVO.getPhoneCode()).getCheckedData(); | ||||
|         Assert.notNull(phoneNumberInfo, "获得手机信息失败,结果为空"); | ||||
| 
 | ||||
|         // 获得获得注册用户
 | ||||
|  | @ -131,7 +131,7 @@ public class MemberAuthServiceImpl implements MemberAuthService { | |||
| 
 | ||||
|         // 绑定社交用户
 | ||||
|         String openid = socialUserApi.bindSocialUser(new SocialUserBindReqDTO(user.getId(), getUserType().getValue(), | ||||
|                 SocialTypeEnum.WECHAT_MINI_APP.getType(), reqVO.getLoginCode(), "")); | ||||
|                 SocialTypeEnum.WECHAT_MINI_APP.getType(), reqVO.getLoginCode(), "")).getCheckedData(); | ||||
| 
 | ||||
|         // 创建 Token 令牌,记录登录日志
 | ||||
|         return createTokenAfterLoginSuccess(user, user.getMobile(), LoginLogTypeEnum.LOGIN_SOCIAL, openid); | ||||
|  | @ -144,14 +144,14 @@ public class MemberAuthServiceImpl implements MemberAuthService { | |||
|         // 创建 Token 令牌
 | ||||
|         OAuth2AccessTokenRespDTO accessTokenRespDTO = oauth2TokenApi.createAccessToken(new OAuth2AccessTokenCreateReqDTO() | ||||
|                 .setUserId(user.getId()).setUserType(getUserType().getValue()) | ||||
|                 .setClientId(OAuth2ClientConstants.CLIENT_ID_DEFAULT)); | ||||
|                 .setClientId(OAuth2ClientConstants.CLIENT_ID_DEFAULT)).getCheckedData(); | ||||
|         // 构建返回结果
 | ||||
|         return AuthConvert.INSTANCE.convert(accessTokenRespDTO, openid); | ||||
|     } | ||||
| 
 | ||||
|     @Override | ||||
|     public String getSocialAuthorizeUrl(Integer type, String redirectUri) { | ||||
|         return socialClientApi.getAuthorizeUrl(type, UserTypeEnum.MEMBER.getValue(), redirectUri); | ||||
|         return socialClientApi.getAuthorizeUrl(type, UserTypeEnum.MEMBER.getValue(), redirectUri).getCheckedData(); | ||||
|     } | ||||
| 
 | ||||
|     private MemberUserDO login0(String mobile, String password) { | ||||
|  | @ -195,7 +195,7 @@ public class MemberAuthServiceImpl implements MemberAuthService { | |||
|     @Override | ||||
|     public void logout(String token) { | ||||
|         // 删除访问令牌
 | ||||
|         OAuth2AccessTokenRespDTO accessTokenRespDTO = oauth2TokenApi.removeAccessToken(token); | ||||
|         OAuth2AccessTokenRespDTO accessTokenRespDTO = oauth2TokenApi.removeAccessToken(token).getCheckedData(); | ||||
|         if (accessTokenRespDTO == null) { | ||||
|             return; | ||||
|         } | ||||
|  | @ -232,7 +232,7 @@ public class MemberAuthServiceImpl implements MemberAuthService { | |||
|     @Override | ||||
|     public AppAuthLoginRespVO refreshToken(String refreshToken) { | ||||
|         OAuth2AccessTokenRespDTO accessTokenDO = oauth2TokenApi.refreshAccessToken(refreshToken, | ||||
|                 OAuth2ClientConstants.CLIENT_ID_DEFAULT); | ||||
|                 OAuth2ClientConstants.CLIENT_ID_DEFAULT).getCheckedData(); | ||||
|         return AuthConvert.INSTANCE.convert(accessTokenDO, null); | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -7,7 +7,6 @@ import cn.hutool.core.util.ObjectUtil; | |||
| import cn.hutool.core.util.StrUtil; | ||||
| import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum; | ||||
| import cn.iocoder.yudao.framework.common.pojo.PageResult; | ||||
| import cn.iocoder.yudao.module.infra.api.file.FileApi; | ||||
| import cn.iocoder.yudao.module.member.controller.admin.user.vo.MemberUserPageReqVO; | ||||
| import cn.iocoder.yudao.module.member.controller.admin.user.vo.MemberUserUpdateReqVO; | ||||
| import cn.iocoder.yudao.module.member.controller.app.user.vo.AppMemberUserResetPasswordReqVO; | ||||
|  | @ -18,7 +17,7 @@ import cn.iocoder.yudao.module.member.convert.auth.AuthConvert; | |||
| import cn.iocoder.yudao.module.member.convert.user.MemberUserConvert; | ||||
| import cn.iocoder.yudao.module.member.dal.dataobject.user.MemberUserDO; | ||||
| import cn.iocoder.yudao.module.member.dal.mysql.user.MemberUserMapper; | ||||
| import cn.iocoder.yudao.module.member.mq.producer.user.UserCreateProducer; | ||||
| import cn.iocoder.yudao.module.member.mq.producer.user.MemberUserProducer; | ||||
| import cn.iocoder.yudao.module.system.api.sms.SmsCodeApi; | ||||
| import cn.iocoder.yudao.module.system.api.sms.dto.code.SmsCodeUseReqDTO; | ||||
| import cn.iocoder.yudao.module.system.enums.sms.SmsSceneEnum; | ||||
|  | @ -29,7 +28,6 @@ import org.springframework.stereotype.Service; | |||
| import org.springframework.transaction.annotation.Transactional; | ||||
| import org.springframework.transaction.support.TransactionSynchronization; | ||||
| import org.springframework.transaction.support.TransactionSynchronizationManager; | ||||
| import org.springframework.transaction.support.TransactionTemplate; | ||||
| 
 | ||||
| import javax.annotation.Resource; | ||||
| import javax.validation.Valid; | ||||
|  | @ -54,8 +52,6 @@ public class MemberUserServiceImpl implements MemberUserService { | |||
|     @Resource | ||||
|     private MemberUserMapper memberUserMapper; | ||||
| 
 | ||||
|     @Resource | ||||
|     private FileApi fileApi; | ||||
|     @Resource | ||||
|     private SmsCodeApi smsCodeApi; | ||||
| 
 | ||||
|  | @ -63,10 +59,7 @@ public class MemberUserServiceImpl implements MemberUserService { | |||
|     private PasswordEncoder passwordEncoder; | ||||
| 
 | ||||
|     @Resource | ||||
|     private UserCreateProducer registerCouponProducer; | ||||
| 
 | ||||
|     @Resource | ||||
|     private TransactionTemplate transactionTemplate; | ||||
|     private MemberUserProducer memberUserProducer; | ||||
| 
 | ||||
|     @Override | ||||
|     public MemberUserDO getUserByMobile(String mobile) { | ||||
|  | @ -107,7 +100,7 @@ public class MemberUserServiceImpl implements MemberUserService { | |||
| 
 | ||||
|             @Override | ||||
|             public void afterCommit() { | ||||
|                 registerCouponProducer.sendUserCreateMessage(user.getId()); | ||||
|                 memberUserProducer.sendUserCreateMessage(user.getId()); | ||||
|             } | ||||
| 
 | ||||
|         }); | ||||
|  |  | |||
|  | @ -0,0 +1,113 @@ | |||
| --- #################### 数据库相关配置 #################### | ||||
| spring: | ||||
|   # 数据源配置项 | ||||
|   autoconfigure: | ||||
|     exclude: | ||||
|       - com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceAutoConfigure # 排除 Druid 的自动配置,使用 dynamic-datasource-spring-boot-starter 配置多数据源 | ||||
|   datasource: | ||||
|     druid: # Druid 【监控】相关的全局配置 | ||||
|       web-stat-filter: | ||||
|         enabled: true | ||||
|       stat-view-servlet: | ||||
|         enabled: true | ||||
|         allow: # 设置白名单,不填则允许所有访问 | ||||
|         url-pattern: /druid/* | ||||
|         login-username: # 控制台管理用户名和密码 | ||||
|         login-password: | ||||
|       filter: | ||||
|         stat: | ||||
|           enabled: true | ||||
|           log-slow-sql: true # 慢 SQL 记录 | ||||
|           slow-sql-millis: 100 | ||||
|           merge-sql: true | ||||
|         wall: | ||||
|           config: | ||||
|             multi-statement-allow: true | ||||
|     dynamic: # 多数据源配置 | ||||
|       druid: # Druid 【连接池】相关的全局配置 | ||||
|         initial-size: 5 # 初始连接数 | ||||
|         min-idle: 10 # 最小连接池数量 | ||||
|         max-active: 20 # 最大连接池数量 | ||||
|         max-wait: 600000 # 配置获取连接等待超时的时间,单位:毫秒 | ||||
|         time-between-eviction-runs-millis: 60000 # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位:毫秒 | ||||
|         min-evictable-idle-time-millis: 300000 # 配置一个连接在池中最小生存的时间,单位:毫秒 | ||||
|         max-evictable-idle-time-millis: 900000 # 配置一个连接在池中最大生存的时间,单位:毫秒 | ||||
|         validation-query: SELECT 1 FROM DUAL # 配置检测连接是否有效 | ||||
|         test-while-idle: true | ||||
|         test-on-borrow: false | ||||
|         test-on-return: false | ||||
|       primary: master | ||||
|       datasource: | ||||
|         master: | ||||
|           name: ruoyi-vue-pro | ||||
|           url: jdbc:mysql://400-infra.server.iocoder.cn:3306/${spring.datasource.dynamic.datasource.master.name}?useSSL=false&allowPublicKeyRetrieval=true&useUnicode=true&characterEncoding=UTF-8&serverTimezone=CTT&nullCatalogMeansCurrent=true | ||||
|           driver-class-name: com.mysql.jdbc.Driver | ||||
|           username: root | ||||
|           password: 3WLiVUBEwTbvAfsh | ||||
|         slave: # 模拟从库,可根据自己需要修改 # 模拟从库,可根据自己需要修改 | ||||
|           name: ruoyi-vue-pro | ||||
|           url: jdbc:mysql://400-infra.server.iocoder.cn:3306/${spring.datasource.dynamic.datasource.slave.name}?useSSL=false&allowPublicKeyRetrieval=true&useUnicode=true&characterEncoding=UTF-8&serverTimezone=CTT&nullCatalogMeansCurrent=true | ||||
|           driver-class-name: com.mysql.jdbc.Driver | ||||
|           username: root | ||||
|           password: 3WLiVUBEwTbvAfsh | ||||
| 
 | ||||
|   # Redis 配置。Redisson 默认的配置足够使用,一般不需要进行调优 | ||||
|   redis: | ||||
|     host: 400-infra.server.iocoder.cn # 地址 | ||||
|     port: 6379 # 端口 | ||||
|     database: 1 # 数据库索引 | ||||
| #    password: 123456 # 密码,建议生产环境开启 | ||||
| 
 | ||||
| --- #################### MQ 消息队列相关配置 #################### | ||||
| spring: | ||||
|   cloud: | ||||
|     stream: | ||||
|       rocketmq: | ||||
|         # RocketMQ Binder 配置项,对应 RocketMQBinderConfigurationProperties 类 | ||||
|         binder: | ||||
|           name-server: 127.0.0.1:9876 # RocketMQ Namesrv 地址 | ||||
| 
 | ||||
| --- #################### 定时任务相关配置 #################### | ||||
| xxl: | ||||
|   job: | ||||
|     admin: | ||||
|       addresses: http://127.0.0.1:9090/xxl-job-admin # 调度中心部署跟地址 | ||||
| 
 | ||||
| --- #################### 服务保障相关配置 #################### | ||||
| 
 | ||||
| # Lock4j 配置项 | ||||
| lock4j: | ||||
|   acquire-timeout: 3000 # 获取分布式锁超时时间,默认为 3000 毫秒 | ||||
|   expire: 30000 # 分布式锁的超时时间,默认为 30 毫秒 | ||||
| 
 | ||||
| --- #################### 监控相关配置 #################### | ||||
| 
 | ||||
| # Actuator 监控端点的配置项 | ||||
| management: | ||||
|   endpoints: | ||||
|     web: | ||||
|       base-path: /actuator # Actuator 提供的 API 接口的根目录。默认为 /actuator | ||||
|       exposure: | ||||
|         include: '*' # 需要开放的端点。默认值只打开 health 和 info 两个端点。通过设置 * ,可以开放所有端点。 | ||||
| 
 | ||||
| # Spring Boot Admin 配置项 | ||||
| spring: | ||||
|   boot: | ||||
|     admin: | ||||
|       # Spring Boot Admin Client 客户端的相关配置 | ||||
|       client: | ||||
|         instance: | ||||
|           service-host-type: IP # 注册实例时,优先使用 IP [IP, HOST_NAME, CANONICAL_HOST_NAME] | ||||
|       # Spring Boot Admin Server 服务端的相关配置 | ||||
|       context-path: /admin # 配置 Spring | ||||
| 
 | ||||
| --- #################### 芋道相关配置 #################### | ||||
| 
 | ||||
| # 芋道配置项,设置当前项目所有自定义的配置 | ||||
| yudao: | ||||
|   xss: | ||||
|     enable: false | ||||
|   web: | ||||
|     admin-ui: | ||||
|       url: http://dashboard.yudao.iocoder.cn # Admin 管理后台 UI 的地址 | ||||
|   demo: true # 开启演示模式 | ||||
|  | @ -0,0 +1,141 @@ | |||
| --- #################### 数据库相关配置 #################### | ||||
| spring: | ||||
|   # 数据源配置项 | ||||
|   autoconfigure: | ||||
|     exclude: | ||||
|       - com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceAutoConfigure # 排除 Druid 的自动配置,使用 dynamic-datasource-spring-boot-starter 配置多数据源 | ||||
|       - de.codecentric.boot.admin.client.config.SpringBootAdminClientAutoConfiguration # 禁用 Spring Boot Admin 的 Client 的自动配置 | ||||
|   datasource: | ||||
|     druid: # Druid 【监控】相关的全局配置 | ||||
|       web-stat-filter: | ||||
|         enabled: true | ||||
|       stat-view-servlet: | ||||
|         enabled: true | ||||
|         allow: # 设置白名单,不填则允许所有访问 | ||||
|         url-pattern: /druid/* | ||||
|         login-username: # 控制台管理用户名和密码 | ||||
|         login-password: | ||||
|       filter: | ||||
|         stat: | ||||
|           enabled: true | ||||
|           log-slow-sql: true # 慢 SQL 记录 | ||||
|           slow-sql-millis: 100 | ||||
|           merge-sql: true | ||||
|         wall: | ||||
|           config: | ||||
|             multi-statement-allow: true | ||||
|     dynamic: # 多数据源配置 | ||||
|       druid: # Druid 【连接池】相关的全局配置 | ||||
|         initial-size: 1 # 初始连接数 | ||||
|         min-idle: 1 # 最小连接池数量 | ||||
|         max-active: 20 # 最大连接池数量 | ||||
|         max-wait: 600000 # 配置获取连接等待超时的时间,单位:毫秒 | ||||
|         time-between-eviction-runs-millis: 60000 # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位:毫秒 | ||||
|         min-evictable-idle-time-millis: 300000 # 配置一个连接在池中最小生存的时间,单位:毫秒 | ||||
|         max-evictable-idle-time-millis: 900000 # 配置一个连接在池中最大生存的时间,单位:毫秒 | ||||
|         validation-query: SELECT 1 FROM DUAL # 配置检测连接是否有效 | ||||
|         test-while-idle: true | ||||
|         test-on-borrow: false | ||||
|         test-on-return: false | ||||
|       primary: master | ||||
|       datasource: | ||||
|         master: | ||||
|           name: ruoyi-vue-pro | ||||
|           url: jdbc:mysql://127.0.0.1:3306/${spring.datasource.dynamic.datasource.master.name}?allowMultiQueries=true&useUnicode=true&useSSL=false&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&autoReconnect=true&nullCatalogMeansCurrent=true # MySQL Connector/J 8.X 连接的示例 | ||||
| #          url: jdbc:mysql://127.0.0.1:3306/${spring.datasource.dynamic.datasource.master.name}?useSSL=false&allowPublicKeyRetrieval=true&useUnicode=true&characterEncoding=UTF-8&serverTimezone=CTT # MySQL Connector/J 5.X 连接的示例 | ||||
| #          url: jdbc:postgresql://127.0.0.1:5432/${spring.datasource.dynamic.datasource.master.name} # PostgreSQL 连接的示例 | ||||
| #          url: jdbc:oracle:thin:@127.0.0.1:1521:xe # Oracle 连接的示例 | ||||
| #          url: jdbc:sqlserver://127.0.0.1:1433;DatabaseName=${spring.datasource.dynamic.datasource.master.name} # SQLServer 连接的示例 | ||||
|           username: root | ||||
|           password: 123456 | ||||
| #          username: sa | ||||
| #          password: JSm:g(*%lU4ZAkz06cd52KqT3)i1?H7W | ||||
|         slave: # 模拟从库,可根据自己需要修改 | ||||
|           name: ruoyi-vue-pro | ||||
|           url: jdbc:mysql://127.0.0.1:3306/${spring.datasource.dynamic.datasource.slave.name}?allowMultiQueries=true&useUnicode=true&useSSL=false&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&autoReconnect=true&nullCatalogMeansCurrent=true # MySQL Connector/J 8.X 连接的示例 | ||||
| #          url: jdbc:mysql://127.0.0.1:3306/${spring.datasource.dynamic.datasource.slave.name}?useSSL=false&allowPublicKeyRetrieval=true&useUnicode=true&characterEncoding=UTF-8&serverTimezone=CTT # MySQL Connector/J 5.X 连接的示例 | ||||
| #          url: jdbc:postgresql://127.0.0.1:5432/${spring.datasource.dynamic.datasource.slave.name} # PostgreSQL 连接的示例 | ||||
| #          url: jdbc:oracle:thin:@127.0.0.1:1521:xe # Oracle 连接的示例 | ||||
| #          url: jdbc:sqlserver://127.0.0.1:1433;DatabaseName=${spring.datasource.dynamic.datasource.slave.name} # SQLServer 连接的示例 | ||||
|           username: root | ||||
|           password: 123456 | ||||
| #          username: sa | ||||
| #          password: JSm:g(*%lU4ZAkz06cd52KqT3)i1?H7W | ||||
| 
 | ||||
|   # Redis 配置。Redisson 默认的配置足够使用,一般不需要进行调优 | ||||
|   redis: | ||||
|     host: 127.0.0.1 # 地址 | ||||
|     port: 6379 # 端口 | ||||
|     database: 0 # 数据库索引 | ||||
| #    password: 123456 # 密码,建议生产环境开启 | ||||
| 
 | ||||
| --- #################### MQ 消息队列相关配置 #################### | ||||
| spring: | ||||
|   cloud: | ||||
|     stream: | ||||
|       rocketmq: | ||||
|         # RocketMQ Binder 配置项,对应 RocketMQBinderConfigurationProperties 类 | ||||
|         binder: | ||||
|           name-server: 127.0.0.1:9876 # RocketMQ Namesrv 地址 | ||||
|       binding-retry-interval: 7200 # 消息绑定重试间隔时间,单位:秒,默认为 30 秒。考虑到本地可能不启动 RocketMQ 服务,设置为 2 小时 | ||||
| 
 | ||||
| --- #################### 定时任务相关配置 #################### | ||||
| 
 | ||||
| xxl: | ||||
|   job: | ||||
|     enabled: false # 是否开启调度中心,默认为 true 开启 | ||||
|     admin: | ||||
|       addresses: http://127.0.0.1:9090/xxl-job-admin # 调度中心部署跟地址 | ||||
| 
 | ||||
| --- #################### 服务保障相关配置 #################### | ||||
| 
 | ||||
| # Lock4j 配置项 | ||||
| lock4j: | ||||
|   acquire-timeout: 3000 # 获取分布式锁超时时间,默认为 3000 毫秒 | ||||
|   expire: 30000 # 分布式锁的超时时间,默认为 30 毫秒 | ||||
| 
 | ||||
| --- #################### 监控相关配置 #################### | ||||
| 
 | ||||
| # Actuator 监控端点的配置项 | ||||
| management: | ||||
|   endpoints: | ||||
|     web: | ||||
|       base-path: /actuator # Actuator 提供的 API 接口的根目录。默认为 /actuator | ||||
|       exposure: | ||||
|         include: '*' # 需要开放的端点。默认值只打开 health 和 info 两个端点。通过设置 * ,可以开放所有端点。 | ||||
| 
 | ||||
| # Spring Boot Admin 配置项 | ||||
| spring: | ||||
|   boot: | ||||
|     admin: | ||||
|       # Spring Boot Admin Client 客户端的相关配置 | ||||
|       client: | ||||
|         instance: | ||||
|           service-host-type: IP # 注册实例时,优先使用 IP [IP, HOST_NAME, CANONICAL_HOST_NAME] | ||||
| 
 | ||||
| # 日志文件配置 | ||||
| logging: | ||||
|   level: | ||||
|     # 配置自己写的 MyBatis Mapper 打印日志 | ||||
|     cn.iocoder.yudao.module.system.dal.mysql: debug | ||||
|     cn.iocoder.yudao.module.system.dal.mysql.sensitiveword.SensitiveWordMapper: INFO # 配置 SensitiveWordMapper 的日志级别为 info | ||||
|     cn.iocoder.yudao.module.system.dal.mysql.sms.SmsChannelMapper: INFO # 配置 SmsChannelMapper 的日志级别为 info | ||||
| 
 | ||||
| --- #################### 芋道相关配置 #################### | ||||
| 
 | ||||
| # 芋道配置项,设置当前项目所有自定义的配置 | ||||
| yudao: | ||||
|   env: # 多环境的配置项 | ||||
|     tag: ${HOSTNAME} | ||||
|   web: | ||||
|     admin-ui: | ||||
|       url: http://dashboard.yudao.iocoder.cn # Admin 管理后台 UI 的地址 | ||||
|   security: | ||||
|     mock-enable: true | ||||
|   xss: | ||||
|     enable: false | ||||
|   access-log: # 访问日志的配置项 | ||||
|     enable: false | ||||
|   error-code: # 错误码相关配置项 | ||||
|     enable: false | ||||
|   demo: false # 关闭演示模式 | ||||
|  | @ -0,0 +1,134 @@ | |||
| spring: | ||||
|   main: | ||||
|     allow-circular-references: true # 允许循环依赖,因为项目是三层架构,无法避免这个情况。 | ||||
|     allow-bean-definition-overriding: true # 允许 Bean 覆盖,例如说 Feign 等会存在重复定义的服务 | ||||
| 
 | ||||
|   # Servlet 配置 | ||||
|   servlet: | ||||
|     # 文件上传相关配置项 | ||||
|     multipart: | ||||
|       max-file-size: 16MB # 单个文件大小 | ||||
|       max-request-size: 32MB # 设置总上传的文件大小 | ||||
|   mvc: | ||||
|     pathmatch: | ||||
|       matching-strategy: ANT_PATH_MATCHER # 解决 SpringFox 与 SpringBoot 2.6.x 不兼容的问题,参见 SpringFoxHandlerProviderBeanPostProcessor 类 | ||||
| 
 | ||||
|   # Jackson 配置项 | ||||
|   jackson: | ||||
|     serialization: | ||||
|       write-dates-as-timestamps: true # 设置 LocalDateTime 的格式,使用时间戳 | ||||
|       write-date-timestamps-as-nanoseconds: false # 设置不使用 nanoseconds 的格式。例如说 1611460870.401,而是直接 1611460870401 | ||||
|       write-durations-as-timestamps: true # 设置 Duration 的格式,使用时间戳 | ||||
|       fail-on-empty-beans: false # 允许序列化无属性的 Bean | ||||
| 
 | ||||
|   # Cache 配置项 | ||||
|   cache: | ||||
|     type: REDIS | ||||
|     redis: | ||||
|       time-to-live: 1h # 设置过期时间为 1 小时 | ||||
| 
 | ||||
| --- #################### 接口文档配置 #################### | ||||
| 
 | ||||
| springdoc: | ||||
|   api-docs: | ||||
|     enabled: true # 1. 是否开启 Swagger 接文档的元数据 | ||||
|     path: /v3/api-docs | ||||
|   swagger-ui: | ||||
|     enabled: true # 2.1 是否开启 Swagger 文档的官方 UI 界面 | ||||
|     path: /swagger-ui.html | ||||
|   default-flat-param-object: true # 参见 https://doc.xiaominfo.com/docs/faq/v4/knife4j-parameterobject-flat-param 文档 | ||||
| 
 | ||||
| knife4j: | ||||
|   enable: true # 2.2 是否开启 Swagger 文档的 Knife4j UI 界面 | ||||
|   setting: | ||||
|     language: zh_cn | ||||
| 
 | ||||
| # MyBatis Plus 的配置项 | ||||
| mybatis-plus: | ||||
|   configuration: | ||||
|     map-underscore-to-camel-case: true # 虽然默认为 true ,但是还是显示去指定下。 | ||||
|   global-config: | ||||
|     db-config: | ||||
|       id-type: NONE # “智能”模式,基于 IdTypeEnvironmentPostProcessor + 数据源的类型,自动适配成 AUTO、INPUT 模式。 | ||||
|       #      id-type: AUTO # 自增 ID,适合 MySQL 等直接自增的数据库 | ||||
|       #      id-type: INPUT # 用户输入 ID,适合 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库 | ||||
|       #      id-type: ASSIGN_ID # 分配 ID,默认使用雪花算法。注意,Oracle、PostgreSQL、Kingbase、DB2、H2 数据库时,需要去除实体类上的 @KeySequence 注解 | ||||
|       logic-delete-value: 1 # 逻辑已删除值(默认为 1) | ||||
|       logic-not-delete-value: 0 # 逻辑未删除值(默认为 0) | ||||
|     banner: false # 关闭控制台的 Banner 打印 | ||||
|   type-aliases-package: ${yudao.info.base-package}.module.*.dal.dataobject | ||||
|   encryptor: | ||||
|     password: XDV71a+xqStEA3WH # 加解密的秘钥,可使用 https://www.imaegoo.com/2020/aes-key-generator/ 网站生成 | ||||
| 
 | ||||
| mybatis-plus-join: | ||||
|   banner: false # 关闭控制台的 Banner 打印 | ||||
| 
 | ||||
| # Spring Data Redis 配置 | ||||
| spring: | ||||
|   data: | ||||
|     redis: | ||||
|       repositories: | ||||
|         enabled: false # 项目未使用到 Spring Data Redis 的 Repository,所以直接禁用,保证启动速度 | ||||
| 
 | ||||
| --- #################### RPC 远程调用相关配置 #################### | ||||
| 
 | ||||
| --- #################### MQ 消息队列相关配置 #################### | ||||
| 
 | ||||
| spring: | ||||
|   cloud: | ||||
|     # Spring Cloud Stream 配置项,对应 BindingServiceProperties 类 | ||||
|     stream: | ||||
|       function: | ||||
|         definition: busConsumer; | ||||
|       # Binding 配置项,对应 BindingProperties Map | ||||
|       # Spring Cloud Stream RocketMQ 配置项 | ||||
|       rocketmq: | ||||
|         # RocketMQ Binder 配置项,对应 RocketMQBinderConfigurationProperties 类 | ||||
|         binder: | ||||
|           name-server: 127.0.0.1:9876 # RocketMQ Namesrv 地址 | ||||
|         default: # 默认 bindings 全局配置 | ||||
|           producer: # RocketMQ Producer 配置项,对应 RocketMQProducerProperties 类 | ||||
|             group: member_producer_group # 生产者分组 | ||||
|             send-type: SYNC # 发送模式,SYNC 同步 | ||||
|         bindings: | ||||
|           springCloudBusInput: | ||||
|             consumer: | ||||
|               message-model: BROADCASTING # 重要,解决 Spring Cloud Bus RocketMQ 默认不是 BROADCASTING 广播消费的问题 | ||||
| 
 | ||||
|     # Spring Cloud Bus 配置项,对应 BusProperties 类 | ||||
|     bus: | ||||
|       enabled: true # 是否开启,默认为 true | ||||
|       id: ${spring.application.name}:${server.port} # 编号,Spring Cloud Alibaba 建议使用“应用:端口”的格式 | ||||
|       destination: springCloudBus # 目标消息队列,默认为 springCloudBus | ||||
| 
 | ||||
| --- #################### 定时任务相关配置 #################### | ||||
| 
 | ||||
| xxl: | ||||
|   job: | ||||
|     executor: | ||||
|       appname: ${spring.application.name} # 执行器 AppName | ||||
|       logpath: ${user.home}/logs/xxl-job/${spring.application.name} # 执行器运行日志文件存储磁盘路径 | ||||
|     accessToken: default_token # 执行器通讯TOKEN | ||||
| 
 | ||||
| --- #################### 芋道相关配置 #################### | ||||
| 
 | ||||
| yudao: | ||||
|   info: | ||||
|     version: 1.0.0 | ||||
|     base-package: cn.iocoder.yudao.module.member | ||||
|   swagger: | ||||
|     title: 管理后台 | ||||
|     description: 提供管理员管理的所有功能 | ||||
|     version: ${yudao.info.version} | ||||
|     base-package: ${yudao.info.base-package} | ||||
|   captcha: | ||||
|     enable: true # 验证码的开关,默认为 true; | ||||
|   error-code: # 错误码相关配置项 | ||||
|     constants-class-list: | ||||
|       - cn.iocoder.yudao.module.member.enums.ErrorCodeConstants | ||||
|   tenant: # 多租户相关配置项 | ||||
|     enable: true | ||||
|     ignore-urls: | ||||
|     ignore-tables: | ||||
| 
 | ||||
| debug: false | ||||
|  | @ -0,0 +1,23 @@ | |||
| --- #################### 注册中心相关配置 #################### | ||||
| 
 | ||||
| spring: | ||||
|   cloud: | ||||
|     nacos: | ||||
|       server-addr: 127.0.0.1:8848 | ||||
|       discovery: | ||||
|         namespace: dev # 命名空间。这里使用 dev 开发环境 | ||||
|         metadata: | ||||
|           version: 1.0.0 # 服务实例的版本号,可用于灰度发布 | ||||
| 
 | ||||
| --- #################### 配置中心相关配置 #################### | ||||
| 
 | ||||
| spring: | ||||
|   cloud: | ||||
|     nacos: | ||||
|       # Nacos Config 配置项,对应 NacosConfigProperties 配置属性类 | ||||
|       config: | ||||
|         server-addr: 127.0.0.1:8848 # Nacos 服务器地址 | ||||
|         namespace: dev # 命名空间 dev 的ID,不能直接使用 dev 名称。创建命名空间的时候需要指定ID为 dev,这里使用 dev 开发环境 | ||||
|         group: DEFAULT_GROUP # 使用的 Nacos 配置分组,默认为 DEFAULT_GROUP | ||||
|         name: ${spring.application.name} # 使用的 Nacos 配置集的 dataId,默认为 spring.application.name | ||||
|         file-extension: yaml # 使用的 Nacos 配置集的 dataId 的文件拓展名,同时也是 Nacos 配置集的配置格式,默认为 properties | ||||
|  | @ -0,0 +1,14 @@ | |||
| spring: | ||||
|   application: | ||||
|     name: member-server | ||||
| 
 | ||||
|   profiles: | ||||
|     active: local | ||||
| 
 | ||||
| server: | ||||
|   port: 48087 | ||||
| 
 | ||||
| # 日志文件配置。注意,如果 logging.file.name 不放在 bootstrap.yaml 配置文件,而是放在 application.yaml 中,会导致出现 LOG_FILE_IS_UNDEFINED 文件 | ||||
| logging: | ||||
|   file: | ||||
|     name: ${user.home}/logs/${spring.application.name}.log # 日志文件名,全路径 | ||||
|  | @ -0,0 +1,76 @@ | |||
| <configuration> | ||||
|     <!-- 引用 Spring Boot 的 logback 基础配置 --> | ||||
|     <include resource="org/springframework/boot/logging/logback/defaults.xml" /> | ||||
|     <!-- 变量 yudao.info.base-package,基础业务包 --> | ||||
|     <springProperty scope="context" name="yudao.info.base-package" source="yudao.info.base-package"/> | ||||
|     <!-- 格式化输出:%d 表示日期,%X{tid} SkWalking 链路追踪编号,%thread 表示线程名,%-5level:级别从左显示 5 个字符宽度,%msg:日志消息,%n是换行符 --> | ||||
|     <property name="PATTERN_DEFAULT" value="%d{${LOG_DATEFORMAT_PATTERN:-yyyy-MM-dd HH:mm:ss.SSS}} | %highlight(${LOG_LEVEL_PATTERN:-%5p} ${PID:- }) | %boldYellow(%thread [%tid]) %boldGreen(%-40.40logger{39}) | %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}"/> | ||||
| 
 | ||||
|     <!-- 控制台 Appender --> | ||||
|     <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">      | ||||
|         <encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder"> | ||||
|             <layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.TraceIdPatternLogbackLayout"> | ||||
|                 <pattern>${PATTERN_DEFAULT}</pattern> | ||||
|             </layout> | ||||
|         </encoder> | ||||
|     </appender> | ||||
| 
 | ||||
|     <!-- 文件 Appender --> | ||||
|     <!-- 参考 Spring Boot 的 file-appender.xml 编写 --> | ||||
|     <appender name="FILE"  class="ch.qos.logback.core.rolling.RollingFileAppender"> | ||||
|         <encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder"> | ||||
|             <layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.TraceIdPatternLogbackLayout"> | ||||
|                 <pattern>${PATTERN_DEFAULT}</pattern> | ||||
|             </layout> | ||||
|         </encoder> | ||||
|         <!-- 日志文件名 --> | ||||
|         <file>${LOG_FILE}</file> | ||||
|         <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy"> | ||||
|             <!-- 滚动后的日志文件名 --> | ||||
|             <fileNamePattern>${LOGBACK_ROLLINGPOLICY_FILE_NAME_PATTERN:-${LOG_FILE}.%d{yyyy-MM-dd}.%i.gz}</fileNamePattern> | ||||
|             <!-- 启动服务时,是否清理历史日志,一般不建议清理 --> | ||||
|             <cleanHistoryOnStart>${LOGBACK_ROLLINGPOLICY_CLEAN_HISTORY_ON_START:-false}</cleanHistoryOnStart> | ||||
|             <!-- 日志文件,到达多少容量,进行滚动 --> | ||||
|             <maxFileSize>${LOGBACK_ROLLINGPOLICY_MAX_FILE_SIZE:-10MB}</maxFileSize> | ||||
|             <!-- 日志文件的总大小,0 表示不限制 --> | ||||
|             <totalSizeCap>${LOGBACK_ROLLINGPOLICY_TOTAL_SIZE_CAP:-0}</totalSizeCap> | ||||
|             <!-- 日志文件的保留天数 --> | ||||
|             <maxHistory>${LOGBACK_ROLLINGPOLICY_MAX_HISTORY:-30}</maxHistory> | ||||
|         </rollingPolicy> | ||||
|     </appender> | ||||
|     <!-- 异步写入日志,提升性能 --> | ||||
|     <appender name="ASYNC" class="ch.qos.logback.classic.AsyncAppender"> | ||||
|         <!-- 不丢失日志。默认的,如果队列的 80% 已满,则会丢弃 TRACT、DEBUG、INFO 级别的日志 --> | ||||
|         <discardingThreshold>0</discardingThreshold> | ||||
|         <!-- 更改默认的队列的深度,该值会影响性能。默认值为 256 --> | ||||
|         <queueSize>256</queueSize> | ||||
|         <appender-ref ref="FILE"/> | ||||
|     </appender> | ||||
| 
 | ||||
|     <!-- SkyWalking GRPC 日志收集,实现日志中心。注意:SkyWalking 8.4.0 版本开始支持 --> | ||||
|     <appender name="GRPC" class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.log.GRPCLogClientAppender"> | ||||
|         <encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder"> | ||||
|             <layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.TraceIdPatternLogbackLayout"> | ||||
|                 <pattern>${PATTERN_DEFAULT}</pattern> | ||||
|             </layout> | ||||
|         </encoder> | ||||
|     </appender> | ||||
| 
 | ||||
|     <!-- 本地环境 --> | ||||
|     <springProfile name="local"> | ||||
|         <root level="INFO"> | ||||
|             <appender-ref ref="STDOUT"/> | ||||
|             <appender-ref ref="GRPC"/> <!-- 本地环境下,如果不想接入 SkyWalking 日志服务,可以注释掉本行 --> | ||||
|             <appender-ref ref="ASYNC"/>  <!-- 本地环境下,如果不想打印日志,可以注释掉本行 --> | ||||
|         </root> | ||||
|     </springProfile> | ||||
|     <!-- 其它环境 --> | ||||
|     <springProfile name="dev,test,stage,prod,default"> | ||||
|         <root level="INFO"> | ||||
|             <appender-ref ref="STDOUT"/> | ||||
|             <appender-ref ref="ASYNC"/> | ||||
|             <appender-ref ref="GRPC"/> | ||||
|         </root> | ||||
|     </springProfile> | ||||
| 
 | ||||
| </configuration> | ||||
|  | @ -7,14 +7,13 @@ import cn.iocoder.yudao.module.system.enums.ApiConstants; | |||
| import io.swagger.v3.oas.annotations.Operation; | ||||
| import io.swagger.v3.oas.annotations.Parameter; | ||||
| import io.swagger.v3.oas.annotations.Parameters; | ||||
| import io.swagger.v3.oas.annotations.tags.Tag; | ||||
| import org.springframework.cloud.openfeign.FeignClient; | ||||
| import org.springframework.web.bind.annotation.GetMapping; | ||||
| import org.springframework.web.bind.annotation.RequestParam; | ||||
| 
 | ||||
| /** | ||||
|  * 社交应用的 API 接口 | ||||
|  * | ||||
|  * @author 芋道源码 | ||||
|  */ | ||||
| @FeignClient(name = ApiConstants.NAME) // TODO 芋艿:fallbackFactory =
 | ||||
| @Tag(name = "RPC 服务 - 社交应用") | ||||
| public interface SocialClientApi { | ||||
| 
 | ||||
|     String PREFIX = ApiConstants.PREFIX + "/social-client"; | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 YunaiV
						YunaiV