青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

旅途

如果想飛得高,就該把地平線忘掉

Linux——Linux后臺運行命令詳述

本次主要講述后臺運行命令(crontab,at,&,nohup)及(*,?,[])等

? 設置c r o n t a b文件,并用它來提交作業。
? 使用a t命令來提交作業。
? 在后臺提交作業。
? 使用n o h u p命令提交作業。
名詞解釋:
cron:系統調度進程。可以使用它在每天的非高峰負荷時間段運行作業,或在一周或一月中的不同時段運行。
at命令:使用它在一個特定的時間運行一些特殊的作業,或在晚一些的非負荷高峰時間段或高峰負荷時間段運行。
&:使用它在后臺運行一個占用時間不長的進程。
nohup:用它在后臺運行一個命令,即使在用戶退出時也不受影響


1.cron and crontab

c r o n是系統主要的調度進程,可以在無需人工干預的情況下運行作業。c r o n t a b命令允許用戶提交、編輯或刪除相應的作業。每一個用戶都可以有一個c r o n t a b文件來保存調度信息。可以使用它運行任意一個s h e l l腳本或某個命令,每小時運行一次,或一周三次,這完全取決于你。每一個用戶都可以有自己的c r o n t a b文件,但在一個較大的系統中,系統管理員一般會禁止這些文件,而只在整個系統保留一個這樣的文件。系統管理員是通過c r o n . d e n y和c r o n . a l l o w這兩個文件來禁止或允許用戶擁有自己的c r o n t a b文件。

crontab的域

為了能夠在特定的時間運行作業,需要了解c r o n t a b文件每個條目中各個域的意義和格式。

下面就是這些域:
代碼:

第1列分鐘1~5 9
第2列小時1~2 3(0表示子夜)
第3列日1~3 1
第4列月1~1 2
第5列星期0~6(0表示星期天)
第6列要運行的命令


下面是c r o n t a b的格式:
代碼:

分< >時< >日< >月< >星期< >要運行的命令


其中< >表示空格。

c r o n t a b文件的一個條目是從左邊讀起的,第一列是分,最后一列是要運行的命令,它位于星期的后面。

可以用橫杠-來表示一個時間范圍,例如你希望星期一至星期五運行某個作業,那么可以在星期域使用1 - 5來表示。
還可以在這些域中使用逗號“,”,例如你希望星期一和星期四運行某個作業,只需要使用1 , 4來表示。
可以用星號*來表示連續的時間段。如果你對某個表示時間的域沒有特別的限定,也應該在該域填入*。該文件的每一個條目必須含有5個時間域,而且每個域之間要用空格分隔。
該文件中所有的注釋行要在行首用#來表示。



c r o n t a b文件例子:
代碼:

30 21* * * /apps/bin/cleanup.sh

上面的例子表示每晚的2 1 : 3 0運行/ a p p s / b i n目錄下的c l e a n u p . s h。

代碼:

45 4 1,10,22 * * /apps/bin/backup.sh

上面的例子表示每月1、1 0、2 2日的4 : 4 5運行/ a p p s / b i n目錄下的b a c k u p . s h。

代碼:

10 1 * * 6,0 /bin/find -name "core" -exec rm {} \;

上面的例子表示每周六、周日的1 : 1 0運行一個f i n d命令。

代碼:

0,30 18-23 * * * /apps/bin/dbcheck.sh

上面的例子表示在每天1 8 : 0 0至2 3 : 0 0之間每隔3 0分鐘運行/ a p p s / b i n目錄下的d b c h e c k . s h。

代碼:

0 23 * * 6 /apps/bin/qtrend.sh

上面的例子表示每星期六的11 : 0 0 p m運行/ a p p s / b i n目錄下的q t r e n d . s h。

你可能已經注意到上面的例子中,每個命令都給出了絕對路徑。當使用c r o n t a b運行s h e l l腳本時,要由用戶來給出腳本的絕對路徑,設置相應的環境變量。記住,既然是用戶向c r o n提交了這些作業,就要向c r o n提供所需的全部環境。不要假定c r o n知道所需要的特殊環境,它其實并不知道。所以你要保證在s h e l l腳本中提供所有必要的路徑和環境變量,除了一些自動設置的全局變量。
如果c r o n不能運行相應的腳本,用戶將會收到一個郵件說明其中的原因。

c r o n t a b命令的一般形式為:
代碼:

crontab [-u user] -e -l -r


其中:
-u 用戶名。
-e 編輯c r o n t a b文件。
-l 列出c r o n t a b文件中的內容。
-r 刪除c r o n t a b文件。


如果使用自己的名字登錄,就不用使用- u選項,因為在執行c r o n t a b命令時,該命令能夠知道當前的用戶。


創建一個新的crontab文件

在向c r o n進程提交一個c r o n t a b文件之前,要先設置環境變量E D I TO R.c r o n進程根據它來確定使用哪個編輯器編輯c r o n t a b文件。大部份的U N I X和L I N U X用戶都使用v i,如果你也是這樣,那么你就編輯$ H O M E目錄下的. p r o f i l e文件,在其中加入這樣一行:
代碼:

EDITOR=vi; export EDITOR

然后保存并退出。

創建一個名為< u s e r > c r o n的文件,其中< u s e r >是用戶名,例如, samcron。在該文件中加入如下的內容。
代碼:

#(put your own initials here) echo the date to the console every
#15 minutes between 6pm and 6am
0,15,30,45 18-06 * * * /bin/echo 'date' > /dev/console


保存并退出。確信前面5個域用空格分隔。
在上面的例子中,系統將每隔1 5分鐘向控制臺輸出一次當前時間。如果系統崩潰或掛起,從最后所顯示的時間就可以一眼看出系統是什么時間停止工作的。在有些系統中,用t t y 1來表示控制臺,可以根據實際情況對上面的例子進行相應的修改。
為了提交你剛剛創建的c r o n t a b文件,可以把這個新創建的文件作為c r o n命令的參數:
代碼:

$su sam
crontab samcron


為了方便演示,切換到sam用戶環境下,然后用crontab samcron提交給c r o n進程,它將每隔1 5分鐘運行一次。

同時,新創建文件的一個副本已經被放在/ v a r / s p o o l / c r o n目錄中,文件名就是用戶名(即sam)。

代碼:

#su
# cat /var/spool/cron/sam
# DO NOT EDIT THIS FILE - edit the master and reinstall.
# (samcron installed on Wed Nov 10 21:41:55 2004)
# (Cron version -- $Id: crontab.c,v 2.13 1994/01/17 03:20:37 vixie Exp $)
#(put your own initials here) echo the date to the console every
#15 minutes between 6pm and 6am
0,15,30,45 18-06 * * * /bin/echo 'date' > /dev/console


回到root下,查看/var/spool/cron/sam

列出crontab文件

為了列出c r o n t a b文件,可以用:
代碼:

$ crontab -l
# DO NOT EDIT THIS FILE - edit the master and reinstall.
# (samcron installed on Wed Nov 10 21:41:55 2004)
# (Cron version -- $Id: crontab.c,v 2.13 1994/01/17 03:20:37 vixie Exp $)
#(put your own initials here) echo the date to the console every
#15 minutes between 6pm and 6am
0,15,30,45 18-06 * * * /bin/echo 'date' > /dev/console


你將會看到和上面類似的內容。可以使用這種方法在$ H O M E目錄中對c r o n t a b文件做一備份:
代碼:

$ crontab -l > $HOME/mycron

這樣,一旦不小心誤刪了c r o n t a b文件,可以用上一節所講述的方法迅速恢復。


編輯crontab文件

如果希望添加、刪除或編輯c r o n t a b文件中的條目,而E D I TO R環境變量又設置為v i,那么就可以用v i來編輯c r o n t a b文件,相應的命令為:
代碼:

$ crontab -e


可以像使用v i編輯其他任何文件那樣修改c r o n t a b文件并退出。如果修改了某些條目或添加了新的條目,那么在保存該文件時, c r o n會對其進行必要的完整性檢查。如果其中的某個域出現了超出允許范圍的值,它會提示你。
例如,加入下面的一條:
代碼:

#DT:delete core files,at 3:30am on 1,7,14,21,26 days of each month
30 3 1,7,14,21,26 * * /bin/find -name "core" -exec rm {} \;


現在保存并退出。最好在c r o n t a b文件的每一個條目之上加入一條注釋,這樣就可以知道它的功能、運行時間,更為重要的是,知道這是哪位用戶的作業。
現在讓我們使用前面講過的crontab -l命令列出它的全部信息:
代碼:

#(put your own initials here) echo the date to the console every
#15 minutes between 6pm and 6am
0,15,30,45 18-06 * * * /bin/echo 'date' > /dev/console

#DT:delete core files,at 3:30am on 1,7,14,21,26 days of each month
30 3 1,7,14,21,26 * * /bin/find -name "core" -exec rm {} \;



刪除crontab文件

為了刪除c r o n t a b文件,可以用:
代碼:

$ crontab -r


恢復丟失的crontab文件
如果不小心誤刪了c r o n t a b文件,假設你在自己的$ H O M E目錄下還有一個備份,那么可以將其拷貝到/ v a r / s p o o l / c r o n / < u s e r n a m e >,其中< u s e r n a m e >是用戶名。如果由于權限問題無法完成拷貝,可以用:
代碼:

$ crontab <filename>


其中,< f i l e n a m e >是你在$ H O M E目錄中副本的文件名。
建議在自己的$ H O M E目錄中保存一個該文件的副本。編輯副本,然后重新提交新的文件。
有些c r o n t a b的變體有些怪異,所以在使用c r o n t a b命令時要格外小心。如果遺漏了任何選項,c r o n t a b可能會打開一個空文件,或者看起來像是個空文件。這時敲d e l e t e鍵退出,不要按< C t r l - D >,否則你將丟失c r o n t a b文件。



2.at

a t命令允許用戶向c r o n守護進程提交作業,使其在稍后的時間運行。一旦一個作業被提交, a t命令將會保留所有當前的環境變量,包括路徑,不象c r o n t a b,只提供缺省的環境。該作業的所有輸出都將以電子郵件的形式發送給用戶,除非你對其輸出進行了重定向,絕大多數情況下是重定向到某個文件中。
和c r o n t a b一樣,根用戶可以通過/ e t c目錄下的a t . a l l o w和a t . d e n y文件來控制哪些用戶可以使用a t命令,哪些用戶不行。不過一般來說,對a t命令的使用不如對c r o n t a b的使用限制那么嚴格。


a t命令的基本形式為:
代碼:

at [-f script] [-m -l -r] [time] [date]


其中,
-f:script 是所要提交的腳本或命令。

-l:列出當前所有等待運行的作業。a t q命令具有相同的作用。
-r:清除作業。為了清除某個作業,還要提供相應的作業標識( I D);有些U N I X變體只接受a t r m作為清除命令。
-m:作業完成后給用戶發郵件。

time:at命令的時間格式非常靈活;可以是H、H H . H H M M、H H : M M或H : M,其中H和M分別是小時和分鐘。還可以使用a . m .或p . m .。
date:日期格式可以是月份數或日期數,而且a t命令還能夠識別諸如t o d a y、t o m o r r o w這樣的詞。

使用at命令提交命令或腳本

使用a t命令提交作業有幾種不同的形式,可以通過命令行方式,也可以使用a t命令提示符。一般來說在提交若干行的系統命令時,使用a t命令提示符方式,在提交s h e l l腳本時,使用命令行方式。

提示符方式:
代碼:

以在a t命令后面跟上日期/時間并回車。然后就進入了a t命令提示符,這時只需逐條輸入相應的命令,然后按‘ < C T R L - D >’退出。


命令行方式:
代碼:

at [-f script] [-m -l -r] [time] [date]



例一:提示符方式
代碼:

# su sam
$ at 10:40
warning: commands will be executed using (in order) a) $SHELL b) login shell c) /bin/sh
at> find /etc -name "passwd" -print
at> <EOT>
job 1 at 2004-11-02 10:40


其中, < E O T >就是< C T R L - D >。在10:40系統將執行一個簡單的f i n d命令。提交的作業被分配了一個唯一標識job 1。該命令在完成以后會將全部結果以郵件的形式發送給我。

下面這些日期/時間格式都是a t命令可以接受的:
代碼:

at 5.00am May23
at 11.20pm
at now +2 hour
at 9am tomorrow
at 15:00 May24
at now + 10 minutes


例二:命令行方式
如果希望向a t命令提交一個s h e l l腳本,使用其命令行方式即可。在提交腳本時使用- f選項。
如:
代碼:

$ touch db_table.sh
$ at 3:00pm tomorrow -f db_table.sh
warning: commands will be executed using (in order) a) $SHELL b) login shell c) /bin/sh
job 3 at 2004-11-02 15:00


在上面的例子中,一個叫做d b _ t a b l e . s h的腳本將在2004-11-02 15:00運行。

還可以使用e c h o命令向a t命令提交作業:
代碼:

$ echo find /etc -name "passwd" -print | at now +1 minute
warning: commands will be executed using (in order) a) $SHELL b) login shell c) /bin/sh
job 4 at 2004-11-01 19:07



列出所提交的作業
一個作業被提交后,可以使用at -l命令來列出所有的作業:
代碼:

$ at -l
1? ? ? ?2004-11-02 10:40 a sam
3? ? ? ?2004-11-02 15:00 a sam
4? ? ? ?2004-11-01 19:07 a sam


其中,第一行是作業標識,后面是作業運行的日期/時間。最后一列a代表a t。
還可以使用a t q命令來完成同樣的功能,它是a t命令的一個鏈接。
直接>atq,相當于>at -l

當提交一個作業后,它就被拷貝到/ v a r / s p o o l / a t目錄中,準備在要求的時間運行。
代碼:

# pwd
/var/spool/at
# ls -l


清除一個作業

清除作業的命令格式為:
代碼:

atrm [job no] 或at -r [job no]

要清除某個作業,首先要執行at -l命令,以獲取相應的作業標識,然后對該作業標識使用at -r 命令,清除該作業。
代碼:

$ at -l
1? ? ? ?2004-11-02 10:40 a sam
3? ? ? ?2004-11-02 15:00 a sam
4? ? ? ?2004-11-01 19:07 a sam
$at -r 3
$at -l
1? ? ? ?2004-11-02 10:40 a sam
4? ? ? ?2004-11-01 19:07 a sam



有些系統使用at-r [job no]命令清除作業。



3.&

當在前臺運行某個作業時,終端被該作業占據;而在后臺運行作業時,它不會占據終端。可以使用&命令把作業放到后臺執行。

該命令的一般形式為:
代碼:
命令&



在后臺運行作業時要當心:需要用戶交互的命令不要放在后臺執行,因為這樣你的機器就會在那里傻等。
不過,作業在后臺運行一樣會將結果輸出到屏幕上,干擾你的工作。如果放在后臺運行的作業會產生大量的輸出,最好使用下面的方法把它的輸出重定向到某個文件中:
代碼:

command >out.file 2>&1 &


在上面的例子中,2>&1表示所有的標準輸出和錯誤輸出都將被重定向到一個叫做out.file 的文件中。
當你成功地提交進程以后,就會顯示出一個進程號,可以用它來監控該進程,或殺死它。

例一:

查找名為“httpd.conf”的文件,并把所有標準輸出和錯誤輸出重定向到f i n d . d t的文件中:
代碼:

# find /etc/httpd/ -name "httpd.conf" -print >find.dt 2>&1 &
[2] 7832
[1]? ?Done? ? ? ? ? ? ? ? ? ? find /etc/ -name "httpd.conf" -print >find.dt 2>&1 &

成功提交該命令之后,系統給出了它的進程號7832。
代碼:

# cat find.dt
/etc/httpd/conf/httpd.conf
[2]+? Done? ? ? ? ? ? ? ? ? ? find /etc/httpd/ -name "httpd.conf" -print >find.dt 2>&1 &

查看find.dt,可以看到執行結果


例二:
在后臺執行腳本,如:有一個叫psl的腳本
代碼:

$ps psl &
[7878]

用ps命令查看進程
用提交命令時所得到的進程號來監控它的運行。用p s命令和g r e p命令列出這個進程:
代碼:

# ps -x |grep 7832
7868 pts/0? ? S? ? ? 0:00 grep 7832


如果系統不支持ps x命令,可以用:
代碼:

# ps -ef |grep 7832
root? ? ? 7866? 7790? 0 23:40 pts/0? ? 00:00:00 grep 7832

在用p s命令列出進程時,它無法確定該進程是運行在前臺還是后臺。


殺死后臺進程

殺死后臺進程可以使用k i l l命令。當一個進程被放到后臺運行時, s h e l l會給出一個進程號,我們可以根據這個進程號,用k i l l命令殺死該進程。該命令的基本形式為:
代碼:

kill -signal [process_number]


現在暫且不要考慮其中的各種不同信號。
在殺進程的時候,執行下面的命令(你的進程號可能會不同)并按回車鍵。系統將會給出相應的信息告訴用戶進程已經被殺死。
代碼:

$kill 7832


如果系統沒有給出任何信息,告訴你進程已經被殺死,那么不妨等一會兒,也許系統正在殺該進程,如果還沒有回應,就再執行另外一個k i l l命令,這次帶上一個信號選項:
代碼:

$kill - 9 7868

如果用上述方法提交了一個后臺進程,那么在退出時該進程將會被終止。為了使后臺進程能夠在退出后繼續運行,可以使用n o h u p命令。

4.nohug

如果你正在運行一個進程,而且你覺得在退出帳戶時該進程還不會結束,那么可以使用n o h u p命令。該命令可以在你退出帳戶之后繼續運行相應的進程。n o h u p就是不掛起的意思( no hang up)。
該命令的一般形式為:
代碼:

nohup command &


使用nohup命令提交作業
如果使用n o h u p命令提交作業,那么在缺省情況下該作業的所有輸出都被重定向到一個名為n o h u p . o u t的文件中,除非另外指定了輸出文件:
代碼:

nohup command > myout.file 2>&1

在上面的例子中,輸出被重定向到m y o u t . f i l e文件中。

讓我們來看一個例子,驗證一下在退出帳戶后相應的作業是否能夠繼續運行。我們先提交一個名為p s 1的日志清除進程:
代碼:

$nobup ps1 &

現在退出該s h e l l,再重新登錄,然后執行下面的命令:
代碼:

$ps x |grep ps1


我們看到,該腳本還在運行。如果系統不支持ps x命令,使用ps -ef|grep ps1命令。

5.一次提交幾個作業

如果希望一次提交幾個命令,最好能夠把它們寫入到一個s h e l l腳本文件中,并用n o h u p命令來執行它。
例如,下面的所有命令都用管道符號連接在一起;我們可以把這些命令存入一個文件,并使該文件可執行。
代碼:

cat /home/accounts/qrt_0499 | /apps/bin/trials.awk | sort | lp
$cat > quarterend
cat /home/accounts/qtr_0499 | /apps/bin/trials.awk | sort | lp
<ctrl-D>


現在讓它可執行:
代碼:

$ chmod 744 quarterend


我們還將該腳本的所有輸出都重定向到一個名為q t r. o u t的文件中。
代碼:

nobup ./quarterend > qtr.out 2>


后臺運行作業的:
有時我們必須要對大文件進行大量更改,或執行一些復雜的查找,這些工作最好能夠在系統負荷較低時執行。
創建一個定時清理日志文件或完成其他特殊工作的腳本,這樣只要提交一次,就可以每天晚上運行,而且無需你干預,只要看看相應的腳本日志就可以了。c r o n和其他工具可以使系統管理任務變得更輕松。



6.*,?,[...],[!...]等


? 匹配文件名中的任何字符串。
? 匹配文件名中的單個字符。
? 匹配文件名中的字母或數字字符。


下面就是這些特殊字符:

* 匹配文件名中的任何字符串,包括空字符串。
? 匹配文件名中的任何單個字符。
[...] 匹配[ ]中所包含的任何字符。
[!...] 匹配[ ]中非感嘆號!之后的字符。


當s h e l l遇到上述字符時,就會把它們當作特殊字符,而不是文件名中的普通字符,這樣用戶就可以用它們來匹配相應的文件名。

a、*:使用星號*可以匹配文件名中的任何字符串。就不用多說了,和win下差不多
b、?:使用可以匹配文件名中的任何單個字符。和win差不多
c、[]:使用[ . . . ]可以用來匹配方括號[ ]中的任何字符。可以使用一個橫杠-來連接兩個字母或數字,以此來表示一個范圍。

1)列出以i或o開頭的文件名:
代碼:

#ls [io]*


2)列出log.開頭、后面跟隨一個數字、然后可以是任意字符串的文件名:
代碼:

#ls log.[0-9]*


3)與例二相反,列出log.開頭、后面不跟隨一個數字、然后可以是任意字符串的文件名
代碼:

#ls log.[!0-9]*


4)列出所有以LPS開頭、中間可以是任何兩個字符,最后以1結尾的文件名:
代碼:

#ls LPS??1


5)列出所有以大寫字母開頭的文件名:
代碼:

$ ls [A-Z]*


6)列出所有以小寫字母開頭的文件名:
代碼:

$ ls [a-z]*


7)為了列出所有以數字開頭的文件名:
代碼:

$ ls [0-9]*


8)列出所有以. 開頭的文件名(隱含文件,例如. p r o f i l e、. r h o s t s、. h i s t o r y等):
代碼:

$ ls .*


Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1456841

posted on 2007-08-09 00:55 旅途 閱讀(326) 評論(0)  編輯 收藏 引用 所屬分類: Linux Shell

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            黄色小说综合网站| 免费欧美电影| 久久精品99久久香蕉国产色戒 | 夜夜嗨av一区二区三区网页| 久久精品理论片| 久久精品国产99精品国产亚洲性色 | 午夜精品久久久久久久久久久久久| 夜夜嗨av一区二区三区四区 | 久久婷婷国产综合国色天香| 久久综合图片| 激情av一区| 麻豆精品在线视频| 亚洲成色www久久网站| 国产欧美丝祙| 欧美一级在线视频| 久久网站免费| 亚洲国产精品高清久久久| 久热成人在线视频| 亚洲国产日韩欧美在线99| 亚洲免费高清视频| 欧美日韩精品欧美日韩精品一 | 老妇喷水一区二区三区| 在线观看欧美亚洲| 免费不卡中文字幕视频| 亚洲国产精品视频| 亚洲图片在线| 国产欧美视频在线观看| 久久精品视频免费播放| 亚洲二区视频| 亚洲视频视频在线| 国产精品视频一区二区高潮| 欧美一区二区三区免费视频| 麻豆精品视频在线观看| 亚洲精品免费一区二区三区| 欧美色精品在线视频| 西西人体一区二区| 欧美 日韩 国产 一区| 日韩视频欧美视频| 国产美女精品免费电影| 久久久久久久久久久成人| 亚洲国产欧美一区二区三区同亚洲 | 在线播放不卡| 欧美极品在线播放| 亚洲天堂男人| 免费在线亚洲欧美| 一区二区三区四区五区在线| 国产欧美一区二区白浆黑人| 另类激情亚洲| 亚洲影院在线| 欧美国产免费| 亚洲欧美三级伦理| 亚洲国产日韩一区| 国产精品一区二区三区成人| 麻豆精品一区二区av白丝在线| 99综合在线| 欧美ed2k| 久久国产精品黑丝| 99热这里只有精品8| 欧美精品亚洲一区二区在线播放| 久久久国产精品亚洲一区| 亚洲第一中文字幕| 国产精品国产三级国产专播精品人| 久久精品日韩一区二区三区| 99视频精品全部免费在线| 久久久精品性| 亚洲一区亚洲二区| 91久久午夜| 国产亚洲一区精品| 欧美午夜精品久久久久免费视| 久久久最新网址| 亚洲一区二区三区四区在线观看| 亚洲成色777777女色窝| 久久一区二区视频| 午夜欧美精品| 一二美女精品欧洲| 亚洲国产精品久久91精品| 国产一区二区三区高清 | 亚洲欧美日韩在线播放| 亚洲三级网站| 欧美激情视频网站| 老司机午夜免费精品视频| 欧美在线精品一区| 亚洲一区二区三区视频| 亚洲另类春色国产| 亚洲国产你懂的| 狠狠色丁香久久婷婷综合丁香 | 国产自产高清不卡| 国产精品一区二区三区久久| 欧美视频精品在线| 欧美日本在线看| 欧美成人黄色小视频| 久久综合色综合88| 久久全国免费视频| 久久人人爽人人爽爽久久| 欧美一级视频精品观看| 亚洲免费伊人电影在线观看av| 99热免费精品在线观看| 日韩午夜免费| 宅男噜噜噜66一区二区 | 久久av红桃一区二区小说| 午夜精品久久久久久久99热浪潮| 亚洲曰本av电影| 亚洲欧美资源在线| 欧美亚洲日本网站| 欧美在线黄色| 久久久精品动漫| 久久久久久电影| 另类av一区二区| 欧美国产三区| 91久久精品一区二区别| 欧美激情一区二区三区高清视频 | 亚洲二区视频| 亚洲精品一区二区网址| 一本色道久久加勒比88综合| 在线一区二区三区四区五区| 亚洲香蕉伊综合在人在线视看| 亚洲女性喷水在线观看一区| 先锋影音国产精品| 久久免费精品日本久久中文字幕| 久久人人97超碰人人澡爱香蕉| 美女国产精品| 欧美日韩高清在线播放| 欧美午夜剧场| 国产偷国产偷精品高清尤物| 狠狠色丁香久久综合频道| 亚洲欧洲一区二区在线播放 | 国产亚洲一区在线播放| 悠悠资源网亚洲青| 亚洲精品欧美激情| 国内精品免费在线观看| 亚洲电影免费观看高清完整版在线观看| 在线国产欧美| 制服诱惑一区二区| 久久国产手机看片| 欧美国产国产综合| 中文精品一区二区三区| 欧美在线91| 欧美乱大交xxxxx| 国产精品手机视频| 亚洲第一中文字幕| 亚洲男同1069视频| 女女同性精品视频| av成人免费观看| 久久福利资源站| 欧美激情免费观看| 国产乱理伦片在线观看夜一区| 影音先锋亚洲电影| 亚洲一区二区三区在线视频| 久久久久久久999| 亚洲理论在线观看| 久久精品30| 欧美视频在线观看 亚洲欧| 韩国v欧美v日本v亚洲v| 中文无字幕一区二区三区| 久久人91精品久久久久久不卡| 亚洲精品久久久一区二区三区| 香蕉久久夜色精品国产使用方法| 欧美成人综合网站| 国内精品伊人久久久久av一坑| 一本色道久久综合亚洲二区三区| 久久精品99国产精品| av成人免费| 欧美1区3d| 国产日韩一级二级三级| 一区二区三区成人| 欧美国产大片| 久久激情五月丁香伊人| 国产精品久久久久9999高清| 最新日韩中文字幕| 久久深夜福利| 亚洲砖区区免费| 欧美日韩一区二区在线播放| 亚洲激情社区| 蜜桃精品一区二区三区| 午夜国产精品影院在线观看| 欧美日韩精品在线观看| 亚洲欧洲精品成人久久奇米网| 久久青草福利网站| 欧美一区二区精品| 国产精品女人网站| 亚洲一区二区三| 亚洲免费av网站| 欧美精品免费看| 亚洲日本视频| 欧美激情综合色| 久久香蕉国产线看观看av| 国外精品视频| 久久久精品tv| 欧美一区二区视频在线| 国产日韩欧美精品| 欧美一区二区视频在线观看| 亚洲午夜精品一区二区| 国产精品扒开腿做爽爽爽视频| 亚洲美女在线看| 亚洲精品影视| 欧美视频不卡| 亚洲欧美日韩电影| 亚洲一区二区三区中文字幕 | 性欧美大战久久久久久久久| 国产农村妇女精品|