三種Java自定義DNS解析器方法與實(shí)踐
前言:
最近終于用上了高性能的測試機(jī)(54C96G * 3),相較之前的單機(jī)性能提升了三倍,數(shù)量提升了三倍,更關(guān)鍵的寬帶提單機(jī)升了30倍不止,總體講提升了100多倍,這下再也不用擔(dān)心單機(jī)壓力機(jī)瓶頸,直接原地起飛。
不過沒高興5分鐘,我發(fā)現(xiàn)接口居然請求不通,經(jīng)過一陣撥亂反正終于找到原因:域名無法解析,IP無法直接訪問。
自然而然,解決方案呼之欲出:自定義Java DNS解析器。
經(jīng)過同事指點(diǎn)、資料搜索和探索實(shí)踐。終于鎖定了兩個核心類:org.apache.http.impl.conn.InMemoryDnsResolver
和org.apache.http.impl.conn.SystemDefaultDnsResolver
,下面我會演示一下這兩個類的使用實(shí)踐,其中主要區(qū)別還是在負(fù)載均衡的實(shí)現(xiàn)上,這個有空再分享。
1.InMemoryDnsResolver
這個類使用比較簡單,先寫一個Demo,實(shí)現(xiàn)一個簡單的域名解析。
? ? /** ? ? ?* 重寫Java自定義DNS解析器,非負(fù)載均衡 ? ? ?* ? ? ?* @return ? ? ?*/ ? ? private static DnsResolver getDnsResolver2() { ? ? ? ? InMemoryDnsResolver dnsResolver = new InMemoryDnsResolver(); ? ? ? ? try { ? ? ? ? ? ? dnsResolver.add("fun.tester", InetAddress.getByName("127.0.0.1")); ? ? ? ? } catch (Exception e) { ? ? ? ? ? ? e.printStackTrace(); ? ? ? ? } ? ? ? ? return dnsResolver; ? ? }
這樣我們就可以把fun.tester解析到127.0.0.1上了,后面我會進(jìn)行一個簡單的測試。
2.SystemDefaultDnsResolver
這個看名字是系統(tǒng)默認(rèn)DNS解析器,但默認(rèn)在哪,我也沒看出來,唯一可以查到的引用就是異步線程池管理器使用
org.apache.http.impl.nio.conn.PoolingNHttpClientConnectionManager#PoolingNHttpClientConnectionManager(org.apache.http.nio.reactor.ConnectingIOReactor, org.apache.http.nio.conn.NHttpConnectionFactory<org.apache.http.nio.conn.ManagedNHttpClientConnection>, org.apache.http.config.Registry<org.apache.http.nio.conn.SchemeIOSessionStrategy>, org.apache.http.conn.SchemePortResolver, org.apache.http.conn.DnsResolver, long, java.util.concurrent.TimeUnit),
接下來我們看這個Demo
? /** ? ? ?* 重寫Java自定義DNS解析器,負(fù)載均衡 ? ? ?* ? ? ?* @return ? ? ?*/ ? ? private static DnsResolver getDnsResolver() { ? ? ? ? return new SystemDefaultDnsResolver() { ? ? ? ? ? ? @Override ? ? ? ? ? ? public InetAddress[] resolve(final String host) throws UnknownHostException { ? ? ? ? ? ? ? ? if (host.equalsIgnoreCase("fun.tester")) { ? ? ? ? ? ? ? ? ? ? return new InetAddress[]{InetAddress.getByName("127.0.0.1")}; ? ? ? ? ? ? ? ? } else { ? ? ? ? ? ? ? ? ? ? return super.resolve(host); ? ? ? ? ? ? ? ? } ? ? ? ? ? ? } ? ? ? ? }; ? ? }
3.自定義DnsResolver
通過源碼可以看出,兩個實(shí)現(xiàn)類都是通過實(shí)現(xiàn)org.apache.http.conn.DnsResolver
這個接口中org.apache.http.conn.DnsResolver#resolve
方法。我們自己可以完全自己實(shí)現(xiàn)。
? /** ? ? ?* 自定義本地DNS解析器實(shí)現(xiàn) ? ? ?* ? ? ?* @return ? ? ?*/ ? ? private static DnsResolver getDnsResolver3() { ? ? ? ? return new DnsResolver() { ? ? ? ? ? ? @Override ? ? ? ? ? ? public InetAddress[] resolve(final String host) throws UnknownHostException { ? ? ? ? ? ? ? ? if (host.equalsIgnoreCase("fun.tester")) { ? ? ? ? ? ? ? ? ? ? return new InetAddress[]{InetAddress.getByName("127.0.0.1")}; ? ? ? ? ? ? ? ? } else { ? ? ? ? ? ? ? ? ? ? return InetAddress.getAllByName(host); ? ? ? ? ? ? ? ? } ? ? ? ? ? ? } ? ? ? ? }; ? ? }
仔細(xì)看不難發(fā)現(xiàn),其實(shí)就是代碼縫合怪。
4.連接池管理器
下面分享一下如何使用自定義的org.apache.http.conn.DnsResolver
,就是在創(chuàng)建連接池管理器的時候設(shè)置一下就可以。
5.測試
首先我在本地起一個HTTP服務(wù),端口12345,非常簡單。代碼如下:
? static void main(String[] args) { ? ? ? ? def util = new ArgsUtil(args) ? ? ? ? def server = getServerNoLog(util.getIntOrdefault(0, 12345)) ? ? ? ? server.response("Have Fun ~ Tester !") ? ? ? ? def run = run(server) ? ? ? ? waitForKey("fan") ? ? ? ? run.stop() ? ? }
然后我準(zhǔn)備一個測試腳本:
? public static void main(String[] args) { ? ? ? ? String url = "http://fun.tester:12345/" ? ? ? ? def get = getHttpGet(url) ? ? ? ? def funtester = { ? ? ? ? ? ? fun { ? ? ? ? ? ? ? ? getHttpResponse(get) ? ? ? ? ? ? } ? ? ? ? } ? ? ? ? 10.times { ? ? ? ? ? ? funtester() ? ? ? ? } ? ? }
控制臺日志輸出:
INFO-> 27.214 F-1 請求uri:http://fun.tester:12345/ , 耗時:304 ms , HTTPcode: 200
INFO-> 27.214 F-4 請求uri:http://fun.tester:12345/ , 耗時:304 ms , HTTPcode: 200
INFO-> 27.214 F-10 請求uri:http://fun.tester:12345/ , 耗時:305 ms , HTTPcode: 200
INFO-> 27.214 F-5 請求uri:http://fun.tester:12345/ , 耗時:305 ms , HTTPcode: 200
INFO-> 27.214 F-2 請求uri:http://fun.tester:12345/ , 耗時:305 ms , HTTPcode: 200
INFO-> 27.214 F-8 請求uri:http://fun.tester:12345/ , 耗時:305 ms , HTTPcode: 200
INFO-> 27.214 F-3 請求uri:http://fun.tester:12345/ , 耗時:305 ms , HTTPcode: 200
INFO-> 27.214 F-7 請求uri:http://fun.tester:12345/ , 耗時:305 ms , HTTPcode: 200
INFO-> 27.214 F-6 請求uri:http://fun.tester:12345/ , 耗時:305 ms , HTTPcode: 200
INFO-> 27.214 F-9 請求uri:http://fun.tester:12345/ , 耗時:305 ms , HTTPcode: 200
三種實(shí)現(xiàn)方式控制臺輸出大同小異,都能滿足我們的需求,當(dāng)然僅僅是功能測試場景下。下期會結(jié)合源碼分析如何實(shí)現(xiàn)負(fù)載均衡。
到此這篇關(guān)于三種Java自定義DNS解析器方法與實(shí)踐的文章就介紹到這了,更多相關(guān)Java自定義DNS解析器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
基于Java編寫一個PDF與Word文件轉(zhuǎn)換工具
前段時間一直使用到word文檔轉(zhuǎn)pdf或者pdf轉(zhuǎn)word,尋思著用Java應(yīng)該是可以實(shí)現(xiàn)的,于是花了點(diǎn)時間寫了個文件轉(zhuǎn)換工具,感興趣的可以了解一下2023-01-01C#使用MySQLConnectorNet和MySQLDriverCS操作MySQL的方法
這篇文章主要介紹了C#使用MySQLConnectorNet和MySQLDriverCS操作MySQL的方法,相比普通方法能夠在Windows下簡化很多操作步驟,需要的朋友可以參考下2016-04-04淺談java 字符串,字符數(shù)組,list間的轉(zhuǎn)化
下面小編就為大家?guī)硪黄獪\談java 字符串,字符數(shù)組,list間的轉(zhuǎn)化。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11SpringBoot整合RabbitMQ及生產(chǎn)全場景高級特性實(shí)戰(zhàn)
本文主要介紹了SpringBoot整合RabbitMQ及生產(chǎn)全場景高級特性實(shí)戰(zhàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-10-10淺談JSON的數(shù)據(jù)交換、緩存問題和同步問題
這篇文章主要介紹了淺談JSON的數(shù)據(jù)交換、緩存問題和同步問題,具有一定借鑒價值,需要的朋友可以參考下2017-12-12深入了解SpringBoot中@InitBinder注解的使用
這篇文章主要介紹了深入了解SpringBoot中@InitBinder注解的使用,@InitBinder注解可以作用在被@Controller注解的類的方法上,表示為當(dāng)前控制器注冊一個屬性編輯器,用于對WebDataBinder進(jìn)行初始化,且只對當(dāng)前的Controller有效,需要的朋友可以參考下2023-10-10SpringBoot使用Jasypt對配置文件和數(shù)據(jù)庫密碼加密
在做數(shù)據(jù)庫敏感信息保護(hù)時,應(yīng)加密存儲,本文就來介紹一下SpringBoot使用Jasypt對配置文件和數(shù)據(jù)庫密碼加密,具有一定的參考價值,感興趣的可以了解一下2024-02-02