三種Java自定義DNS解析器方法與實(shí)踐
前言:
最近終于用上了高性能的測(cè)試機(jī)(54C96G * 3),相較之前的單機(jī)性能提升了三倍,數(shù)量提升了三倍,更關(guān)鍵的寬帶提單機(jī)升了30倍不止,總體講提升了100多倍,這下再也不用擔(dān)心單機(jī)壓力機(jī)瓶頸,直接原地起飛。
不過沒高興5分鐘,我發(fā)現(xiàn)接口居然請(qǐng)求不通,經(jīng)過一陣撥亂反正終于找到原因:域名無法解析,IP無法直接訪問。
自然而然,解決方案呼之欲出:自定義Java DNS解析器。
經(jīng)過同事指點(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)在哪,我也沒看出來,唯一可以查到的引用就是異步線程池管理器使用
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),
接下來我們看這個(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
通過源碼可以看出,兩個(gè)實(shí)現(xiàn)類都是通過實(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)文章
centos下GitLab+Jenkins持續(xù)集成環(huán)境搭建(安裝jenkins)
這篇文章主要為大家詳細(xì)介紹了centos下搭建GitLab+Jenkins持續(xù)集成環(huán)境,安裝jenkins的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-04-04
Spring?Boot存在路徑遍歷漏洞CVE-2021-22118的問題解析
CVE-2021-22118?是一個(gè)在?Spring?Boot?中發(fā)現(xiàn)的漏洞,該漏洞關(guān)系到?Spring?Boot?的開發(fā)者工具(Devtools)中的遠(yuǎn)程更新(Remote?Update)功能,這篇文章主要介紹了Spring?Boot存在路徑遍歷漏洞CVE-2021-22118,需要的朋友可以參考下2023-09-09
使用JMeter從JSON響應(yīng)的URL參數(shù)中提取特定值
在使用Apache JMeter進(jìn)行API測(cè)試時(shí),我們經(jīng)常需要從JSON格式的響應(yīng)中提取特定字段的值,這可以通過使用JMeter內(nèi)置的JSON提取器和正則表達(dá)式提取器來完成,本文介紹JMeter JSON提取特定值的相關(guān)知識(shí),感興趣的朋友跟隨小編一起看看吧2024-03-03
Maven+SSM框架實(shí)現(xiàn)簡(jiǎn)單的增刪改查
這篇文章主要介紹了Maven+SSM框架實(shí)現(xiàn)簡(jiǎn)單的增刪改查,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-03-03
一問詳解SpringBoot配置文件優(yōu)先級(jí)
在SpringBoot項(xiàng)目當(dāng)中,我們要想配置一個(gè)屬性,可以通過這三種方式當(dāng)中的任意一種來配置都可以,那么優(yōu)先級(jí)怎么算,本文主要介紹了一問詳解SpringBoot配置文件優(yōu)先級(jí),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04
java web實(shí)現(xiàn)分頁查詢實(shí)例方法
在本篇文章里我們給大家分享了java web實(shí)現(xiàn)分頁查詢的詳細(xì)方法知識(shí)點(diǎn),有需要的朋友們參考學(xué)習(xí)下。2018-10-10

