今天Java基础(多线程,JVM等)没怎么考察,但其他方面都有所涉猎,从框架底层到架构方面都有问到。稍微记录一下问到的题吧!!!
1、索引不生效的情况:
1.有or必全有索引;
2.复合索引未用左列字段;
3.like以%开头;
4.需要类型转换;
5.where中索引列有运算;
6.where中索引列使用了函数;
7.如果mysql觉得全表扫描更快时(数据少);
自身总结:这个平时explain没有细细看,只说出了其中三四种。
2、Spring的传播行为:
总结:也是只说出来三四种,太久以前记的东西印象不够深刻了。。像Never和Nested从来没有用过就一点印象没有了。
3、SpringCloud用过哪些组件:
1、Zuul,网关(面试官提到现在都是使用Gateway)
2、Eureka,服务注册
3、Feign,服务调用
4、Config,配置中心(面试官提到现在都用Nacos)
5、Hystrix,熔断降级
6、Sleuth,链路追踪
面试官还提到了服务网格,听都没听过的名词,我流下了没有知识的眼泪。。
总结:自己了解的可能有点过时,需及时了解新兴框架或技术才行
4、Redis的配置:
配过一次后就忘了。。
@Component
@EnableRedisHttpSession(maxInactiveIntervalInSeconds = 3600)
public class RedisConfig {
@Bean
public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory){
RedisTemplate redisTemplate = new RedisTemplate();
redisTemplate.setConnectionFactory(redisConnectionFactory);
//首先解决key的序列化方式
StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
redisTemplate.setKeySerializer(stringRedisSerializer);
//解决value的序列化方式
Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
ObjectMapper objectMapper = new ObjectMapper();
SimpleModule simpleModule = new SimpleModule();
simpleModule.addSerializer(DateTime.class,new JodaDateTimeJsonSerializer());
simpleModule.addDeserializer(DateTime.class,new JodaDateTimeJsonDeserializer());
objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
objectMapper.registerModule(simpleModule);
jackson2JsonRedisSerializer.setObjectMapper(objectMapper);
redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
return redisTemplate;
}
}
5、Rabbitmq如何保证消息可靠性
持久化:
1、queue的持久化
queue的持久化是通过durable=true来实现的。
2、消息的持久化
如过将queue的持久化标识durable设置为true,则代表是一个持久的队列,那么在服务重启之后,也会存在,因为服务会把持久化的queue存放在硬盘上,当服务重启的时候,会重新什么之前被持久化的queue。队列是可以被持久化,但是里面的消息是否为持久化那还要看消息的持久化设置。也就是说,重启之前那个queue里面还没有发出去的消息的话,重启之后那队列里面是不是还存在原来的消息,这个就要取决于发生着在发送消息时对消息的设置了。
如果要在重启后保持消息的持久化必须设置消息是持久化的标识。
3、exchange的持久化
上面阐述了队列的持久化和消息的持久化,如果不设置exchange的持久化对消息的可靠性来说没有什么影响,但是同样如果exchange不设置持久化,那么当broker服务重启之后,exchange将不复存在,那么既而发送方rabbitmq producer就无法正常发送消息。
6、Transactional事务不起作用原因
不带事务的方法调用该类中带事务的方法,不会回滚。
自己也提到Redis也不会回滚
7、Spring AOP,说说你的拦截器怎么实现的
第一步:自定义一个实现了Interceptor接口的类,或者继承抽象类AbstractInterceptor。
第二步:在配置文件中注册定义的拦截器。
第三步:在需要使用Action中引用上述定义的拦截器,为了方便也可以将拦截器定义为默认的拦截器,这样在不加特殊说明的情况下,所有的Action都被这个拦截器拦截。
8、使用自增ID的弊端
导入旧数据时,可能会ID重复或ID变化,导致导入失败。
分布式架构,分库分表,无法实现全局ID唯一。
增长是从1开始的,无法处理统一为统一格式。
还问到了Mysql分库分表(MyCat),SpringBoot都用过哪些组件等等(有些记不住了,没睡午觉精神有点不好。。)
面试官提到了挺多自己之前了解不够深的东西,像Mybatis-plus,听说已经可以不用写xml了(那不是比JPA还好用);服务网格,高级玩意;数据库自增ID的坏处,他们已经使用了雪花算法也会出现问题等等等等很多
面试总结:自己都答的不是很好!!因为是第一场面试,没有时间提前准备(没想到投了简历当天就被通知第二天面试)。。很多问题都只能凭印象说个大概!!很多问题也没回答全。。看来平时积累不太够,很多技术只能有个印象。。接触不够深,在学习新技术的同时,应该结合自己掌握的技术做一个总结和比较。多写demo!
出来面试跟考试一样,能抓到不少知识盲区!以后工作中是不是没事就去面试比较好(这句话写出来估计会给HR们骂死吧)。。。