最后
Java架构进阶面试及知识点文档笔记
这份文档共498页,其中包括Java集合,并发编程,JVM,Dubbo,Redis,Spring全家桶,MySQL,Kafka等面试解析及知识点整理
Java分布式高级面试问题解析文档
其中都是包括分布式的面试问题解析,内容有分布式消息队列,Redis缓存,分库分表,微服务架构,分布式高可用,读写分离等等!
互联网Java程序员面试必备问题解析及文档学习笔记
Java架构进阶视频解析合集
(1)引入es的RestHighLevelClient
依赖:
org.elasticsearch.client
elasticsearch-rest-high-level-client
(2)因为SpringBoot默认的ES版本是7.6.2,所以我们需要覆盖默认的ES版本:
<java.version>1.8</java.version>
<elasticsearch.version>7.12.1</elasticsearch.version>
(3)初始化RestHighLevelClient
:
RestHighLevelClient client = new RestHighLevelClient(RestClient.builder(
//填自己的服务器ip地址
HttpHost.create(“http://192.168.150.101:9200”)
));
这里为了单元测试方便,我们创建一个测试类HotelIndexTest
,然后将初始化的代码编写在@BeforeEach
方法中:
public class HotelIndexTest {
private RestHighLevelClient client;
//初始化
@BeforeEach
void setUp() {
this.client = new RestHighLevelClient(RestClient.builder(
HttpHost.create(“http://192.168.150.101:9200”)
));
}
//用完释放资源
@AfterEach
void tearDown() throws IOException {
this.client.close();
}
}
2.1 创建索引库
代码分为三步:
-
创建Request对象。因为是创建索引库的操作,因此Request是
CreateIndexRequest
。 -
添加请求参数,其实就是DSL的JSON参数部分。因为json字符串很长,这里是定义了静态字符串常量
MAPPING_TEMPLATE
,让代码看起来更加优雅。 -
发送请求,
client.indices()
方法的返回值是IndicesClient
类型,封装了所有与索引库操作有关的方法。
在hotel-demo
的cn.itcast.hotel.constants包下,创建一个类,定义mapping映射的JSON字符串常量:
public class HotelConstants {
public static final String MAPPING_TEMPLATE = “{\n” +
" “mappings”: {\n" +
" “properties”: {\n" +
" “id”: {\n" +
" “type”: “keyword”\n" +
" },\n" +
" “name”:{\n" +
" “type”: “text”,\n" +
" “analyzer”: “ik_max_word”,\n" +
" “copy_to”: “all”\n" +
" },\n" +
" “address”:{\n" +
" “type”: “keyword”,\n" +
" “index”: false\n" +
" },\n" +
" “price”:{\n" +
" “type”: “integer”\n" +
" },\n" +
" “score”:{\n" +
" “type”: “integer”\n" +
" },\n" +
" “brand”:{\n" +
" “type”: “keyword”,\n" +
" “copy_to”: “all”\n" +
" },\n" +
" “city”:{\n" +
" “type”: “keyword”,\n" +
" “copy_to”: “all”\n" +
" },\n" +
" “starName”:{\n" +
" “type”: “keyword”\n" +
" },\n" +
" “business”:{\n" +
" “type”: “keyword”\n" +
" },\n" +
" “location”:{\n" +
" “type”: “geo_point”\n" +
" },\n" +
" “pic”:{\n" +
" “type”: “keyword”,\n" +
" “index”: false\n" +
" },\n" +
" “all”:{\n" +
" “type”: “text”,\n" +
" “analyzer”: “ik_max_word”\n" +
" }\n" +
" }\n" +
" }\n" +
“}”;
}
在hotel-demo
中的HotelIndexTest
测试类中,编写单元测试,实现创建索引:
@Test
void createHotelIndex() throws IOException {
// 1.创建Request对象
CreateIndexRequest request = new CreateIndexRequest(“hotel”);
// 2.准备请求的参数:DSL语句
request.source(MAPPING_TEMPLATE, XContentType.JSON);
// 3.发送请求
client.indices().create(request, RequestOptions.DEFAULT);
}
2.2 删除索引库
删除索引库的DSL语句:
DELETE /hotel
代码分三步:
-
创建Request对象。这次是
DeleteIndexRequest
对象 -
准备参数。这里是无参
-
发送请求。改用
delete
方法
@Test
void testDeleteHotelIndex() throws IOException {
// 1.创建Request对象
DeleteIndexRequest request = new DeleteIndexRequest(“hotel”);
// 2.发送请求
client.indices().delete(request, RequestOptions.DEFAULT);
}
2.3 判断索引库是否存在
判断索引库是否存在,本质就是查询,对应的DSL是:
GET /hotel
代码分三步:
-
创建Request对象。这次是
GetIndexRequest
对象 -
准备参数。这里是无参
-
发送请求。改用
exists
方法
@Test
void testExistsHotelIndex() throws IOException {
// 1.创建Request对象
GetIndexRequest request = new GetIndexRequest(“hotel”);
// 2.发送请求
boolean exists = client.indices().exists(request, RequestOptions.DEFAULT);
// 3.输出
System.err.println(exists ? “索引库已经存在!” : “索引库不存在!”);
}
2.4 总结
JavaRestClient
操作elasticsearch
的流程基本类似。核心是client.indices()
方法来获取索引库的操作对象。
索引库操作的基本步骤:
-
初始化
RestHighLevelClient
-
创建
XxxIndexRequest
。XXX是Create、Get、Delete -
准备
DSL
( Create时需要,其它是无参) -
发送请求。调用
RestHighLevelClient#indices().xxx()
方法,xxx是create、exists、delete
在创建一个测试类HotelDocumentTest
:
-
初始化
RestHighLevelClient
-
我们的酒店数据在数据库,需要利用
IHotelService
去查询,所以注入这个接口
@SpringBootTest
public class HotelDocumentTest {
@Autowired
private IHotelService hotelService;
private RestHighLevelClient client;
@BeforeEach
void setUp() {
this.client = new RestHighLevelClient(RestClient.builder(
HttpHost.create(“http://192.168.150.101:9200”)
));
}
@AfterEach
void tearDown() throws IOException {
this.client.close();
}
}
3.1 新增文档
目的:我们要将数据库的酒店数据查询出来,写入elasticsearch中。
数据库查询后的结果是一个Hotel
类型的对象。结构如下:
@Data
@TableName(“tb_hotel”)
public class Hotel {
@TableId(type = IdType.INPUT)
private Long id;
private String name;
private String address;
private Integer price;
private Integer score;
private String brand;
private String city;
private String starName;
private String business;
private String longitude;
private String latitude;
private String pic;
}
因为数据库与我们的索引库结构存在差异:longitude
和latitude
需要合并为location
因此,我们需要定义一个新的类型HotelDoc
,与索引库结构吻合:
@Data
@NoArgsConstructor
public class HotelDoc {
private Long id;
private String name;
private String address;
private Integer price;
private Integer score;
private String brand;
private String city;
private String starName;
private String business;
private String location;
private String pic;
public HotelDoc(Hotel hotel) {
this.id = hotel.getId();
this.name = hotel.getName();
this.address = hotel.getAddress();
this.price = hotel.getPrice();
this.score = hotel.getScore();
this.brand = hotel.getBrand();
this.city = hotel.getCity();
this.starName = hotel.getStarName();
this.business = hotel.getBusiness();
this.location = hotel.getLatitude() + ", " + hotel.getLongitude();
this.pic = hotel.getPic();
}
}
新增文档的DSL语句如下:
POST /{索引库名}/_doc/1
{
“name”: “Jack”,
“age”: 21
}
注意:
与创建索引库不同的是,这里直接使用client.xxx()的API,不再需要client.indices()了
结局:总结+分享
看完美团、字节、腾讯这三家的一二三面试问题,是不是感觉问的特别多,可能咱们真的又得开启面试造火箭、工作拧螺丝的模式去准备下一次的面试了。
开篇有提及我可是足足背下了Java互联网工程师面试1000题,多少还是有点用的呢,换汤不换药,不管面试官怎么问你,抓住本质即可!能读到此处的都是真爱
- Java互联网工程师面试1000题
而且从上面三家来看,算法与数据结构是必备不可少的呀,因此我建议大家可以去刷刷这本左程云大佬著作的 《程序员代码面试指南 IT名企算法与数据结构题目最优解》,里面近200道真实出现过的经典代码面试题。
- 程序员代码面试指南–IT名企算法与数据结构题目最优解
- 其余像设计模式,建议可以看看下面这4份PDF(已经整理)
- 更多的Java面试学习笔记如下,关于面试这一块,我额外细分出Java基础-中级-高级开发的面试+解析,以及调优笔记等等等。。。
以上所提及的全部Java面试学习的PDF及笔记,如若皆是你所需要的,那么都可发送给你!
…(img-a1vVe3L6-1715586722268)]
而且从上面三家来看,算法与数据结构是必备不可少的呀,因此我建议大家可以去刷刷这本左程云大佬著作的 《程序员代码面试指南 IT名企算法与数据结构题目最优解》,里面近200道真实出现过的经典代码面试题。
- 程序员代码面试指南–IT名企算法与数据结构题目最优解
[外链图片转存中…(img-j3cjPvdv-1715586722269)]
- 其余像设计模式,建议可以看看下面这4份PDF(已经整理)
[外链图片转存中…(img-CrJiGVGw-1715586722269)]
- 更多的Java面试学习笔记如下,关于面试这一块,我额外细分出Java基础-中级-高级开发的面试+解析,以及调优笔记等等等。。。
[外链图片转存中…(img-lqjnKzff-1715586722269)]
以上所提及的全部Java面试学习的PDF及笔记,如若皆是你所需要的,那么都可发送给你!