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;
5、如何解決跨域問題?
什麼是跨域:
跨域指的是瀏覽器不能執行其它網站的指令碼,它是由瀏覽器的同源策略造成的,是瀏覽器對JavaScript 施加的安全限制。
解決跨域的方法:
1、response新增header
在Servlet請求返回時新增如下程式碼:
// *表示支援所有網站訪問,也可以額外配置響應網站 resp.setHeader("Access-Control-Allow-Origin", "*");
2、使用JSON方式,出於同源策略考慮
3、HttpClient請求轉發
4、nginx轉發
即利用nginx反向代理,將請求分發到部署相應專案的tomcat伺服器,當然就不存在跨域問題了。
心動時,還沒來得及學會勇敢。
勇敢時,我們已在時光裡走散。