日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

對話 UNIX,第 8 部分: UNIX 進程

瀏覽:301日期:2024-06-18 10:03:46

在最近的街頭游樂會上,有一個單人樂隊讓我很是著迷。的確,這讓我很開心,還給我留下了深刻印象。這個單人樂隊的唯一成員利用嘴、大腿、膝蓋和腳分別控制口琴、五弦琴、鈸和腳鼓,生動地演奏了齊柏林飛船樂隊的《天堂的階梯》,他演奏的貝多芬《第五交響曲》也頗為動人。和他相比,我能一邊拍腦袋一邊摸肚子就覺得很不錯了。(或者是一邊拍肚子一邊摸腦袋。)

對您來說,幸運的是,Unix® 操作系統(tǒng)更像是那個單人樂隊,而不是像我這個笨手笨腳的專欄作家。UNIX 特別擅長同時處理多個任務,并安排它們訪問系統(tǒng)中的有限資源(內(nèi)存、設備和 CPU)。打個比方,UNIX 可以一邊散步,一邊嚼口香糖。

這個月我們研究的內(nèi)容要比平常更深入一些,我們會看看 UNIX 是如何同時做這么多事的。這次我們還會探索 shell 的內(nèi)部,了解工作控制命令,如 Ctrl+C(終止)和 Ctrl+Z(掛起)是怎樣實現(xiàn)的。

一個真正的多任務系統(tǒng)

在 UNIX(以及大多數(shù)現(xiàn)代操作系統(tǒng),包括 Microsoft® Windows®、Mac OS X、FreeBSD 和 Linux®)中,每個計算任務都是由一個進程表示的。UNIX 似乎能同時運行很多任務,這是因為每個進程都會輪流(從概念上來講)分到一小片 CPU 時間。

一個進程就像一個容器,它與某個正在運行的應用程序、環(huán)境變量、應用程序的輸入和輸出,以及進程的狀態(tài)(包括其優(yōu)先級和累計資源使用情況)捆綁在一起。圖 1 顯示了一個進程。

圖 1. UNIX 進程的概念化模型

為了便于理解,您可以把一個進程想像成一個獨立的國家,有邊界、資源,還有國民生產(chǎn)總值。

每個進程還有一個所有者。一般來說,您啟動的任務(如您的 shell 和命令)的所有者就是您。系統(tǒng)服務的所有者可能是特殊用戶或超級用戶 root。例如,為了增強安全性,Apache HTTP Server 的所有者一般是一個名為 www 的專用用戶,該用戶能提供 Web 服務器所需的的文件訪問權限,但不包含其他權限。

進程的所有權可能會改變,但必須嚴格保持其獨占性。一個進程在任何時候都只能有一個所有者。

最后,每個進程都具有權限。一般來說,進程的權限與其所有者的權限是相稱的。(例如,如果您無法在命令行 Shell 中訪問某個特定文件,則您從 Shell 中啟動的程序也會繼承同樣的限制。)這一繼承規(guī)則有一個例外情況,即應用程序啟用了特殊的 setuid 或 setgid 位,如 ls 顯示的那樣,在此情況下,某個進程可能會獲得比其所有者更高的權限。

setuid 位可以使用 chmod u+s 進行設置。setuid 的權限如下所示:

$ ls -l /usr/bin/top-rwsr-xr-x 1 root wheel 83088 Mar 20 2005 top

setgid 位可以使用 chmod g+s 設置:

$ ls -l /usr/bin/top-r-xr-sr-x  1 root tty 19388 Mar 20 2005 /usr/bin/wall

一個 setuid 進程(如啟動 top)是用擁有該文件的用戶權限運行的。因此,當您運行 top 時,您的權限會被提升,與 root 的權限等同。類似地,一個 setgid 進程是用與文件的組所有者相關聯(lián)的權限運行的。

例如,在 Mac OS X 中,wall 工具(“write all的縮寫,因其會將某個消息寫入所有物理或虛擬終端設備而得名)的 setgid 被設為tty(如上所示)。當您登錄并分配到一個用來鍵入的終端設備(該終端成為 Shell 的標準輸入)時,您將被指定為該設備的所有者,而 tty 成為組所有者。因為 wall 是以組 tty 的權限運行的,所以它可以打開和寫入所有終端。

獲取列表

就像所有其他系統(tǒng)資源一樣,您的 Unix 有一個有限但十分龐大的進程池(實際上,系統(tǒng)中的進程幾乎用之不盡)。每個新任務(如啟動 vi 或運行 xclock)都會立即從池中分配到一個進程。在 UNIX 系統(tǒng)中,您可以使用 ps 命令,查看一個或多個進程。

例如,如果您想查看您擁有的所有進程,鍵入 ps -w --user username :$ ps -w --user mstreicher

您可以使用 ps -a -w -x 查看完整的進程列表。(ps 命令的格式和特定的標志隨各個 UNIX 版本而有所差異。請參閱系統(tǒng)的聯(lián)機文檔,以查找具體的說明。) -a 是選擇 tty 設備上運行的所有進程;-x 則可進一步選擇與 tty 無關的所有進程,通常包括所有的永久系統(tǒng)服務,如 Apache HTTP server、cron 工作調(diào)度程序等等;-w 則以加寬的格式顯示內(nèi)容,在查看命令行或與每個進程相關的應用程序完整路徑名時很有用。

ps 具有豐富的功能,某些版本的 ps 甚至允許您自定義輸出。例如,下面就是一個有用的自定義進程列表:

$ ps --user mstreicher -o pid,uname,command,state,stime,time PID USER COMMAND S STIME TIME14138 mstreic sshd: mstreicher S 09:57 00:00:0014139 mstreic -bashS 09:57 00:00:0014937 mstreic ps --user mstrei R 10:23 00:00:00

-o 根據(jù)各列名稱的順序?qū)敵鲞M行格式化。pid、uname 和 command 分別指進程 ID、用戶名和命令。state 代表進程的狀態(tài),如正在睡眠 (S) 或運行 (R)。(稍后將對進程狀態(tài)進行更詳細的說明。)stime 顯示命令的開始時間,time 則顯示該進程占用了多少 CPU 時間。

進程從哪里來?

在 Unix 中,某些進程會從系統(tǒng)啟動到關機的時間里一直運行,但大多數(shù)進程都會隨任務的開始和完成而迅速地出現(xiàn)和消失。有時,某個進程可能會“早夭“,甚至會“暴死(比如在系統(tǒng)崩潰時)。新的進程是從哪里來的呢?

每個新的 UNIX 進程都是某個現(xiàn)有進程的產(chǎn)物。另外,每個新進程(不妨將其稱為“子進程)是對“父進程的克隆體(至少有一瞬間是如此),直到“子進程繼續(xù)獨立執(zhí)行為止。(如果每個進程都是某個現(xiàn)有進程的后代,那么不免會有一個疑問:“第一個進程是從哪里來的?請參閱下面的側(cè)欄以尋找答案。)

雞和蛋

某些爭論是經(jīng)久不息的:生存還是毀滅?可口可樂還是百事可樂?PC 還是 Mac?當然,還有一個古老的悖論,“雞生蛋,還是蛋生雞?

如果每個新的 UNIX 進程都是某個現(xiàn)有的、正在運行的進程的后代,那么第一個進程是從哪里來的?答案是:UNIX 內(nèi)核在系統(tǒng)啟動序列中產(chǎn)生了第一個進程。

第一個進程被恰如其分地稱為 init,所有其他系統(tǒng)進程的親緣關系最終都可以追溯到 init。實際上,init 的進程編號是 1。如果您要查看 init 的狀態(tài),可鍵入 ps -l 1:

F S UID PID PPID C PRI NI ADDR SZ WCHAN TTY TIME CMD4 S  0  10 0 68  0 -  373 select ?  0:02 init [2]正如您所看到的,init 的所有者 (UID) 是 0 (root)。和系統(tǒng)中所有其他進程不同的是,init 沒有父進程,它的父進程 ID (PPID) 為 0。

圖 1-4 詳細說明了進程的產(chǎn)生過程:

在圖 2 和圖 3 中,進程 A (Process A),正在運行一個由藍色方框表示的程序。它運行編號為 10,11,12…的指令。進程 A 有屬于自己的數(shù)據(jù)、程序的副本、打開的文件集,以及自己的環(huán)境變量集,當進程 A 剛出現(xiàn)時,會對它們進行初次捕捉。

圖 2. 進程 A 運行代碼

在 Unix 中,fork() 系統(tǒng)調(diào)用(之所以有這個名稱,是因為它是一個調(diào)用或請求,要求操作系統(tǒng)進行協(xié)助)被用來產(chǎn)生新的進程。當程序 A (Program A) 執(zhí)行指令 13 (Instruction 13) fork() 時,系統(tǒng)會立即創(chuàng)建進程 A 的一個精確克隆版本,并將其命名為進程 Z (Process Z)。Z 具有和 A 相同的環(huán)境變量、相同的內(nèi)存內(nèi)容、相同的程序狀態(tài),打開的文件也一樣。圖 3 顯示的是進程 A 生成進程 Z后,進程 A 和 Z 的狀態(tài)。

圖 3. 進程 A 生成自身的克隆體

起初,進程 Z 是從進程 A 停止的地方開始執(zhí)行的。也就是說,此后進程 Z 從指令 14 (Instruction 14) 處開始執(zhí)行。進程 A 會在同一指令位置繼續(xù)執(zhí)行。

一般來說,指令 14 處的編程邏輯將測試當前的進程是子進程還是父進程,也就是說,進程 Z 和進程 A 中的指令 14 分別判定這兩個進程是否為其他進程的后代或祖先。為了以示區(qū)別,fork() 系統(tǒng)調(diào)用在子進程中返回 0,但返回給父進程的卻是進程 Z 的進程 ID。

在上次測試之后,進程 A 和進程 Z 會出現(xiàn)差異,每個進程會采用單獨的代碼路徑,就像路上出現(xiàn)岔道,每一個都會走上不同的分枝。生成一個新進程的流程更多地被稱為分叉,這就像兩位旅行者走到了路上的岔道。因此,系統(tǒng)調(diào)用被命名為 fork()。

在分叉之后,進程 A 可能會繼續(xù)運行同一個應用程序。而進程 Z 則可能立即發(fā)生變化,轉(zhuǎn)到另一個應用程序。后一種操作會改變程序通過進程運行的內(nèi)容,它被稱為執(zhí)行,但您可以把它看成是一次再生過程:雖然進程 ID 不變,但進程內(nèi)部的指令會被新程序的指令完全取代。圖 4 顯示的是稍后進程 Z 的狀態(tài)。

圖 4. 進程 Z 現(xiàn)在獨立于它的祖先,即進程 A

分叉

您可以在自己的命令行,很方便地體驗分叉操作。首先,打開一個新的 xterm。(您現(xiàn)在可能會認識到,xterm 就是它本身的進程,在 xterm 中,shell 是由 xterm 產(chǎn)生的一個獨立進程)。接下來,輸入:ps -o pid,ppid,uname,command,state,stime,time

您應該會看到類似這樣的內(nèi)容: PID PPID USER COMMAND S STIME TIME16351 16350 mstreic -bashS 11:23 00:00:0016364 16351 mstreic ps -o pid,ppid,u R 11:24 00:00:00

從該列表的 PPID 字段中,我們知道 ps 命令是 bash shell 的子進程。(-bash 中的連字符說明 shell 實例是一個登錄 shell。)為了運行 ps,bash 會分叉,創(chuàng)建一個新進程;新進程通過使用執(zhí)行,使其本身得以重生,轉(zhuǎn)化為 ps 的一個新的實例。

這里是另一個可供嘗試的實驗。鍵入:sleep 10 & sleep 10 & sleep 10 & ps -o pid,ppid,uname,command,state,stime,time

您應該會看到類似這樣的內(nèi)容:$ sleep 10 & sleep 10 & sleep 10 & ps -o pid,ppid,uname,command,state,stime,time PID PPID USER COMMAND S STIME TIME16351 16350 mstreic -bashS 11:23 00:00:0016843 16351 mstreic sleep 10 S 11:42 00:00:0016844 16351 mstreic sleep 10 S 11:42 00:00:0016845 16351 mstreic sleep 10 S 11:42 00:00:0016846 16351 mstreic ps -o pid,ppid,u R 11:42 00:00:00

命令行生成四個新進程。在每個 sleep 命令后鍵入 &,在后臺運行每一個命令,或與 Shell 并行。 ps 是生成的另一個進程,但它是在前臺運行的,可以防止 shell 在該進程終止之前運行其他命令。而且,如 PPID 的值所示,所有四個進程都是 Shell 的后代。三個 sleep 命令都被標為 S,因為沒有哪個進程會在它們睡眠時使用資源。

為了方便起見,shell 會持續(xù)跟蹤它生成的所有后臺進程。鍵入 jobs,可以看到一個列表:

$ sleep 10 & sleep 10 & sleep 10 &[1] 16843[2] 16844[3] 16845$ jobs[1]  Running sleep 10 &[2]  Running sleep 10 &[3]  Running sleep 10 &

此處,為了方便起見,三個工作分別用標簽標為 1,2 和 3。數(shù)字 16843、16844 和 16845 分別是每個進程的進程 ID。因此,后臺任務 1 即為進程 ID 16843。

您可以利用這些標簽,從命令行操作您的后臺工作。例如,如要終止某個命令,鍵入 kill %N ,其中 N 是該命令的標簽。如要將某個命令由后臺移到前臺,請鍵入 fg %N :

$ sleep 10 & sleep 10 & sleep 10 &[7] 17741[8] 17742[9] 17743$ kill %7$ jobs[7]  Terminated sleep 10[8]- Running sleep 10 &[9]+ Running sleep 10 &$ fg %8sleep 10

從命令行中同時異步運行多個命令,是處理您自己的任務集的好方法。一個長時間運行的工作(例如,系統(tǒng)管理的數(shù)值計算或大型程序的編譯)最適合放在后臺。為了捕獲每個后臺命令的輸出,請考慮使用重定向操作符 >、>&、>> 和 >>&,將輸入重定向到某個文件。當后臺命令結束后,shell 會在下一個提示符之前顯示一條警告消息:

$ whoamimstreicher[8]- Donesleep 10[9]+ Donesleep 10$

向遙遠的進程池前進

某些進程會一直存活(如 init),而某些進程會以新的形式重生(如您的 shell)。最終大多進程都會因自然原因(即程序運行結束)而消亡。

此外,您還可以將某個進程放在一個掛起的動作序列中,等待被再次激活。正如先前的示例所示,您可以用 kill 提前終止某個進程。

當某個命令在前臺運行時,如果您希望將它掛起,請按 Ctrl + Z:

$ sleep 10(Press Control-Z)[1]+ Stopped sleep 10$ ps PID PPID USER COMMAND S STIME TIME18195 16351 mstreic sleep 10 T 12:44 00:00:00

Shell 已將命令掛起,為了方便起見,還為它分配了一個標簽。您可以像先前那樣使用這個標簽,以終止工作或讓工作返回前臺。您還可以使用 bg 命令在后臺恢復這個進程:

bg %1[1]+ sleep 10 &

當某個命令在前臺運行時,如果您想終止它,請按 Ctrl + C:

$ sleep 10(Press Control-C$ jobs$

您的 Shell 能使進程的掛起和終止變得更容易,但在 Shell 單純的外表下,卻隱藏著復雜的一面。在內(nèi)部,Shell 使用 Unix 信號來影響進程的狀態(tài)。信號是一個事件,它被用來向某個進程發(fā)出警報。操作系統(tǒng)生成許多信號,但您可以將信號從一個進程發(fā)送到另一個進程,甚至能讓某個進程給自己發(fā)送信號。

UNIX 包括多種信號,它們大多都有特殊目的。例如,如果您將信號 SIGSTOP 發(fā)送到某個進程,該進程將掛起。(要獲取信號的完整列表,請鍵入 man 7 signal 或鍵入 kill -L)。您可以用 kill 命令發(fā)送信號。

$ sleep 20 &[1] 19988$ kill -SIGSTOP 19988$ jobs[1]+ Stopped sleep 20

起初,sleep 命令在后臺啟動,其進程 ID 為 19988。在發(fā)送 SIGSTOP 之后,該進程會改變狀態(tài),變?yōu)閽炱鸹蛲V埂0l(fā)送另一個信號 SIGCONT,重新激活進程,該進程將從上次停止的地方繼續(xù)執(zhí)行。

也就是說,每次您按 Ctrl + Z 時,您的 shell 將向前臺發(fā)送 SIGSTOP 信號。bg 命令發(fā)送 SIGCONT。而 Ctrl + C 則會發(fā)送 SIGTERM,要求立即終止進程。

一些信號可以被某個進程阻塞,應用程序可以通過設計,顯式地“捕捉 (catch)信號,并以一種特殊的方式對每個事件作出反應。例如,系統(tǒng)服務 xinetd 會按需要啟動其他網(wǎng)絡服務,它在收到 SIGHUP 時會重新讀取它的配置文件。在 Linux 中,向 init 發(fā)送信號,可能會改變系統(tǒng)的運行級別,甚至會導致系統(tǒng)關閉。.(這里有一個問題:kill %1 和 kill 1 有什么區(qū)別?

進程甚至可以給自己發(fā)送信號。想像一下,您正在編寫一個游戲,想留給用戶五秒鐘時間作出反應。您的代碼可以設置一個五秒鐘的定時器,接下來繼續(xù)進行重繪屏幕等操作。當定時器的時間耗盡后,將有一個 SIGALRM 信號被送回您的進程。呯!時間到!

(這里提供了問題的答案:kill %1 會終止標簽為 1 的后臺工作。kill 1 會終止 init,當必須關閉計算機時,將向操作系統(tǒng)發(fā)送這個信號。)

在特殊情況下,操作系統(tǒng)還可以將一些其他信號傳送給進程。內(nèi)存違例會引發(fā) SIGSEGV 信號,立即終止進程,并留下一個內(nèi)核轉(zhuǎn)儲。有一個特殊的信號 SIGKILL 是無法被阻塞或捕捉的,它會立即終止某個進程。

和 Unix 中許多其他資源一樣,您只能向您擁有的進程發(fā)送信號。這可以防止您終止重要的系統(tǒng)服務和其他用戶的進程。超級用戶 root 可以向任何進程發(fā)送信號。

更多魔法揭密

UNIX 有許多可活動的部分。它有系統(tǒng)服務、設備、內(nèi)存管理器等等。好在這些復雜的花樣大都被隱藏起來,不會被看到,或可以通過用戶界面(如 shell 或窗口工具)很方便地使用。更妙的是,如果您想深入探究,隨時都可以使用 top, ps 和 kill 等專用工具。

現(xiàn)在您已經(jīng)知道了進程的工作原理,可以組成自己的單人樂隊了。只有一個要求:成為一只自由自在的飛鳥!

標簽: Unix系統(tǒng)
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲一区二区毛片| 国产精品密蕾丝视频下载| 国产成人精品一区二区三区免费| 国产欧美69| 国产精品日韩精品中文字幕| 国产精品久久久久久av公交车| 国产精品主播在线观看| 九九久久国产| 伊人久久视频| 免费视频一区三区| 亚洲激情婷婷| aa国产精品| 亚洲综合婷婷| 欧美日韩在线精品一区二区三区激情综合| 国产精品亚洲综合色区韩国| 成人污污视频| 91成人精品| 三级久久三级久久久| 97精品国产| 欧美福利专区| 亚洲区第一页| 国产精品chinese| 国产一区二区三区网| 欧美香蕉视频| 亚洲精品中文字幕乱码| 中文字幕日韩高清在线| 日韩国产精品久久久久久亚洲| 国产精品一区二区中文字幕| 精品一区二区三区中文字幕| 999久久久91| 免费看黄色91| 国产精品亚洲综合久久| 天堂网av成人| 怡红院精品视频在线观看极品| 亚洲另类黄色| 欧美成人一二区| 99久久亚洲精品蜜臀| 亚洲精品中文字幕99999| 精品少妇一区| 亚洲资源av| 国产精品国产三级在线观看| 亚洲成人va| 精品丝袜在线| 日韩精品亚洲专区在线观看| 福利在线免费视频| 免费在线观看成人| 国精品产品一区| 午夜亚洲福利在线老司机| 久久久久国产精品一区二区| 日欧美一区二区| 蜜桃成人av| 嫩草伊人久久精品少妇av杨幂| 香蕉视频成人在线观看| 国产精品美女久久久| 国产精品**亚洲精品| 国产日韩欧美中文在线| 国产成人精品三级高清久久91| 国产亚洲久久| 日韩免费视频| 999久久久精品国产| 国产午夜久久| 亚洲精品伦理| 日韩精品一区二区三区免费视频| 日韩视频一二区| 日本伊人久久| 亚洲黄色中文字幕| 色老板在线视频一区二区| 中文字幕一区二区三区四区久久| 国产精品久久国产愉拍| 91高清一区| 成人看片网站| 狠狠久久婷婷| 欧美日韩伊人| 国产精品亚洲一区二区三区在线观看| 91精品国产调教在线观看| 一区二区三区国产在线| 成人台湾亚洲精品一区二区| 蜜桃视频一区二区三区| 久久精品国产99国产精品| 国产精品毛片一区二区三区| 日韩精品免费视频一区二区三区| 999国产精品999久久久久久| 国产精品欧美三级在线观看| 中文字幕av一区二区三区人| 视频一区国产视频| 九九九精品视频| 日韩专区一卡二卡| 91亚洲成人| 日本不良网站在线观看| 国产精品字幕| 欧美日韩一区二区国产 | 国产精品不卡| 精品一区二区三区在线观看视频| 成人午夜亚洲| 国产精品美女午夜爽爽| 麻豆中文一区二区| 国产一区二区精品久| 青青草国产精品亚洲专区无| 亚洲欧美日韩在线观看a三区| 国产视频一区在线观看一区免费| 热三久草你在线| 黑森林国产精品av| 欧美va天堂在线| 国产精品三上| 成人片免费看| 日韩成人综合| 国产调教精品| 日本中文字幕视频一区| 人人精品人人爱| 国产精品美女| 欧美专区一区二区三区| 美女91精品| 欧美成人国产| 99精品在线| jiujiure精品视频播放| 亚洲最新无码中文字幕久久 | 欧美日韩一区二区三区在线电影| 日韩专区视频网站| 蜜乳av另类精品一区二区| 1000部精品久久久久久久久| 欧美精品一二| 欧美精品一区二区久久| 涩涩涩久久久成人精品| 欧美午夜网站| 国产一区二区三区成人欧美日韩在线观看| 美女国产一区二区三区| caoporn视频在线| 日韩高清一区二区| 中文字幕在线视频网站| 中文字幕在线高清| 亚洲午夜在线| 国产午夜精品一区在线观看| 日本国产欧美| 蜜桃精品在线| 国产精品日韩| 亚洲婷婷在线| 免费在线成人| 在线国产精品一区| 国产日韩一区二区三区在线| 国产成年精品| 国产视频一区在线观看一区免费| 久久影院一区二区三区| 亚洲精品第一| 久草免费在线视频| 日本综合精品一区| 中文字幕一区久| 欧美日韩在线网站| 久久不见久久见免费视频7| 欧美三级精品| 好吊一区二区三区| 欧美久久香蕉| 免费视频最近日韩| 国产精品美女| 日韩在线短视频| 麻豆精品在线| 蜜桃一区二区三区在线| 午夜精品成人av| 久久亚洲色图| 国产精品腿扒开做爽爽爽挤奶网站| 国产亚洲人成a在线v网站| 久久精品三级| 99久久精品国产亚洲精品| 国产精品地址| 蜜桃av.网站在线观看| 欧美国产不卡| av资源中文在线| 国产精品入口久久| 蜜臀91精品一区二区三区| 精品国产第一福利网站| 国产一级成人av| 中文字幕一区二区三区日韩精品 | 黄色在线一区| 激情五月综合网| 韩国精品主播一区二区在线观看 | 精品久久久亚洲| 婷婷精品在线| 国产欧美另类| 亚欧洲精品视频在线观看| 91日韩欧美| 日韩在线中文| 国产精品v日韩精品v欧美精品网站 | 精品视频自拍| 久久成人亚洲| 蜜臀精品久久久久久蜜臀| 丝袜a∨在线一区二区三区不卡| 不卡一区综合视频| 欧美香蕉视频| 免费人成在线不卡| 亚洲一二三区视频| 免费欧美日韩| 久久香蕉精品| 天海翼精品一区二区三区| 日韩福利视频导航| 久久精品xxxxx| 亚洲a一区二区三区| 午夜精品网站| 麻豆久久一区| 日韩高清不卡在线| 欧洲av不卡| 欧美日韩a区|