三種Java自定義DNS解析器方法與實(shí)踐
前言:
最近終于用上了高性能的測(cè)試機(jī)(54C96G * 3),相較之前的單機(jī)性能提升了三倍,數(shù)量提升了三倍,更關(guān)鍵的寬帶提單機(jī)升了30倍不止,總體講提升了100多倍,這下再也不用擔(dān)心單機(jī)壓力機(jī)瓶頸,直接原地起飛。
不過(guò)沒(méi)高興5分鐘,我發(fā)現(xiàn)接口居然請(qǐng)求不通,經(jīng)過(guò)一陣撥亂反正終于找到原因:域名無(wú)法解析,IP無(wú)法直接訪問(wèn)。
自然而然,解決方案呼之欲出:自定義Java DNS解析器。
經(jīng)過(guò)同事指點(diǎn)、資料搜索和探索實(shí)踐。終于鎖定了兩個(gè)核心類:org.apache.http.impl.conn.InMemoryDnsResolver
和org.apache.http.impl.conn.SystemDefaultDnsResolver
,下面我會(huì)演示一下這兩個(gè)類的使用實(shí)踐,其中主要區(qū)別還是在負(fù)載均衡的實(shí)現(xiàn)上,這個(gè)有空再分享。
1.InMemoryDnsResolver
這個(gè)類使用比較簡(jiǎn)單,先寫一個(gè)Demo,實(shí)現(xiàn)一個(gè)簡(jiǎ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上了,后面我會(huì)進(jìn)行一個(gè)簡(jiǎn)單的測(cè)試。
2.SystemDefaultDnsResolver
這個(gè)看名字是系統(tǒng)默認(rèn)DNS解析器,但默認(rèn)在哪,我也沒(méi)看出來(lái),唯一可以查到的引用就是異步線程池管理器使用
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),
接下來(lái)我們看這個(gè)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
通過(guò)源碼可以看出,兩個(gè)實(shí)現(xiàn)類都是通過(guò)實(shí)現(xiàn)org.apache.http.conn.DnsResolver
這個(gè)接口中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í)候設(shè)置一下就可以。
5.測(cè)試
首先我在本地起一個(gè)HTTP服務(wù),端口12345,非常簡(jiǎn)單。代碼如下:
? 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)備一個(gè)測(cè)試腳本:
? public static void main(String[] args) { ? ? ? ? String url = "http://fun.tester:12345/" ? ? ? ? def get = getHttpGet(url) ? ? ? ? def funtester = { ? ? ? ? ? ? fun { ? ? ? ? ? ? ? ? getHttpResponse(get) ? ? ? ? ? ? } ? ? ? ? } ? ? ? ? 10.times { ? ? ? ? ? ? funtester() ? ? ? ? } ? ? }
控制臺(tái)日志輸出:
INFO-> 27.214 F-1 請(qǐng)求uri:http://fun.tester:12345/ , 耗時(shí):304 ms , HTTPcode: 200
INFO-> 27.214 F-4 請(qǐng)求uri:http://fun.tester:12345/ , 耗時(shí):304 ms , HTTPcode: 200
INFO-> 27.214 F-10 請(qǐng)求uri:http://fun.tester:12345/ , 耗時(shí):305 ms , HTTPcode: 200
INFO-> 27.214 F-5 請(qǐng)求uri:http://fun.tester:12345/ , 耗時(shí):305 ms , HTTPcode: 200
INFO-> 27.214 F-2 請(qǐng)求uri:http://fun.tester:12345/ , 耗時(shí):305 ms , HTTPcode: 200
INFO-> 27.214 F-8 請(qǐng)求uri:http://fun.tester:12345/ , 耗時(shí):305 ms , HTTPcode: 200
INFO-> 27.214 F-3 請(qǐng)求uri:http://fun.tester:12345/ , 耗時(shí):305 ms , HTTPcode: 200
INFO-> 27.214 F-7 請(qǐng)求uri:http://fun.tester:12345/ , 耗時(shí):305 ms , HTTPcode: 200
INFO-> 27.214 F-6 請(qǐng)求uri:http://fun.tester:12345/ , 耗時(shí):305 ms , HTTPcode: 200
INFO-> 27.214 F-9 請(qǐng)求uri:http://fun.tester:12345/ , 耗時(shí):305 ms , HTTPcode: 200
三種實(shí)現(xiàn)方式控制臺(tái)輸出大同小異,都能滿足我們的需求,當(dāng)然僅僅是功能測(cè)試場(chǎng)景下。下期會(huì)結(jié)合源碼分析如何實(shí)現(xiàn)負(fù)載均衡。
到此這篇關(guān)于三種Java自定義DNS解析器方法與實(shí)踐的文章就介紹到這了,更多相關(guān)Java自定義DNS解析器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
基于Java編寫一個(gè)PDF與Word文件轉(zhuǎn)換工具
前段時(shí)間一直使用到word文檔轉(zhuǎn)pdf或者pdf轉(zhuǎn)word,尋思著用Java應(yīng)該是可以實(shí)現(xiàn)的,于是花了點(diǎn)時(shí)間寫了個(gè)文件轉(zhuǎn)換工具,感興趣的可以了解一下2023-01-01C#使用MySQLConnectorNet和MySQLDriverCS操作MySQL的方法
這篇文章主要介紹了C#使用MySQLConnectorNet和MySQLDriverCS操作MySQL的方法,相比普通方法能夠在Windows下簡(jiǎn)化很多操作步驟,需要的朋友可以參考下2016-04-04淺談java 字符串,字符數(shù)組,list間的轉(zhuǎn)化
下面小編就為大家?guī)?lái)一篇淺談java 字符串,字符數(shù)組,list間的轉(zhuǎn)化。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-11-11SpringBoot整合RabbitMQ及生產(chǎn)全場(chǎng)景高級(jí)特性實(shí)戰(zhàn)
本文主要介紹了SpringBoot整合RabbitMQ及生產(chǎn)全場(chǎng)景高級(jí)特性實(shí)戰(zhàn),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10java中@Configuration使用場(chǎng)景
本文主要介紹了java中@Configuration使用場(chǎng)景,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03上傳自己的jar包到maven中央倉(cāng)庫(kù)的快速操作方法
網(wǎng)絡(luò)上可以搜索到很多jar包到中央倉(cāng)庫(kù),但是都不是多適合自己的項(xiàng)目,于是自己動(dòng)手寫個(gè),本文檔通過(guò)sonatype上傳jar包至maven中央倉(cāng)庫(kù),Sonatype通過(guò)JIRA來(lái)管理OSSRH倉(cāng)庫(kù),具體實(shí)例代碼跟隨小編一起看看吧2021-08-08淺談JSON的數(shù)據(jù)交換、緩存問(wèn)題和同步問(wèn)題
這篇文章主要介紹了淺談JSON的數(shù)據(jù)交換、緩存問(wèn)題和同步問(wèn)題,具有一定借鑒價(jià)值,需要的朋友可以參考下2017-12-12深入了解SpringBoot中@InitBinder注解的使用
這篇文章主要介紹了深入了解SpringBoot中@InitBinder注解的使用,@InitBinder注解可以作用在被@Controller注解的類的方法上,表示為當(dāng)前控制器注冊(cè)一個(gè)屬性編輯器,用于對(duì)WebDataBinder進(jìn)行初始化,且只對(duì)當(dāng)前的Controller有效,需要的朋友可以參考下2023-10-10SpringBoot使用Jasypt對(duì)配置文件和數(shù)據(jù)庫(kù)密碼加密
在做數(shù)據(jù)庫(kù)敏感信息保護(hù)時(shí),應(yīng)加密存儲(chǔ),本文就來(lái)介紹一下SpringBoot使用Jasypt對(duì)配置文件和數(shù)據(jù)庫(kù)密碼加密,具有一定的參考價(jià)值,感興趣的可以了解一下2024-02-02