精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

不懂優(yōu)雅停機(jī),搞掛了線上服務(wù),咋辦?

系統(tǒng) Linux
在 Linux 世界里,一切都是資源。當(dāng)我們啟動一個(gè) JVM 的時(shí)候,我們就加載了許多的資源。而當(dāng)我們關(guān)閉 JVM 的時(shí)候,JVM 只會釋放內(nèi)存這個(gè)資源,而其他資源是不會釋放的,例如:網(wǎng)絡(luò)連接、文件句柄等等。

公司項(xiàng)目是用 consul 進(jìn)行注冊的,在發(fā)布微服務(wù)的時(shí)候,總是會導(dǎo)致調(diào)用方出現(xiàn)一定幾率的調(diào)用失敗。一開始百思不得其解,后來咨詢了資深的同事才知道:原來是服務(wù)下線的時(shí)候沒有優(yōu)雅停機(jī),沒有去 consul 將自己下線再停機(jī),導(dǎo)致調(diào)用方拿到了舊的調(diào)用地址,導(dǎo)致調(diào)用失敗! 看來優(yōu)雅停機(jī)還是一個(gè)蠻重要的知識點(diǎn),可不能忽略,今天就讓我們來盤盤它吧!

什么是優(yōu)雅停機(jī)?

在 Linux 世界里,一切都是資源。當(dāng)我們啟動一個(gè) JVM 的時(shí)候,我們就加載了許多的資源。而當(dāng)我們關(guān)閉 JVM 的時(shí)候,JVM 只會釋放內(nèi)存這個(gè)資源,而其他資源是不會釋放的,例如:網(wǎng)絡(luò)連接、文件句柄等等。

Linux 的網(wǎng)絡(luò)連接數(shù)、文件句柄數(shù)都是有限的,如果我們沒有及時(shí)釋放,時(shí)間久了就會導(dǎo)致一些奇怪的問題。那么如何在 JVM 關(guān)閉的時(shí)候,釋放這些資源呢?答案就是:利用 Java 提供的 ShutdownHook 接口。 我們所說的優(yōu)雅停機(jī),就是利用 Java 提供的 ShutdownHook 接口注冊一個(gè)鉤子,讓 JVM 在關(guān)閉之前執(zhí)行鉤子函數(shù)的代碼,讓其關(guān)閉對應(yīng)的資源。

適用場景

在學(xué)會怎么使用優(yōu)雅停機(jī)之前,我們需要弄清楚優(yōu)雅停機(jī)適用于哪些場景,那我們就需要先弄清楚 JVM 關(guān)閉的幾種情況了。JVM 關(guān)閉的情況可以分為 3 大類 11 個(gè)情況,如下圖所示:

圖片

JVM 關(guān)閉的場景

在 JVM 關(guān)閉的 3 大類場景中,只有正常關(guān)閉與異常關(guān)閉是支持優(yōu)雅停機(jī)的,而強(qiáng)制關(guān)閉則是不支持的。下面我們通過三個(gè)例子來驗(yàn)證一下。

JVM 正常關(guān)閉

JVM 正常關(guān)閉這種情況,我們只需要正常運(yùn)行一個(gè) main 函數(shù),然后為其注冊一個(gè) ShutdownHook 即可,其代碼如下所示。

public class NormalShutdownTest {
public void start() {
Runtime.getRuntime().addShutdownHook(new Thread(() ->
System.out.println("鉤子函數(shù)被執(zhí)行,可以在這里關(guān)閉資源。")
));
}

public static void main(String[] args) {
new NormalShutdownTest().start();
System.out.println("主應(yīng)用程序在執(zhí)行,正常關(guān)閉。");
}
}

輸出結(jié)果為:

主應(yīng)用程序在執(zhí)行,正常關(guān)閉。
鉤子函數(shù)被執(zhí)行,可以在這里關(guān)閉資源。

可以看到鉤子函數(shù)的代碼正常執(zhí)行了。如果你在 main 函數(shù)增加 System.exit(0) 代碼,執(zhí)行之后的結(jié)果也還是一樣。這說明 JVM 正常關(guān)閉情況下,是支持優(yōu)雅停機(jī)的。

異常關(guān)閉

JVM 異常關(guān)閉這種情況,我們嘗試制造內(nèi)存溢出。只需要聲明一個(gè) 500 MB 的數(shù)組,然后設(shè)置 JVM 堆最大為 20 MB 即可(-Xmx20M),其代碼如下所示。

public class OomShutdownTest {
public void start() {
Runtime.getRuntime().addShutdownHook(new Thread(() ->
System.out.println("鉤子函數(shù)被執(zhí)行,可以在這里關(guān)閉資源")
));
}

public static void main(String[] args) throws Exception {
new OomShutdownTest().start();
System.out.println("主應(yīng)用程序在執(zhí)行,內(nèi)存溢出關(guān)閉。");
byte[] b = new byte[500 * 1024 * 1024];
}
}

執(zhí)行結(jié)果為:

主應(yīng)用程序在執(zhí)行,內(nèi)存溢出關(guān)閉。
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at tech.shuyi.javacodechip.shutdownhook.OomShutdownTest.main(OomShutdownTest.java:13)
鉤子函數(shù)被執(zhí)行,可以在這里關(guān)閉資源

可以看到 JVM 拋出了 OOM 錯(cuò)誤,但是鉤子函數(shù)還是被執(zhí)行了。如果你在 main 函數(shù)中自行拋出 RuntimeException,鉤子函數(shù)也還是會被執(zhí)行。感興趣的朋友可以自行嘗試一下。

強(qiáng)制關(guān)閉

JVM 強(qiáng)制關(guān)閉這種情況,我們可以使用 Runtime.getRuntime().halt(1) 進(jìn)行測試,其代碼如下所示。

public class ForceShutdownTest {
public void start() {
Runtime.getRuntime().addShutdownHook(new Thread(() ->
System.out.println("鉤子函數(shù)被執(zhí)行,可以在這里關(guān)閉資源。")
));
}

public static void main(String[] args) throws Exception {
new ForceShutdownTest().start();
System.out.println("主應(yīng)用程序在執(zhí)行,強(qiáng)制關(guān)閉。");
Runtime.getRuntime().halt(1);
}
}

執(zhí)行結(jié)果:

主應(yīng)用程序在執(zhí)行,強(qiáng)制關(guān)閉。

可以看到鉤子函數(shù)并沒有被執(zhí)行,所以 JVM 強(qiáng)制關(guān)閉這種場景不支持優(yōu)雅停機(jī)。

最佳實(shí)踐

看了上面的例子,看起來優(yōu)雅停機(jī)沒那么復(fù)雜嘛。實(shí)際上,優(yōu)雅停機(jī)用不好,很可能出現(xiàn)一些其他問題。這里給出幾個(gè)最佳實(shí)踐原則,幫助大家用好優(yōu)雅停機(jī)!

只注冊一個(gè)鉤子

我們都知道 JVM 可以注冊多個(gè)鉤子,而鉤子本質(zhì)上是一個(gè)線程,可以并發(fā)執(zhí)行。那么就很可能出現(xiàn)鉤子之間相互依賴,這樣就會導(dǎo)致依賴死鎖了。另外,也可能因?yàn)槎鄠€(gè)鉤子操作同一個(gè)資源,導(dǎo)致資源競爭出現(xiàn)死鎖。因此,較好的一種方式就是只注冊一個(gè)鉤子,所有的資源釋放都在這個(gè)鉤子中操作。

確保線程安全

因?yàn)殂^子本質(zhì)上也是一個(gè)線程,JVM 可能會并發(fā)執(zhí)行多個(gè)鉤子,JVM 并不保證它們的執(zhí)行順序,因此需要保證鉤子中的操作是線程安全的。當(dāng)然了,如果你只有一個(gè)鉤子的話,那這個(gè)提示可以忽略了。

不要做耗時(shí)的操作

在鉤子中,不要做耗時(shí)的操作。因?yàn)楫?dāng)我們要關(guān)閉 JVM 時(shí),用戶肯定是希望盡快關(guān)閉,因此鉤子中主要用于關(guān)閉殘留資源,不應(yīng)該再做其他耗時(shí)的操作。

不要做注冊、移除鉤子的操作

在關(guān)閉鉤子中,不能執(zhí)行注冊、移除鉤子的操作,否則 JVM 拋出 IllegalStateException。

不要調(diào)用 System.exit () 操作

也不能調(diào)用 System.exit() 操作,但是調(diào)用 Runtime.halt() 操作是可以的。我想,這是因?yàn)檎{(diào)用 System.exit () 操作會導(dǎo)致循環(huán)進(jìn)入鉤子,導(dǎo)致死循環(huán)吧。

需要考慮的資源

除了上面一些代碼上的操作需要考慮,我們還需要注意下面這些場景的處理:

  • 池化資源的釋放:數(shù)據(jù)庫連接池、HTTP 連接池、線程池。
  • 在處理線程的釋放:已經(jīng)被連接的 HTTP 請求。
  • MQ 消費(fèi)者的處理:正在處理的消息。
  • 隱形受影響的資源的處理:Zookeeper、Nacos 實(shí)例下線等。

應(yīng)用案例

Java 提供的優(yōu)雅停機(jī)機(jī)制,可以說是許多框架的基礎(chǔ)。諸如 Spring、Consul 等中間件框架,都是利用 Java 提供的這個(gè)機(jī)制進(jìn)行優(yōu)雅停機(jī)的。

Spring 的優(yōu)雅停機(jī)

例如 Spring 是基于 Java 語言開發(fā)的框架,那其也勢必依賴于 JVM 的 ShutdownHook。Spring 關(guān)于優(yōu)雅停機(jī)的代碼在 org.springframework.context.support.AbstractApplicationContext#registerShutdownHook 處,代碼如下圖所示。

@Override
public void registerShutdownHook() {
if (this.shutdownHook == null) {
// No shutdown hook registered yet.
this.shutdownHook = new Thread(SHUTDOWN_HOOK_THREAD_NAME) {
@Override
public void run() {
synchronized (startupShutdownMonitor) {
doClose();
}
}
};
// 增加 ShutdownHook 鉤子
Runtime.getRuntime().addShutdownHook(this.shutdownHook);
}
}

可以看到 Spring 在 registerShutdownHook() 函數(shù)里,注冊了一個(gè)關(guān)閉的鉤子,鉤子中調(diào)用了 doClose() 方法。

服務(wù)治理的優(yōu)雅停機(jī)

不論是 Dubbo 還是 Spring Cloud 的分布式服務(wù)框架,需要關(guān)注的是怎么能在服務(wù)停止前,先將提供者在注冊中心進(jìn)行反注冊,然后在停止服務(wù)提供者,這樣才能保證業(yè)務(wù)系統(tǒng)不會產(chǎn)生各種 503、timeout 等現(xiàn)象。為了實(shí)現(xiàn)上述說到的效果,那么我們就必須關(guān)注優(yōu)雅停機(jī)這件事情。

彩蛋

我們都知道通過 kill -15 可以讓 JVM 優(yōu)雅停機(jī),那我們是否可以監(jiān)聽特定的信號量,從而讓程序做特定的操作呢?例如:讓 JVM 監(jiān)聽第 12 信號量,然后打印一條日志,隨后優(yōu)雅停機(jī)。

答案是當(dāng)然可以啦!我們只需要利用 Signal 類,并實(shí)現(xiàn)一個(gè) SignHandler 類就可以了。其實(shí)現(xiàn)代碼如下所示:

public class CustomShutdownTest {
public void start() {
Runtime.getRuntime().addShutdownHook(new Thread(() ->
System.out.println("鉤子函數(shù)被執(zhí)行,可以在這里關(guān)閉資源。")
));
}

public static void main(String[] args) {
// custom signal kill
Signal sg = new Signal("USR2"); // kill -12 pid
Signal.handle(sg, new SignalHandler() {
@Override
public void handle(Signal signal) {
System.out.println("接收到信號量:" + signal.getName());
// 監(jiān)聽信號量,通過System.exit(0)正常關(guān)閉JVM,觸發(fā)關(guān)閉鉤子執(zhí)行收尾工作
System.exit(0);
}
});
// other logic
new CustomShutdownTest().start();
System.out.println("主應(yīng)用程序在執(zhí)行,正常關(guān)閉。");
try {
Thread.sleep(30000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}

我們啟動該類后,先讓其休眠 30 秒,隨后用 jps 命令找到進(jìn)程 ID,隨后運(yùn)行 kill -USR2 PID 即可,如截圖所示。

圖片

隨后可以看到控制臺打印出如下消息:

主應(yīng)用程序在執(zhí)行,正常關(guān)閉。
接收到信號量:USR2
鉤子函數(shù)被執(zhí)行,可以在這里關(guān)閉資源。

從上面消息我們知道,JVM 成功接收到了 USR2 信號量,也成功執(zhí)行了鉤子函數(shù)。搞定!

提示:其實(shí) USR2 是 Linux 第 12 個(gè)信號量,是留給用戶使用的一個(gè)信號量。我們可以通過該信號量做一些定制化操作,從而實(shí)現(xiàn)更加復(fù)雜的功能。

參考資料

  • 如何優(yōu)雅地停止 Java 進(jìn)程 | iBit 程序猿
  • JVM 進(jìn)程的優(yōu)雅關(guān)閉 - waterystone - 博客園
  • VIP!例子比較不錯(cuò)!如何優(yōu)雅的關(guān)閉 JVM?-51CTO.COM
  • 比較深度一些,范圍比較廣!Spring—— 項(xiàng)目優(yōu)雅停機(jī) - 曹偉雄 - 博客園
  • RPC 服務(wù)治理相關(guān)。VIP!研究優(yōu)雅停機(jī)時(shí)的一點(diǎn)思考 | 徐靖峰 | 個(gè)人博客
  • Spring 的優(yōu)雅停機(jī) | Yanick's Blog
  • rocketmq 優(yōu)雅停機(jī)往事 - 云 + 社區(qū) - 騰訊云?
責(zé)任編輯:武曉燕 來源: 陳樹義
相關(guān)推薦

2022-07-24 09:46:48

優(yōu)雅停機(jī)代碼

2025-07-29 08:25:57

2021-05-08 08:33:00

Rocketmq日志數(shù)據(jù)源

2021-04-19 09:37:12

RocketMQ集群版本

2023-01-30 07:41:43

2020-08-25 10:34:22

微服務(wù)微服務(wù)架構(gòu)生產(chǎn)環(huán)境

2025-03-17 00:00:00

2024-03-18 14:06:00

停機(jī)Spring服務(wù)器

2020-08-03 07:04:54

測試面試官應(yīng)用程序

2025-03-11 00:55:00

Spring停機(jī)安全

2021-08-02 15:06:46

vim服務(wù)Java

2011-11-18 16:41:42

IDC世紀(jì)互聯(lián)

2021-02-06 13:11:28

SQL系統(tǒng)數(shù)據(jù)庫

2019-10-18 15:07:14

數(shù)據(jù)科學(xué)職業(yè)生涯萬努克

2021-06-10 06:59:34

Redis應(yīng)用API

2020-10-14 10:29:58

人工智能

2021-10-03 15:00:44

數(shù)據(jù)庫mysql單機(jī)

2018-11-01 13:38:51

Java中斷停止

2024-07-22 19:31:34

2020-11-18 08:17:14

Java源碼Class
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

精品免费国产| 久久久久久久久国产一区| 国产欧美日本一区视频| 青草青草久热精品视频在线观看| 黄色污在线观看| 丁香花在线电影小说观看| 国产盗摄女厕一区二区三区| 欧美肥老妇视频| 日本xxx在线播放| 99欧美精品| 亚洲美女视频一区| 国产经典一区二区三区| 久久久免费高清视频| 亚洲盗摄视频| 欧美久久久久久久久久| 日本熟妇人妻xxxx| 国产婷婷在线视频| 这里只有精品在线| 亚洲精品一区二区久| 日日躁夜夜躁aaaabbbb| 在线视频中文字幕第一页| 97精品久久久久中文字幕| 国产黑人绿帽在线第一区| 国产稀缺精品盗摄盗拍| 国产精品视频3p| 欧美性猛交xxxx| 亚洲一区二区不卡视频| 日韩中文字幕综合| 亚洲久久一区| 日韩国产精品一区| 性久久久久久久久久久久久久| 鲁鲁在线中文| 亚洲精品久久嫩草网站秘色| 欧美综合77777色婷婷| 国产女人18毛片18精品| 日韩影院在线观看| 中文字幕自拍vr一区二区三区| 69久久精品无码一区二区| free欧美| 五月天一区二区三区| 日韩欧美三级一区二区| 欧美特级特黄aaaaaa在线看| 精品一区二区成人精品| 欧美激情女人20p| 成人欧美一区二区三区黑人一| 六月丁香久久丫| 日韩欧美一卡二卡| 中文字幕成人在线视频| 欧美粗大gay| 亚洲精品成人少妇| 成年人黄色在线观看| 国产女主播在线直播| 99久久久精品免费观看国产蜜| 97免费资源站| 国产人妻精品一区二区三区 | 国产精品视频导航| 久久人人爽人人爽人人| 亚洲精品按摩视频| 日韩视频在线观看国产| 蜜臀精品一区二区三区| 综合av在线| 精品视频在线播放| 国产精品嫩草影院8vv8| 亚洲女同av| 疯狂蹂躏欧美一区二区精品| 日韩精品在线视频免费观看| 香港伦理在线| 91尤物视频在线观看| 动漫一区二区在线| www.五月激情| 久草中文综合在线| 国产精品com| 免费av网站在线| 亚洲综合好骚| 超碰精品一区二区三区乱码| www.99re6| 日韩一区二区在线| 久久精品国产亚洲精品2020| 午夜激情福利在线| xvideos国产在线视频| 一区二区三区高清在线| 裸体大乳女做爰69| 成人精品福利| 久久久久久久综合色一本| 蜜桃日韩视频| 五月天丁香视频| 国产三级精品三级| 亚洲黄色一区二区三区| 免费观看成人高潮| 亚洲黄色录像片| 欧洲精品在线播放| 涩涩视频在线免费看| 欧美综合天天夜夜久久| 91亚洲精品久久久蜜桃借种| 欧美日本三级| 国产视频综合在线| 久久久久麻豆v国产| 欧美成人久久| 午夜精品久久久久久99热| www成人在线| 亚洲毛片一区| 2020国产精品视频| 销魂美女一区二区| 狠狠色综合日日| 99国内精品久久久久久久软件| 午夜在线观看视频18| 成人爱爱电影网址| 国产福利一区二区三区在线观看| 精品国产免费无码久久久| 26uuu亚洲婷婷狠狠天堂| 一本一本a久久| 91在线超碰| 日本久久电影网| 小日子的在线观看免费第8集| 里番精品3d一二三区| 三级精品视频久久久久| 日本熟妇一区二区| 六月婷婷色综合| 国产伦精品一区二区三区四区免费| 蜜桃视频在线观看视频| 亚洲激情欧美激情| 国产三级三级三级看三级| 疯狂欧洲av久久成人av电影| 日韩精品视频在线观看网址 | 国产尤物一区二区在线| 激情一区二区三区| 国产黄色片在线观看| 有坂深雪av一区二区精品| 99视频精品免费| 亚洲一区二区三区日本久久九| 精品在线欧美视频| 精品成人av一区二区三区| 狠狠色丁香久久综合频道| 国产精品视频在线观看| 头脑特工队2免费完整版在线观看 头脑特工队2在线播放 | 理论片在线不卡免费观看| 性色av无码久久一区二区三区| 免费在线观看成人av| 国产精品12| 亚洲成人影院麻豆| 午夜婷婷国产麻豆精品| 中文字幕第66页| 91亚洲成人| 5566成人精品视频免费| 国内爆初菊对白视频| 亚洲靠逼com| 欧美成人三级在线播放| 精品国产一区二区三区av片| 欧美自拍视频在线观看| 欧美一级做性受免费大片免费| 亚洲精品视频在线观看免费| 日韩中文字幕二区| 一区二区美女| 日本在线观看天堂男亚洲| 亚洲欧洲视频在线观看| 午夜影院久久久| 中文字幕在线永久| 亚洲天堂久久| 国产精品视频福利| 黄色在线看片| 精品久久人人做人人爽| 曰本女人与公拘交酡| 国产自产视频一区二区三区 | 午夜精品电影| 92国产精品视频| 国产毛片在线| 色哟哟一区二区在线观看| 中文字幕一区二区三区人妻电影| 国产一区二区精品| 国产精品久久久久久久久久久久午夜片 | 国产精品视频内| 天堂а√在线官网| 91麻豆精品国产| 成人做爰视频网站| 国产精品亚洲午夜一区二区三区 | 亚洲人视频在线| 999国产精品视频| 成人免费福利在线| 日韩专区av| 56国语精品自产拍在线观看| 九九免费精品视频| 国产成人精品免费网站| 青青艹视频在线| 亚洲日本va午夜在线电影| 欧美激情日韩图片| 日韩av地址| 欧美日韩大陆一区二区| 男人操女人的视频网站| 国产传媒欧美日韩成人| 国产黄色一级网站| 欧美一区二区三区久久| 国产精品久久综合av爱欲tv| 乱人伦中文视频在线| 欧美精品一区二区不卡| 九九精品免费视频| 久久精品夜色噜噜亚洲a∨| 日韩成人精品视频在线观看| 黄色一区二区三区四区| 狼狼综合久久久久综合网| 国产精品亚洲成在人线| 欧美激情视频在线免费观看 欧美视频免费一 | 一级性生活毛片| 精品一区二区三区影院在线午夜| 日韩精品在线视频免费观看| 欧美精品系列| 成人av.网址在线网站| 91白丝在线| 中文字幕日韩综合av| 国产视频一二三四区| 动漫精品一区二区| 9999热视频| 久久久精品2019中文字幕之3| 欧美又黄又嫩大片a级| 亚洲国产网站| 国产精品波多野结衣| 一本久久青青| 成人免费激情视频| 蜜臀国产一区| 久久久久久午夜| 天天在线视频色| 亚洲国产精品网站| 中文字幕人妻精品一区| 亚洲一区二区在线免费观看视频| 欧美人与性囗牲恔配| www.欧美.com| japan高清日本乱xxxxx| 奇米色777欧美一区二区| 黄色一级在线视频| 亚洲无中文字幕| 日韩一区二区电影在线观看| 日本韩国欧美超级黄在线观看| 91久久国产精品| 玛雅亚洲电影| 久久久久久国产精品久久| av网站在线播放| 亚洲欧美第一页| 农村少妇久久久久久久| 欧美日韩你懂得| 自拍偷拍校园春色| 欧美视频在线免费看| 国产无套在线观看| 亚洲一区二区三区四区的| 黄色片网站免费| 久久一日本道色综合| 国产黄色三级网站| 国产专区欧美精品| 成年网站免费在线观看| 久热精品视频| 国产淫片av片久久久久久| 99综合视频| 男人日女人逼逼| 夜夜嗨一区二区| 日韩成人三级视频| 性欧美69xoxoxoxo| 免费成人进口网站| 亚洲男女av一区二区| 日韩 欧美 自拍| 综合国产精品| 超碰成人免费在线| 亚洲二区视频| 欧美国产亚洲一区| 亚洲欧美春色| 日本精品一区二区三区高清 久久| 欧美色图五月天| 国产精品久久精品国产| 欧美一性一交| 国产三级精品在线不卡| 日韩三级不卡| 91在线视频九色| 成人免费91| 国产日韩在线亚洲字幕中文| 婷婷激情成人| 99久re热视频这里只有精品6| 日韩在线精品强乱中文字幕| 国产精品国产精品| 秋霞影院一区二区三区| 玖玖玖精品中文字幕| 精品国产一区二区三区四区| 亚洲欧洲久久| 欧美久久影院| av黄色在线网站| 久热精品视频| www.久久久久久久久久久| 国产高清不卡一区二区| 午夜剧场免费看| 国产日韩精品一区二区三区 | 日韩av一二三四区| 美女视频免费一区| av影片在线播放| 不卡一区在线观看| 国产精品久久久视频| 亚洲欧美一区二区三区极速播放| 欧美久久久久久久久久久久| 中文字幕一区二区在线播放| 国产真实乱在线更新| 国产亲近乱来精品视频| 欧美国产日韩在线观看成人| 欧美日韩免费在线观看| 国产黄网在线观看| 欧美一区二区视频网站| 亚洲国产精品久久久久久6q| 亚洲毛片在线看| 免费日本一区二区三区视频| 午夜欧美大片免费观看| 久久夜夜久久| 久久99国产精品99久久| 日韩在线理论| 欧美日韩成人免费视频| 免费成人在线观看| 亚洲成人福利视频| 久久嫩草精品久久久精品| 极品盗摄国产盗摄合集| 在线亚洲高清视频| 亚洲国产精品久久久久久6q| 丝袜亚洲欧美日韩综合| 三级中文字幕在线观看| 91免费的视频在线播放| 特黄特色欧美大片| 91免费国产精品| 美女网站在线免费欧美精品| 国模私拍在线观看| 亚洲欧美另类小说视频| 五月天婷婷久久| 日韩情涩欧美日韩视频| 91sp网站在线观看入口| 九九热在线精品视频| 欧洲美女精品免费观看视频 | 色88888久久久久久影院| 中文字幕乱码免费| 欧美aaa在线| 伊人久久久久久久久| 国产精品久久影院| 在线观看污污网站| 亚洲国产精品资源| av在线之家电影网站| 日本精品久久久久久久| 青青草这里只有精品| 欧洲xxxxx| 日产国产欧美视频一区精品| 波多野结衣有码| 国产精品久久久久桃色tv| 无码免费一区二区三区| 日韩电影第一页| 国产乱码精品一区二三赶尸艳谈| 成人免费视频网| 日本成人福利| 国产精品有限公司| 午夜久久久久| 中文字幕无码毛片免费看| 中文字幕中文乱码欧美一区二区 | 欧美日本一区二区三区| av在线播放av| 91精品免费看| 亚洲一级淫片| 性欧美1819| 成人免费一区二区三区视频 | 亚洲精品一区二区三区蜜桃下载 | 亚洲一区二区三区免费| 久久久国内精品| 久久三级福利| 亚洲第一综合网| 欧美日韩精品欧美日韩精品 | 91精品国产乱码久久久张津瑜| 精品国产精品一区二区夜夜嗨| av片在线观看免费| 91九色蝌蚪国产| 激情婷婷欧美| 精品人妻伦一二三区久| 日本一区二区动态图| 中文字幕在线观看欧美| 久久精品国产综合| 九九99久久精品在免费线bt| 精品国产免费人成电影在线观...| 亚洲日韩成人| 粉嫩av蜜桃av蜜臀av| 亚洲国产精品久久人人爱| 天天综合天天综合| 国产精品91在线观看| 天天天综合网| 又大又长粗又爽又黄少妇视频| 一区二区三区日韩| 天堂av资源网| 国产精品久久久久久久9999| 欧美一区电影| caoporm在线视频| 2023国产精品自拍| 真实的国产乱xxxx在线91| 不卡av在线网站| 亚洲精品不卡在线观看| 日日碰狠狠添天天爽超碰97| 欧美激情一区二区| 中文字幕免费观看视频| www.久久色.com| 国产成人在线中文字幕| 日韩在线视频在线观看| 国产午夜精品久久久久久免费视| 国产色片在线观看| 欧美一级淫片aaaaaaa视频| 欧美3p视频| 精品久久久久一区二区|