2021-2-28 Mark-Java Interview Simple
2021-2-28 Mark-Java Interview Simple
心動時,還沒來得及學會勇敢。
勇敢時,我們已在時光里走散。
簡介:2021-2-28日Java面試沒能脫口而出或是回答得不好的些許問題。
1、Redis數據類型有哪些?使用Redis何種數據類型處理告警?
String、Hash、List、Set、zset 五種。
String(字元串)
String是最基本的類型,一個key對應一個value;String類型是二進位安全的,即redis的string可以包含任何數據,比如jpg圖片or序列化對象;String類型的值最大存儲量為512M。
Hash(哈希)
Hash是一個string類型的field和value映射表,hash適合於存儲對象;存儲一些結構化的數據,比如用戶的昵稱、年齡、性別、積分等,存儲一個用戶資訊對象數據。
List(列表)
Redis 列表是簡單的字元串列表,按照插入順序排序;list類型經常會被用於消息隊列的服務,以完成多程式之間的消息交換。
Set(集合)
Redis的Set是string類型的無序集合;集合是通過哈希表實現的,所以添加,刪除,查找的複雜度都是O(1),適用於如利用交集求共同好友。
zset(sorted set:有序集合)
Redis zset 和 set 一樣也是string類型元素的集合,且不允許重複的成員;sorted set是插入有序的,即自動排序;當你需要一個有序的並且不重複的集合列表時,那麼可以選擇sorted set數據結構;例如存儲全班同學的成績,其集合value可以是同學的學號,而score就可以是成績;或排行榜應用。
2、事務傳播類型有哪些?
1、Required(默認):支援使用當前事務,如果當前事務不存在,創建一個新事物;
2、Supports:支援使用當前事務,如果當前事務不存在,則不使用事務;
3、Mandatory:中文翻譯為強制,支援使用當前事務,如果當前事務不存在,則拋出Exception;
4、Required_New:創建一個新事務,如果當前事務存在,把當前事務掛起;(@Transactional(propagation = Propagation.REQUIRES_NEW))
5、Not_Supported:無事務執行,如果當前事務存在,把當前事務掛起;
6、Never:無事務執行,如果當前有事務則拋出Exception;
7、Nested:嵌套事務,如果當前事務存在,則在嵌套的事務中執行;若當前事務不存在,則表現跟Required一樣。
3、ELK日誌中間件?
ELK日誌系統分別是Elasticsearch、Logstash、Kibana三個開源框架的縮寫。
Elasticsearch:開源分散式搜索引擎,提供存儲、分析、搜索功能;用於接收搜集的海量結構化日誌數據,並提供給kibana查詢分析。
Logstash:開源日誌搜集、分析、過濾框架;用於收集日誌,對日誌進行過濾形成結構化數據,並轉發到elasticsearch中。
Kibana:開源日誌報表系統,對elasticsearch以及logstash有良好的web頁面支援;用於對elasticsearch提供的數據進行分析展示。
4、MySQL分區?
什麼是分區?
在下面的場景中,分區可以起到非常大的作用:
A:表非常大以至於無法全部都放在記憶體中,或者只在表的最後部分有熱點數據,其他都是歷史數據
B:分區表的數據更容易維護,如:想批量刪除大量數據可以使用清除整個分區的方式。另外,還可以對一個獨立分區進行優化、檢查、修復等操作
C:分區表的數據可以分布在不同的物理設備上,從而高效地利用多個硬體設備
D:可以使用分區表來避免某些特殊的瓶頸,如:innodb的單個索引的互斥訪問,ext3文件系統的inode鎖競爭等
E:如果需要,還可以備份和恢復獨立的分區,這在非常大的數據集的場景下效果非常好
F:優化查詢,在where字句中包含分區列時,可以只使用必要的分區來提高查詢效率,同時在涉及sum()和count()這類聚合函數的查詢時,可以在每個分區上面並行處理,最終只需要匯總所有分區得到的結果。
有水平分區&垂直分區兩種。
分區幾種方式實踐:Ranger、List、Hash、Key
Range: create table range( id int(11), money int(11) unsigned not null, date datetime )partition by range(year(date))( partition p2007 values less than (2008), partition p2008 values less than (2009), partition p2009 values less than (2010) partition p2010 values less than maxvalue ); List: create table list( a int(11), b int(11) )(partition by list (b) partition p0 values in (1,3,5,7,9), partition p1 values in (2,4,6,8,0) ); Hash: create table hash( a int(11), b datetime )partition by hash (YEAR(b) partitions 4; Key: create table t_key( a int(11), b datetime) partition by key (b) partitions 4;
View Code~拍一拍
5、如何解決跨域問題?
什麼是跨域:
跨域指的是瀏覽器不能執行其它網站的腳本,它是由瀏覽器的同源策略造成的,是瀏覽器對JavaScript 施加的安全限制。
解決跨域的方法:
1、response添加header
在Servlet請求返回時添加如下程式碼:
// *表示支援所有網站訪問,也可以額外配置響應網站
resp.setHeader("Access-Control-Allow-Origin", "*");
2、使用JSON方式,出於同源策略考慮
3、HttpClient請求轉發
4、nginx轉發
即利用nginx反向代理,將請求分發到部署相應項目的tomcat伺服器,當然就不存在跨域問題了。
心動時,還沒來得及學會勇敢。
勇敢時,我們已在時光里走散。