日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > linux >内容正文

linux

Linux守护进程设计规范及python实现

發(fā)布時間:2024/1/8 linux 48 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Linux守护进程设计规范及python实现 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

http://blog.csdn.net/mr_jj_lian/article/details/7252222

守護(hù)進(jìn)程

守護(hù)進(jìn)程是生存期長的一種進(jìn)程。它們獨立于控制終端并且周期性的執(zhí)行某種任務(wù)或等待處理某些發(fā)生的事件。他們常常在系統(tǒng)引導(dǎo)裝入時啟動,在系統(tǒng)關(guān)閉時終止。unix系統(tǒng)有很多守護(hù)進(jìn)程,大多數(shù)服務(wù)器都是用守護(hù)進(jìn)程實現(xiàn)的。比如,網(wǎng)絡(luò)服務(wù)inetd、Web服務(wù)http等。同時,守護(hù)進(jìn)程完成許多系統(tǒng)任務(wù)。比如,作業(yè)規(guī)劃進(jìn)程crond、打印進(jìn)程lqd等。

這里主要說明守護(hù)進(jìn)程的進(jìn)程結(jié)構(gòu),以及如何編寫守護(hù)進(jìn)程程序。因為守護(hù)進(jìn)程沒有控制終端,所以我們還要介紹在守護(hù)進(jìn)程運行時錯誤輸出的方法。

守護(hù)進(jìn)程及其特性

守護(hù)進(jìn)程最重要的特性是后臺運行。在這一點上,DOS下的常駐內(nèi)存程序TSR與之相似。

其次,守護(hù)進(jìn)程必須與其運行前的環(huán)境隔離開來。這些環(huán)境包括未關(guān)閉的文件描述符、控制終端、會話和進(jìn)程組、工作目錄以及文件創(chuàng)建掩碼等。這些環(huán)境通常是守護(hù)進(jìn)程從執(zhí)行它的父進(jìn)程(特別是shell)中繼承下來的。

最后,守護(hù)進(jìn)程的啟動方式有其特殊之處。它可以在系統(tǒng)啟動時從啟動腳本/etc/rc.d中啟動,可以由inetd守護(hù)進(jìn)程啟動,可以有作業(yè)規(guī)劃進(jìn)程crond啟動,還可以由用戶終端(通常是shell)執(zhí)行。

總之,除開這些特殊性以外,守護(hù)進(jìn)程與普通進(jìn)程基本上沒有什么區(qū)別。因此,編寫守護(hù)進(jìn)程實際上是把一個普通進(jìn)程按照上述的守護(hù)進(jìn)程的特性改造成為守護(hù)進(jìn)程。如果大家對進(jìn)程的認(rèn)識比較深入,就對守護(hù)進(jìn)程容易理解和編程了。

首先我們來察看一些常用的系統(tǒng)守護(hù)進(jìn)程,看一下他們和幾個概念:進(jìn)程組、控制終端和對話期有什么聯(lián)系。p s命令打印系統(tǒng)中各個進(jìn)程的狀態(tài)。該命令有多個選擇項,有關(guān)細(xì)節(jié)請參考系統(tǒng)手冊。為了察看所需的信息,執(zhí)行:
ps –axj

PPID PID PGID SID TTY TPGID STAT UID TIME COMMAND
0 1 0 0 ? -1 S 0 0:04 init
1 2 1 1 ? -1 SW 0 0:00 [keventd]
1 3 1 1 ? -1 SW 0 0:00 [kapm-idled]
0 4 1 1 ? -1 SWN 0 0:00 [ksoftirqd_CPU0]
0 5 1 1 ? -1 SW 0 0:00 [kswapd]
0 6 1 1 ? -1 SW 0 0:00 [kreclaimd]
0 7 1 1 ? -1 SW 0 0:00 [bdflush]
0 8 1 1 ? -1 SW 0 0:00 [kupdated]
1 9 1 1 ? -1 SW< 0 0:00 [mdrecoveryd]
1 17 1 1 ? -1 SW 0 0:02 [kjournald]
1 92 1 1 ? -1 SW 0 0:00 [khubd]
1 573 573 573 ? -1 S 0 0:03 syslogd -r -x
1 578 578 578 ? -1 S 0 0:00 klogd -2
1 598 598 598 ? -1 S 32 0:00 portmap

進(jìn)程號為1、2的這些進(jìn)程非常特殊,存在于系統(tǒng)的整個生命期中。它們沒有父進(jìn)程ID ,沒有組進(jìn)程ID ,也沒有對話期ID 。syslogd 守護(hù)進(jìn)程可用于任何為操作人員記錄系統(tǒng)消息的程序中。可以在一臺實際的控制臺上打印這些消息,也可將它們寫到一個文件中。sendmail 是標(biāo)準(zhǔn)郵遞守護(hù)進(jìn)程。update 程序定期將內(nèi)核緩存中的內(nèi)容寫到硬盤上(通常是每隔30 秒)。為了做到這一點,該程序每隔30 秒調(diào)用sync(2 )函數(shù)一次。cron 守護(hù)進(jìn)程在指定的日期和時間執(zhí)行指定的命令。許多系統(tǒng)管理任務(wù)是由cron 定期地使相關(guān)程序執(zhí)行而得以實現(xiàn)的。inetd進(jìn)程監(jiān)聽系統(tǒng)的網(wǎng)絡(luò)界面,以輸入對各種網(wǎng)絡(luò)服務(wù)器的請求。最后一個守護(hù)進(jìn)程,lpd 處理對系統(tǒng)提出的各個打印請求。

注意,所有守護(hù)進(jìn)程都以超級用戶(用戶ID為0)的優(yōu)先權(quán)運行。沒有一個守護(hù)進(jìn)程具有控制終端,終端名稱設(shè)置為問號(?)、終端前臺進(jìn)程組ID設(shè)置為-1。缺少控制終端是守護(hù)進(jìn)程調(diào)用了setsid的結(jié)果。除update以外的所有守護(hù)進(jìn)程都是進(jìn)程組的首進(jìn)程,對話期的首進(jìn)程,而且是這些進(jìn)程組和對話期中的唯一進(jìn)程。最后,應(yīng)當(dāng)引起注意的是所有這些守護(hù)進(jìn)程的父進(jìn)程都是init進(jìn)程。

在接觸實際編程前,我們來看看編寫守護(hù)進(jìn)程要碰到的概念:進(jìn)程組合會話期。

進(jìn)程組

每個進(jìn)程除了有一進(jìn)程ID之外,還屬于一個進(jìn)程組(在討論信號時就會涉及進(jìn)程組)進(jìn)程組是一個或多個進(jìn)程的集合。每個進(jìn)程有一個唯一的進(jìn)程組ID。進(jìn)程組ID類似于進(jìn)程ID——它是一個正整數(shù),并可存放在pid_t數(shù)據(jù)類型中。

每個進(jìn)程組有一個組長進(jìn)程。組長進(jìn)程的標(biāo)識是,其進(jìn)程組ID等于其進(jìn)程ID,進(jìn)程組組長可以創(chuàng)建一個進(jìn)程組,創(chuàng)建該組中的進(jìn)程,然后終止,只要在某個進(jìn)程組中有一個進(jìn)程存在,則該進(jìn)程就存在,這與其組長進(jìn)程是否終止無關(guān)。從進(jìn)程組創(chuàng)建開始到其中最后一個進(jìn)程離開為止的時間區(qū)間稱為進(jìn)程組的生命期。某個進(jìn)程組中的最后一個進(jìn)程可以終止,也可以參加另一進(jìn)程組。

前面已經(jīng)提到進(jìn)程調(diào)用setgid可以參加一個現(xiàn)存的組或者創(chuàng)建一個新進(jìn)程組(setsid也可以創(chuàng)建一個新的進(jìn)程組,后面將用到)

會話期

會話期(session)是一個或多個進(jìn)程組的集合。其中,在一個會話期中有3個進(jìn)程組,通常是有shell的管道線將幾個進(jìn)程編成一組的。

下面說明有關(guān)會話期和進(jìn)程組的一些特性:

一個會話期可以有一個單獨的控制終端(controlling terminal),這一般是我們在其上登錄的終端設(shè)備(終端登錄)或偽終端設(shè)備(網(wǎng)絡(luò)登錄),但這個控制終端并不是必需的。

建立與控制終端連接的會話期首進(jìn)程,被稱之為控制進(jìn)程(contronlling process)。以及一個會話期中的幾個進(jìn)程組可被分為一個前臺進(jìn)程組(foreground process group)以及一個或幾個后臺進(jìn)程組(background process group)

如果一個會話期有一個控制終端,則它有一個前臺進(jìn)程組,其他進(jìn)程組為后臺進(jìn)程組。無論何時鍵入中斷鍵(常常是delete或ctrl-c)或退出鍵(通常是ctrl-/),就會造成將中斷信號或退出信號送至前途進(jìn)程組的所有進(jìn)程。

守護(hù)進(jìn)程的編程規(guī)則

在不同Unix環(huán)境下,守護(hù)進(jìn)程的具體編程細(xì)節(jié)并不一致。但所幸的是,守護(hù)進(jìn)程的編程原則其實都一樣,區(qū)別僅在于具體的實現(xiàn)細(xì)節(jié)不同,這個原則就是要滿足守護(hù)進(jìn)程的特性。編程規(guī)則如下:

1、在后臺運行

為避免掛起控制終端,要將daemon放入后臺執(zhí)行,其方法是,在進(jìn)程中調(diào)用fork使父進(jìn)程終止,讓daemon在子進(jìn)程中后臺執(zhí)行。具體就是調(diào)用f o r k ,然后使父進(jìn)程e x i t 。這樣做實現(xiàn)了下面幾點:
第一,如果該精靈進(jìn)程是由一條簡單s h e l l 命令起動的,那么使父進(jìn)程終止使得s h e l l 認(rèn)為這條命令已經(jīng)執(zhí)行完成。
第二,子進(jìn)程繼承了父進(jìn)程的進(jìn)程組I D ,但具有一個新的進(jìn)程I D ,這就保證了子進(jìn)程不是一個進(jìn)程組的首進(jìn)程。這對于下面就要做的s e t s i d 調(diào)用是必要的前提條件。

2、脫離控制終端,登錄會話和進(jìn)程組

登錄會話可以包含多個進(jìn)程組,這些進(jìn)程組共享一個控制終端,這個控制終端通常是創(chuàng)建進(jìn)程的登錄終端、控制終端,登錄會話和進(jìn)程組通常是從父進(jìn)程繼承下來的。我們的目的就是要擺脫它們,使之不受它們的影響。

其方法是在第一點的基礎(chǔ)上,調(diào)用setsid()使進(jìn)程成為會話組長:

需要說明的是,當(dāng)進(jìn)程是會話組長時,setsid()調(diào)用會失敗,但第一點已經(jīng)保證進(jìn)程不是會話組長。setsid()調(diào)用成功后,進(jìn)程成為新的會話組長和新的進(jìn)程組長,并與原來的登錄會話和進(jìn)程組脫離,由于會話過程對控制終端的獨占性,進(jìn)程同時與控制終端脫離。
具體是操作就是:
(a )成為新對話期的首進(jìn)程
(b )成為一個新進(jìn)程組的首進(jìn)程
(c )沒有控制終端。

3、禁止進(jìn)程重新打開控制終端

現(xiàn)在,進(jìn)程已經(jīng)成為無終端的會話組長,但它可以重新申請打開一個控制終端。
可以通過使進(jìn)程不再成為會話組長來禁止進(jìn)程重新打開控制終端:

4、關(guān)閉打開的文件描述符

進(jìn)程從創(chuàng)建它的父進(jìn)程那里繼承了打開的文件描述符。如不關(guān)閉,將會浪費系統(tǒng)資源,造成進(jìn)程所在地文件系統(tǒng)無法卸下以及無法預(yù)料的錯誤。一般來說,必要的是關(guān)閉0、1、2三個文件描述符,即標(biāo)準(zhǔn)輸入、標(biāo)準(zhǔn)輸出、標(biāo)準(zhǔn)錯誤。因為我們一般希望守護(hù)進(jìn)程自己有一套信息輸出、輸入的體系,而不是把所有的東西都發(fā)送到終端屏幕上。調(diào)用fclose();

5、改變當(dāng)前工作目錄

將當(dāng)前工作目錄更改為根目錄。從父進(jìn)程繼承過來的當(dāng)前工作目錄可能在一個裝配的文件系統(tǒng)中。因為精靈進(jìn)程通常在系統(tǒng)再引導(dǎo)之前是一直存在的,所以如果精靈進(jìn)程的當(dāng)前工作目錄在一個裝配文件系統(tǒng)中,那么該文件系統(tǒng)就不能被拆卸。

另外,某些精靈進(jìn)程可能會把當(dāng)前工作目錄更改到某個指定位置,在此位置做它們的工作。例如,行式打印機假脫機精靈進(jìn)程常常將其工作目錄更改到它們的s p o o l 目錄上。
可以調(diào)用chdir(“目錄”);

6、重設(shè)文件創(chuàng)建掩碼

將文件方式創(chuàng)建屏蔽字設(shè)置為0 。由繼承得來的文件方式創(chuàng)建屏蔽字可能會拒絕設(shè)置某些許可權(quán)。例如,若精靈進(jìn)程要創(chuàng)建一個組可讀、寫的文件,而繼承的文件方式創(chuàng)建屏蔽字,屏蔽了這兩種許可權(quán),則所要求的組可讀、寫就不能起作用。

7、處理SIGCHLD 信號

處理SIGCHLD信號并不是必需的。但對于某些進(jìn)程,特別是服務(wù)器進(jìn)程往往在請求到來時生產(chǎn)子進(jìn)程出來請求。如果父進(jìn)程不等待子進(jìn)程結(jié)束,子進(jìn)程將成為僵尸進(jìn)程,(zombie)而仍占用系統(tǒng)資源。如果父進(jìn)程等待子進(jìn)程結(jié)束,將增加父進(jìn)程的負(fù)擔(dān),影響服務(wù)器進(jìn)程的并發(fā)性能。在系統(tǒng)V下可以簡單的將SIGCHLD信號的操作設(shè)為SIG-IGN:

signal(SIGCHLD,SIG_IGN);

這樣,內(nèi)核在子進(jìn)程結(jié)束時不會產(chǎn)生僵尸進(jìn)程,這一點與BSD4不同,在BSD4下必須顯示等 待子進(jìn)程結(jié)束才能釋放僵尸進(jìn)程。

守護(hù)進(jìn)程實例

守護(hù)進(jìn)程實例包括兩部分:主程序test.c和初始化程序init.c。主程序每隔一分鐘向/tmp
目錄中的日志test.log 報告運行狀態(tài)。初始化程序中的init_daemon 函數(shù)負(fù)責(zé)生成守護(hù)進(jìn)程

void make_daemon(void)
{
pid_t pid;
FILE * lockfd;
sigset_t sighup;
int i;

extern pid_t getsid(pid_t);
pid = fork();//第一個子進(jìn)程生成
if (pid < 0) {
printinfo("fork error!",INFOERROR);
exit(FAILEXIT);
}else if (pid > 0) {
printinfo("fork 1 ok! ", INFOSCREEN);
exit(OKEXIT);//退出父進(jìn)程,擺脫shell的控制
}
pid = getpid();//獲得子進(jìn)程自身的id
lockfd = fopen(PIDFILE, "w");//以下是將pid寫入文件
if (lockfd != NULL) {
fprintf(lockfd, "%d/n", pid);
fclose(lockfd);
}//寫入pid
if (getsid(0) != pid) {//創(chuàng)建新的會話期
if (setsid() < 0) {
printinfo("backupdaemon setsid error!",INFOERROR);
perror("setsid");
}
}
if(pid=fork()){//再次生成子進(jìn)程,這時候是孫子進(jìn)程
exit(0);//退出上一代進(jìn)程
}else if(pid<0){
exit(1);
}
close(1);//關(guān)閉文件
close(2);
chdir(rundir);//改變運行的目錄
umask(022);//改變文件權(quán)限
}

守護(hù)進(jìn)程的錯誤輸出

守護(hù)進(jìn)程不屬于任何終端,所以當(dāng)需要輸出某些信息時,它無法像一般程序那樣將信息直接輸出到標(biāo)準(zhǔn)輸出和標(biāo)準(zhǔn)錯誤輸出中。我們很大時候也不希望每個守護(hù)進(jìn)程將它自己的出錯消息寫到一個單獨的文件中。因為對于系統(tǒng)管理人員而言,要記住哪一個守護(hù)進(jìn)程寫到哪一個記錄文件中,并定期的檢查這些文件,他一定會為此感到頭疼的。所以,我們需要有一個集中的守護(hù)進(jìn)程出錯記錄機制。目前很多系統(tǒng)都引入了syslog記錄進(jìn)程來實現(xiàn)這一目的。

自伯克利開發(fā)了BSD syslog并廣泛應(yīng)用以來,BSD syslog 機制被大多數(shù)守護(hù)進(jìn)程所使用。我們下面介紹BSD syslog 的用法。有三種方法產(chǎn)生記錄消息:

1 內(nèi)核例程可以調(diào)用log函數(shù)。任何一個用戶進(jìn)程通過打開和讀/dev/klog設(shè)備就可以讀取這些消息。因為我們無意編寫內(nèi)核中的例程,所以不再進(jìn)一步說明此函數(shù)。

2 大多數(shù)用戶進(jìn)程(守護(hù)進(jìn)程)調(diào)用syslog函數(shù)以產(chǎn)生記錄消息。我們將在下面說明其調(diào)用序列。這使消息發(fā)送至Unix域數(shù)據(jù)報套接口/dev/log。

3 在此主機上,或通過TCP/IP網(wǎng)絡(luò)連接到此主機的某一其他主機上的一個用戶進(jìn)程可將記錄消息發(fā)向UDP端口514。

注意:syslog 函數(shù)并不產(chǎn)生這些UDP數(shù)據(jù)報——它們要求產(chǎn)生此記錄消息的進(jìn)程具有顯式的網(wǎng)絡(luò)編程。

通常,syslog守護(hù)進(jìn)程讀取三種格式的記錄消息。此守護(hù)進(jìn)程在啟動時讀一個配置文件。一般來說,其文件名為/etc/syslog.conf,該文件決定了不同種類的消息應(yīng)送向何處。例如,緊急消息可被送向系統(tǒng)管理員(若已登錄),并在控制臺上顯示,而警告消息則可記錄到一個文件中。該機制提供了syslog函數(shù),其調(diào)用格式如下

#include?
void openlog (char*ident,int option ,int facility);
void syslog(int priority,char*format,……)
void closelog();

調(diào)用openlog是可選擇的。如果不調(diào)用openlog,則在第一次調(diào)用syslog時,自動調(diào)用openlog。調(diào)用closelog也是可選擇的,它只是關(guān)閉被用于與syslog守護(hù)進(jìn)程通信的描述符。調(diào)用openlog 使我們可以指定一個ident,以后, 此ident 將被加至每則記錄消息中。ident 一般是程序的名稱(例如 ,cron ,inetd 等)。option 有4種可能:

LOG_CONS 若日志消息不能通過Unix域數(shù)據(jù)報發(fā)送至syslog,則將該消息寫至控制臺。

LOG_NDELAY1 立即打開Unix域數(shù)據(jù)報套接口至syslog守護(hù)進(jìn)程,而不要等到記錄第一消息。通常,在記錄第一條消息之前,該套接口不打開。

LOG_PERROR 除將日志消息發(fā)送給syslog 外,還將它至標(biāo)準(zhǔn)出錯。此選項僅由4.3BSDReno及以后版本支持。

LOG_PID 每條消息都包含進(jìn)程ID。此選項可供對每個請求都fork一個子進(jìn)程的守護(hù)進(jìn)程使用。

在openlog中設(shè)置facility參數(shù)的目的是讓配置文件可以說明,來自不同設(shè)施的消息以不同的方式進(jìn)行處理。如果不調(diào)用openlog,或者以facility 為0來調(diào)用它,那么在調(diào)用syslog 時,可將facility作為priority參數(shù)的一個部分進(jìn)行說明。調(diào)用syslog產(chǎn)生一個記錄消息。其priority參數(shù)是facility和level的組合,它們可選取的值分別列于下面。level值按優(yōu)先級從高級到最低按序排列




python版本:

1. 調(diào)用fork()以便父進(jìn)程可以退出,這樣就將控制權(quán)歸還給運行你程序的命令行或shell程序。需要這一步以便保證新進(jìn)程不是一個進(jìn)程組頭領(lǐng)進(jìn)程(process group leader)。下一步,‘setsid()’,會因為你是進(jìn)程組頭領(lǐng)進(jìn)程而失敗。

2. 調(diào)用‘setsid()’ 以便成為一個進(jìn)程組和會話組的頭領(lǐng)進(jìn)程。由于一個控制終端與一個會話相關(guān)聯(lián),而且這個新會話還沒有獲得一個控制終端,我們的進(jìn)程沒有控制終端,這對于守護(hù)程序來說是一件好事。?

3. 再次調(diào)用‘fork()’所以父進(jìn)程(會話組頭領(lǐng)進(jìn)程)可以退出。這意味著我們,一個非會話組頭領(lǐng)進(jìn)程永遠(yuǎn)不能重新獲得控制終端

4. 調(diào)用‘chdir("/")’確認(rèn)我們的進(jìn)程不保持任何目錄于使用狀態(tài)。不做這個會導(dǎo)致系統(tǒng)管理員不能卸裝(umount)一個文件系統(tǒng),因為它是我們的當(dāng)前工作目錄。 [類似的,我們可以改變當(dāng)前目錄至對于守護(hù)程序運行重要的文件所在目錄]?

5. 調(diào)用‘umask(0)’以便我們擁有對于我們寫的任何東西的完全控制。我們不知道我們繼承了什么樣的umask。 [這一步是可選的](譯者注:這里指步驟5,因為守護(hù)程序不一定需要寫文件)

6. 調(diào)用‘close()’關(guān)閉文件描述符0,1和2。這樣我們釋放了從父進(jìn)程繼承的標(biāo)準(zhǔn)輸入,標(biāo)準(zhǔn)輸出,和標(biāo)準(zhǔn)錯誤輸出。我們沒辦法知道這些文描述符符可能已經(jīng)被重定向去哪里。注意到許多守護(hù)程序使用‘sysconf()’來確認(rèn)‘_SC_OPEN_MAX’的限制。‘_SC_OPEN_MAX’告訴你每個進(jìn)程能夠打開的最多文件數(shù)。然后使用一個循環(huán),守護(hù)程序可以關(guān)閉所有可能的文件描述符。你必須決定你需要做這個或不做。如果你認(rèn)為有可能有打開的文件描述符,你需要關(guān)閉它們,因為系統(tǒng)有一個同時打開文件數(shù)的限制。?

7. 為標(biāo)準(zhǔn)輸入,標(biāo)準(zhǔn)輸出和標(biāo)準(zhǔn)錯誤輸出建立新的文件描述符。即使你不打算使用它們,打開著它們不失為一個好主意。準(zhǔn)確操作這些描述符是基于各自愛好;比如說,如果你有一個日志文件,你可能希望把它作為標(biāo)準(zhǔn)輸出和標(biāo)準(zhǔn)錯誤輸出打開,而把‘/dev/null’作為標(biāo)準(zhǔn)輸入打開;作為替代方法,你可以將‘/dev/console’作為標(biāo)準(zhǔn)錯誤輸出和/或標(biāo)準(zhǔn)輸出打開,而‘/dev/null’作為標(biāo)準(zhǔn)輸入,或者任何其它對你的守護(hù)程序有意義的結(jié)合方法。(譯者注:一般使用dup2函數(shù)原子化關(guān)閉和復(fù)制文件描述符。


def createDaemon():?? ?
??????? import os
?? ??? ?
?? ???? # create - fork 1
??????? try:
??????????????? if os.fork() > 0:?
??????????????????????? os._exit(0)
??????? except OSError, error:
??????????????? print 'fork #1 failed: %d (%s)' % (error.errno, error.strerror)
?? ???????? os._exit(1)
?? ??
?? ???? # it separates the son from the father
??????? os.chdir('/')
??????? os.setsid()
??????? os.umask(0)
?? ??
?? ???? # create - fork 2
??????? try:
??????????????? pid = os.fork()
?? ???????? if pid > 0:
?? ???????????? print 'Daemon PID %d' % pid
?? ???????????? os._exit(0)
??????? except OSError, error:
?? ???????? print 'fork #2 failed: %d (%s)' % (error.errno, error.strerror)
?? ???????? os._exit(1)
?? ??
??????? funzioneDemo() # function demo
?? ??? ?
def funzioneDemo():
?? ??
??????? import time
?? ??
??????? fd = open('/tmp/demone.log', 'w')
??????? while True:
??????????????? fd.write(time.ctime()+'\n')
?? ???????? fd.flush()
?? ???????? time.sleep(2)
??????? fd.close()
?? ??? ?
if __name__ == '__main__':
?? ??
??????? createDaemon()





轉(zhuǎn)自http://blog.csdn.net/dysj4099/article/details/18219411

由于需要為OpenStack中的虛擬機設(shè)計監(jiān)控Agent,因此需要一個穩(wěn)妥、可靠并簡單的守護(hù)進(jìn)程實現(xiàn)作為基礎(chǔ)框架,故研究了一下Linux系統(tǒng)中的守護(hù)進(jìn)程。

首先,守護(hù)進(jìn)程是一類在后臺執(zhí)行,生命周期較長的進(jìn)程,它一般隨系統(tǒng)啟動運行,在系統(tǒng)關(guān)閉的時候停止。翻譯了一下《Advanced Programming in The Unix Environment? Section》的第13.3小節(jié),此小節(jié)是一個關(guān)于守護(hù)進(jìn)程的設(shè)計規(guī)范,羅列了守護(hù)進(jìn)程設(shè)計實現(xiàn)的幾大原則:

?

翻譯《AdvancedProgrammingin The Unix Environment》Section 13.3 Page 583

?

守護(hù)進(jìn)程編碼規(guī)范:

????????本小節(jié)將介紹一些守護(hù)進(jìn)程的基本編碼規(guī)范,這些規(guī)范將阻止守護(hù)進(jìn)程與當(dāng)前環(huán)境產(chǎn)生一些不必要的交互。本節(jié)將通過一個函數(shù)daemonize實現(xiàn)這些規(guī)范。

?

1.???? 首先要做的被稱為?umask這一步驟會將文件創(chuàng)建掩碼重置為0。這一步的原因是守護(hù)進(jìn)程繼承(inherited)得到的文件掩碼有可能會拒絕某些特定的文件操作權(quán)限。如果守護(hù)進(jìn)程想要創(chuàng)建文件,那有可能它需要設(shè)置特定的文件操作權(quán)限。例如,如果守護(hù)進(jìn)程想要創(chuàng)建允許組讀和寫(group-readand group-write)權(quán)限的文件,但繼承得到的文件創(chuàng)建掩碼屏蔽了這個權(quán)限,則創(chuàng)建操作不會成功。

2.????調(diào)用?fork?并使父進(jìn)程退出(exit)。這一步驟的目的在于。首先,如果守護(hù)進(jìn)程是通過一個簡單的shell命令建立的,那么在父進(jìn)程終止的時候shell會認(rèn)為命令已經(jīng)結(jié)束了繼而結(jié)束守護(hù)進(jìn)程。其次,子進(jìn)程繼承得到父進(jìn)程的groupID同時也獲得了一個新的進(jìn)程號,所以我們必須得保證子進(jìn)程不能擔(dān)任groupleader的角色,這是下一步setsid?操作的前提。

注:此步是使得進(jìn)程在后臺運行。

3.????調(diào)用?setsid?創(chuàng)建一個新的會話。有三個步驟將會執(zhí)行:(a)進(jìn)程將成為這個新會話的sessionleader角色,(b)此進(jìn)程將會成為一個新的進(jìn)程組的groupleader,(c)此進(jìn)程將不會有控制終端。

注:此步將使得進(jìn)程脫離控制端、登以及進(jìn)

·?????在基于SystemV的系統(tǒng)中,有建議再一次調(diào)用fork?并使父進(jìn)程退出。而新產(chǎn)生的進(jìn)程將會成為真正的守護(hù)進(jìn)程。這一步驟將保證守護(hù)進(jìn)程不是一個sessionleader,進(jìn)而阻止它獲取一個控制終端。或者另一種阻止守護(hù)進(jìn)程獲取控制終端的方案是任意時刻打開一個終端設(shè)備的時候確保指定O_NOCTTY

注:此步將禁止進(jìn)程重新打開控制端。

4.????將當(dāng)前的工作目錄切換到系統(tǒng)根目錄下。因為從父進(jìn)程集成來的當(dāng)前工作目錄可能是一個被掛載的文件系統(tǒng)。因為守護(hù)進(jìn)程通常是直到系統(tǒng)重啟的時候才會退出,如果守護(hù)進(jìn)程的工作目錄在一個掛載的文件系統(tǒng)上,那么這個文件系統(tǒng)就不能被卸載(unmounted)。

·????? 有的守護(hù)進(jìn)程可能會將當(dāng)前的工作目錄切換到一些特定的路徑,在這些路徑下它們將完成它們的工作。例如,lineprinter spoolingdaemons 通常將工作目錄切換為spool目錄。

5.????一些不必要的文件描述符將會被關(guān)閉。這個步驟將阻止守護(hù)進(jìn)程保持從父進(jìn)程集成到的任何已經(jīng)打開的文件描述符(也可能是shell或其他進(jìn)程)。我們可以使用?open_max?函數(shù)或?getrlimit?函數(shù)來查找當(dāng)前優(yōu)先級最高的文件描述符并關(guān)閉此描述符之下的所有其他描述符。

注:保持打開的描述符將會占用系統(tǒng)資源并可能使某些文件不能被卸

6.????有一些守護(hù)進(jìn)程將打開文件描述符0, 1, 2 指向?/dev/null?,這樣一來所有試圖從標(biāo)準(zhǔn)輸入、輸出及錯誤讀取守護(hù)進(jìn)程信息的操作都不能成功。因為守護(hù)進(jìn)程當(dāng)前已經(jīng)不與任何終端設(shè)備相關(guān)聯(lián),沒有地方顯示其輸出或接受用戶的輸入。即使守護(hù)進(jìn)程是從一個交互式session創(chuàng)建的,守護(hù)進(jìn)程也將運行在后臺,任何終端的登錄與終止將不會影響守護(hù)進(jìn)程。如果有其他用戶通過當(dāng)前的終端登錄,我們也不希望守護(hù)進(jìn)程的輸出出現(xiàn)在終端上,并且該用戶的任何輸入也不會被守護(hù)進(jìn)程接收。

?

總結(jié)起來就是:

1) 第一次fork將會創(chuàng)建父-子進(jìn)程,同時使得父進(jìn)程退出保證守護(hù)進(jìn)程能夠運行在后臺。

2) 通過setsid步驟使得進(jìn)程與控制終端、登錄會話以及進(jìn)程組脫離。

3) 第二次fork將確保進(jìn)程重新打開控制終端,并且產(chǎn)生子-孫進(jìn)程,而子進(jìn)程退出后孫進(jìn)程將成為真正的守護(hù)進(jìn)程。

4) 其他還有一些諸如工作目錄設(shè)置、關(guān)閉文件描述符、設(shè)置文件創(chuàng)建掩碼之類的操作。

?

最后看一個python實現(xiàn)的例子,代碼來自:http://www.jejik.com/articles/2007/02/a_simple_unix_linux_daemon_in_python/

[python]? view plain copy
  • #!/usr/bin/env?python??
  • ??
  • import?sys,?os,?time,?atexit??
  • from?signal?import?SIGTERM???
  • ??
  • class?Daemon:??
  • ????"""?
  • ????A?generic?daemon?class.?
  • ?????
  • ????Usage:?subclass?the?Daemon?class?and?override?the?run()?method?
  • ????"""??
  • ????def?__init__(self,?pidfile,?stdin='/dev/null',?stdout='/dev/null',?stderr='/dev/null'):??
  • ????????self.stdin?=?stdin??
  • ????????self.stdout?=?stdout??
  • ????????self.stderr?=?stderr??
  • ????????self.pidfile?=?pidfile??
  • ??????
  • ????def?daemonize(self):??
  • ????????"""?
  • ????????do?the?UNIX?double-fork?magic,?see?Stevens'?"Advanced??
  • ????????Programming?in?the?UNIX?Environment"?for?details?(ISBN?0201563177)?
  • ????????http://www.erlenstar.demon.co.uk/unix/faq_2.html#SEC16?
  • ????????"""??
  • ????????try:???
  • ????????????pid?=?os.fork()???
  • ????????????if?pid?>?0:??
  • ????????????????#?exit?first?parent??
  • ????????????????sys.exit(0)???
  • ????????except?OSError,?e:???
  • ????????????sys.stderr.write("fork?#1?failed:?%d?(%s)\n"?%?(e.errno,?e.strerror))??
  • ????????????sys.exit(1)??
  • ??????
  • ????????#?decouple?from?parent?environment??
  • ????????os.chdir("/")???
  • ????????os.setsid()???
  • ????????os.umask(0)???
  • ??????
  • ????????#?do?second?fork??
  • ????????try:???
  • ????????????pid?=?os.fork()???
  • ????????????if?pid?>?0:??
  • ????????????????#?exit?from?second?parent??
  • ????????????????sys.exit(0)???
  • ????????except?OSError,?e:???
  • ????????????sys.stderr.write("fork?#2?failed:?%d?(%s)\n"?%?(e.errno,?e.strerror))??
  • ????????????sys.exit(1)???
  • ??????
  • ????????#?redirect?standard?file?descriptors??
  • ????????sys.stdout.flush()??
  • ????????sys.stderr.flush()??
  • ????????si?=?file(self.stdin,?'r')??
  • ????????so?=?file(self.stdout,?'a+')??
  • ????????se?=?file(self.stderr,?'a+',?0)??
  • ????????os.dup2(si.fileno(),?sys.stdin.fileno())??
  • ????????os.dup2(so.fileno(),?sys.stdout.fileno())??
  • ????????os.dup2(se.fileno(),?sys.stderr.fileno())??
  • ??????
  • ????????#?write?pidfile??
  • ????????atexit.register(self.delpid)??
  • ????????pid?=?str(os.getpid())??
  • ????????file(self.pidfile,'w+').write("%s\n"?%?pid)??
  • ??????
  • ????def?delpid(self):??
  • ????????os.remove(self.pidfile)??
  • ??
  • ????def?start(self):??
  • ????????"""?
  • ????????Start?the?daemon?
  • ????????"""??
  • ????????#?Check?for?a?pidfile?to?see?if?the?daemon?already?runs??
  • ????????try:??
  • ????????????pf?=?file(self.pidfile,'r')??
  • ????????????pid?=?int(pf.read().strip())??
  • ????????????pf.close()??
  • ????????except?IOError:??
  • ????????????pid?=?None??
  • ??????
  • ????????if?pid:??
  • ????????????message?=?"pidfile?%s?already?exist.?Daemon?already?running?\n"??
  • ????????????sys.stderr.write(message?%?self.pidfile)??
  • ????????????sys.exit(1)??
  • ??????????
  • ????????#?Start?the?daemon??
  • ????????self.daemonize()??
  • ????????self.run()??
  • ??
  • ????def?stop(self):??
  • ????????"""?
  • ????????Stop?the?daemon?
  • ????????"""??
  • ????????#?Get?the?pid?from?the?pidfile??
  • ????????try:??
  • ????????????pf?=?file(self.pidfile,'r')??
  • ????????????pid?=?int(pf.read().strip())??
  • ????????????pf.close()??
  • ????????except?IOError:??
  • ????????????pid?=?None??
  • ??????
  • ????????if?not?pid:??
  • ????????????message?=?"pidfile?%s?does?not?exist.?Daemon?not?running?\n"??
  • ????????????sys.stderr.write(message?%?self.pidfile)??
  • ????????????return?#?not?an?error?in?a?restart??
  • ??
  • ????????#?Try?killing?the?daemon?process??????
  • ????????try:??
  • ????????????while?1:??
  • ????????????????os.kill(pid,?SIGTERM)??
  • ????????????????time.sleep(0.1)??
  • ????????except?OSError,?err:??
  • ????????????err?=?str(err)??
  • ????????????if?err.find("No?such?process")?>?0:??
  • ????????????????if?os.path.exists(self.pidfile):??
  • ????????????????????os.remove(self.pidfile)??
  • ????????????else:??
  • ????????????????print?str(err)??
  • ????????????????sys.exit(1)??
  • ??
  • ????def?restart(self):??
  • ????????"""?
  • ????????Restart?the?daemon?
  • ????????"""??
  • ????????self.stop()??
  • ????????self.start()??
  • ??
  • ????def?run(self):??
  • ????????"""?
  • ????????You?should?override?this?method?when?you?subclass?Daemon.?It?will?be?called?after?the?process?has?been?
  • ????????daemonized?by?start()?or?restart().?
  • ????????"""??

  • Daemon.daemonize()方法就是執(zhí)行了上述的步驟。如果需要使用此守護(hù)進(jìn)程類,請繼承Daemon類并自行實現(xiàn)run方法。

    [python]? view plain copy
  • #!/usr/bin/env?python??
  • ??
  • import?sys,?time??
  • from?daemon?import?Daemon??
  • ??
  • class?MyDaemon(Daemon):??
  • ????def?run(self):??
  • ????????while?True:??
  • ????????????time.sleep(1)??
  • ??
  • if?__name__?==?"__main__":??
  • ????daemon?=?MyDaemon('/tmp/daemon-example.pid')??
  • ????if?len(sys.argv)?==?2:??
  • ????????if?'start'?==?sys.argv[1]:??
  • ????????????daemon.start()??
  • ????????elif?'stop'?==?sys.argv[1]:??
  • ????????????daemon.stop()??
  • ????????elif?'restart'?==?sys.argv[1]:??
  • ????????????daemon.restart()??
  • ????????else:??
  • ????????????print?"Unknown?command"??
  • ????????????sys.exit(2)??
  • ????????sys.exit(0)??
  • ????else:??
  • ????????print?"usage:?%s?start|stop|restart"?%?sys.argv[0]??
  • ????????sys.exit(2)??

  • 參考資料:

    http://www.jejik.com/articles/2007/02/a_simple_unix_linux_daemon_in_python/

    http://www.zhouxiongzhi.net/tech/double-fork-when-creating-daemon/

    http://blog.163.com/yungang_z/blog/static/175153133201232462140622/

    總結(jié)

    以上是生活随笔為你收集整理的Linux守护进程设计规范及python实现的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

    欧美a级片网站 | av天天澡天天爽天天av | 香蕉久久久久久av成人 | 9992tv成人免费看片 | 91av在线播放| 欧美午夜久久 | 在线观看免费中文字幕 | 在线播放一区二区三区 | 成人91视频 | 婷婷丁香av| 97超碰福利久久精品 | 丁香花在线观看免费完整版视频 | 天天爱av导航 | 成人免费视频网站 | 在线观看成人 | 日韩三级av | 免费又黄又爽视频 | av天天色 | 久操视频在线免费看 | 自拍超碰在线 | 精品99在线| 国产一级电影免费观看 | 亚洲精品在线视频网站 | 国产69精品久久久久99尤 | 国产一区二区三区高清播放 | 丁香国产视频 | 色偷偷888欧美精品久久久 | 久久免费视频一区 | 毛片网站免费在线观看 | 91禁看片 | 欧美日本在线视频 | 久久九九影视 | 婷婷色中文字幕 | 久久国产精品一国产精品 | 成人在线视频网 | 国产精品免费观看网站 | 精品国产伦一区二区三区观看说明 | 日韩高清在线观看 | 日本高清免费中文字幕 | 成人作爱视频 | 深爱五月激情五月 | 在线国产精品视频 | 亚洲全部视频 | 最近更新中文字幕 | 日韩成人看片 | 国产手机在线观看视频 | 午夜精品一区二区三区四区 | h久久| av不卡中文字幕 | 国产精品毛片久久久久久久久久99999999 | 91av视频播放 | 国产999精品久久久久久 | av网站地址 | 国产成人精品免高潮在线观看 | 日韩成人看片 | 婷婷日日 | 国产一级a毛片视频爆浆 | 色综合久久综合 | 一区二区三区在线观看免费视频 | 亚洲国产精品女人久久久 | av福利在线| 99r在线| 日韩免费不卡视频 | 中国一级片在线播放 | 欧美亚洲一区二区在线 | 日本最新一区二区三区 | 日本福利视频在线 | 精品亚洲一区二区 | 天天干人人干 | 美女精品在线观看 | 久久久久久久久久久久久久电影 | 免费观看一区 | 天天操天天干天天玩 | 福利视频一二区 | 国产美女精品人人做人人爽 | 日本中文字幕一二区观 | 91av蜜桃| 亚洲一区久久久 | 日韩精品在线观看视频 | 久久伊人操 | 国产爽视频 | 人人干干人人 | 午夜视频色| 国产精品99蜜臀久久不卡二区 | 国产一区在线看 | 就要干b| 91在线中文| 中文字幕在线电影 | 久久精品99国产精品酒店日本 | 五月激情丁香婷婷 | 国产视频欧美视频 | 亚洲国产日韩av | 96国产在线 | 久久区二区 | 一本一本久久a久久精品综合 | 天天操天天操天天操天天操天天操 | 国产精品久久久久久久久久久久久久 | 久草在线资源观看 | 亚洲欧美综合精品久久成人 | 国产夫妻自拍av | 久久美女免费视频 | 色视频国产直接看 | 久久天天综合网 | 欧美一级大片在线观看 | 麻豆激情电影 | 91精品视频播放 | 一区二区成人国产精品 | 精品亚洲一区二区三区 | 亚欧日韩成人h片 | 91免费在线视频 | 91av在线免费观看 | 国产在线观看你懂的 | 久久久久亚洲精品男人的天堂 | 九九久久久久99精品 | 欧美另类高清 videos | 亚洲日本韩国一区二区 | 国产蜜臀av| 国产在线观看午夜 | 99视频导航 | 久草在线资源观看 | 在线观看亚洲a | 国产麻豆精品95视频 | 亚洲黄a| 六月激情网 | 91高清视频在线 | 999国内精品永久免费视频 | 国产精品露脸在线 | 国产一级特黄电影 | 91福利小视频 | 国产精品免费看久久久8精臀av | 久久精品视频在线观看 | 欧美激情操 | 国产精品久久久久久69 | 久久99久久精品 | 天天干人人插 | 国产黄免费在线观看 | 久久久www| 国产精品尤物视频 | 激情婷婷亚洲 | 久草视频在线资源站 | 亚洲色图美腿丝袜 | 日韩av成人在线观看 | 欧美怡红院 | 91| 久久久国产影视 | 欧美日韩综合在线 | 免费av网址在线观看 | 五月婷婷六月丁香激情 | 久久精品精品电影网 | 97超碰在线资源 | 国产精品亚洲片在线播放 | 99久久精品电影 | 91成年视频 | 天天综合在线观看 | 在线观看免费观看在线91 | aaa日本高清在线播放免费观看 | 黄色av免费在线 | 免费一级片在线观看 | 成人小视频在线免费观看 | 亚洲精品乱码久久久一二三 | 九色91福利 | 96精品高清视频在线观看软件特色 | 国产精品久久久久aaaa | 一级片视频在线 | 天天爱综合 | 深夜国产在线 | 精品亚洲成人 | 国产亚洲91 | 免费在线观看黄网站 | 国产精品一区欧美 | av片中文 | 免费av网址大全 | 在线高清一区 | 黄色亚洲片 | 国产精品久久久久免费 | 成人黄色小说视频 | 欧美久久久久久久久 | 韩日精品视频 | 不卡电影一区二区三区 | 亚洲精品在线视频观看 | 国产一区二区免费在线观看 | 天天干天天干天天射 | 国产一线二线三线在线观看 | 久久久久久亚洲精品 | 亚洲精品高清视频 | 97色噜噜 | 日韩网页| 一级片视频在线 | 亚洲国产中文字幕在线观看 | 久久免费视频观看 | sm免费xx网站 | 欧美日韩国产综合网 | 久久久久一区二区三区四区 | 99精品久久99久久久久 | 在线高清一区 | 国产小视频免费观看 | 天堂av在线免费 | 91在线精品一区二区 | 亚洲精品a区 | 婷婷精品在线视频 | 精品专区| 99热超碰| 国产精品毛片一区视频播不卡 | www黄色软件 | 国产伦理久久精品久久久久_ | 99热精品国产 | 成年人免费电影 | 99精彩视频在线观看免费 | 久久99久久99精品免观看粉嫩 | 97超碰成人 | 国产黄色免费看 | 亚洲a色 | 久久久五月天 | 国产精品乱码高清在线看 | 久久成人精品视频 | 精品久久99 | 在线视频 你懂得 | 免费视频久久久久 | 最近中文字幕在线播放 | 欧美坐爱视频 | 亚洲mv大片欧洲mv大片免费 | 中文字幕观看av | 免费男女羞羞的视频网站中文字幕 | 国产无遮挡又黄又爽馒头漫画 | 在线午夜av | 亚洲精品成人av在线 | 黄网站大全 | 四虎国产精品免费观看视频优播 | 91精品久久久久久久久 | 五月天久久婷 | 91麻豆精品国产91久久久使用方法 | 午夜精品电影 | 亚洲国产日韩av | 色播99| 狠狠色2019综合网 | 综合久久婷婷 | 男女激情麻豆 | 国产天天综合 | 国产精品婷婷午夜在线观看 | 又黄又爽又色无遮挡免费 | 91看片在线观看 | 亚洲精品午夜aaa久久久 | 国产91在| 干干夜夜 | 国产日韩三级 | 成人影视免费 | 欧美激情视频免费看 | 国产精品视频永久免费播放 | 国产精品久久久久av免费 | 精品天堂av | 在线日本看片免费人成视久网 | 久久久久久久国产精品影院 | 久久久精品二区 | 久久国产精品99久久久久久丝袜 | 欧美大片在线观看一区 | www.com.日本一级 | www色,com| 福利一区视频 | 爱av在线网 | 国产黄免费在线观看 | 日韩av一区二区三区四区 | 欧美日韩不卡在线视频 | 国产精品一区二区免费 | www.久久色 | 色婷婷综合久色 | 日本爽妇网| 成年人视频在线免费观看 | 在线观看日韩专区 | 九九免费在线看完整版 | 色婷婷在线视频 | 天天操综合网站 | 狠狠躁日日躁狂躁夜夜躁av | 手机在线小视频 | 免费视频色 | 亚洲精品xxxx | 成年在线观看 | 国产在线a | 在线观看欧美成人 | 久久国产亚洲视频 | 青青河边草观看完整版高清 | 国产精品久久久久久久久久妇女 | 国产一区欧美一区 | 黄色官网在线观看 | 欧美精品一区二区在线观看 | 国产香蕉久久精品综合网 | 伊香蕉大综综综合久久啪 | 国产精品久久久久久久午夜 | 午夜av一区二区三区 | 日韩理论在线视频 | 亚洲五月 | 免费高清无人区完整版 | 成 人 黄 色 视频免费播放 | 最新日韩中文字幕 | 日韩一区二区三免费高清在线观看 | 久久精品电影网 | 国产精品美女久久久久久2018 | av三级av| 91桃色视频| 国产成人精品亚洲 | 色在线高清 | 黄色片网站 | 高清国产一区 | 亚洲美女视频在线 | 精品伦理一区二区三区 | 日本中文字幕高清 | 天天玩天天操天天射 | 国产 日韩 在线 亚洲 字幕 中文 | 制服丝袜亚洲 | 天天插天天射 | 亚洲一区二区三区毛片 | 亚洲成av人影院 | 久久免费试看 | 国内精品一区二区 | 国产精品久久久久久麻豆一区 | av在线播放免费 | 日韩在线三级 | 麻豆视频成人 | 欧美精品在线观看一区 | 亚洲精品a区 | 97av.com | 亚洲在线网址 | 国内精品久久久久久久久 | 国产精品手机看片 | 久久手机免费视频 | 超碰在线亚洲 | 国产一区二区精品久久 | 国产乱对白刺激视频不卡 | 一区二区三区中文字幕在线观看 | 天天爽天天搞 | 亚洲综合色丁香婷婷六月图片 | 久久久久久久久久免费 | 天天操天天干天天 | 国产91区 | 亚洲综合狠狠干 | 免费看高清毛片 | 亚洲精品国产品国语在线 | 国产精品99久久久久的智能播放 | 成人精品国产 | 天天做综合网 | 五月婷婷六月丁香 | 日韩午夜av电影 | 色爱成人网 | 69国产盗摄一区二区三区五区 | 91视频这里只有精品 | 综合婷婷丁香 | 国产一区精品在线观看 | 久久黄色a级片 | 国产精品免费在线播放 | 午夜精品电影 | av手机在线播放 | 久久精品永久免费 | 国产精品久久久免费 | 有码中文在线 | 久久精品3 | 欧美a级一区二区 | 国产精品丝袜在线 | 国产福利中文字幕 | av在线免费观看黄 | 激情久久婷婷 | 亚洲精品视频免费在线 | 欧美色精品天天在线观看视频 | 免费观看一级成人毛片 | 91经典在线 | 欧美成年人在线观看 | 麻豆综合网 | 黄色亚洲片 | 国产成人精品一区二 | 91看片淫黄大片一级在线观看 | 国产免费观看高清完整版 | 欧美极品在线播放 | 狠狠色噜噜狠狠狠狠 | 欧美在线一级片 | 色综合久久88 | 国产免费成人 | 99精品国产亚洲 | 美女久久久久久久久久久 | 国产精品69av | 亚a在线 | 中文字幕一区二区三区久久 | 天天天天天天操 | 国产精品一区二区在线观看 | 亚洲高清精品在线 | 婷婷激情综合网 | 最近中文字幕高清字幕在线视频 | 四虎永久网站 | 亚洲成av片人久久久 | 91在线视频免费 | 日韩1页| 国产美女免费看 | 成年人三级网站 | 成人亚洲精品国产www | 爱干视频| av免费在线播放 | 久久国产美女 | 中文字幕亚洲精品在线观看 | 欧美日韩另类视频 | 成人黄色小说在线观看 | 激情五月婷婷综合 | h网站免费在线观看 | 热久久99这里有精品 | 久久av在线| 亚洲国产精品一区二区尤物区 | 国产视频久 | 99在线观看 | 精品视频在线视频 | 中文国产在线观看 | 美女视频久久 | 黄av在线| 欧美在线一级片 | 999抗病毒口服液 | 久久草av | 欧美一区二区免费在线观看 | 国产专区精品 | 天天操天天摸天天干 | 黄色精品在线看 | 免费a一级 | 亚洲一区二区三区毛片 | 97精品超碰一区二区三区 | 久久色视频 | 激情丁香久久 | 日韩精品在线免费播放 | 欧美在线一二 | 天天爽夜夜爽人人爽一区二区 | 激情综合啪 | 国产精品69久久久久 | 色偷偷中文字幕 | 国产黑丝一区二区三区 | 成人免费观看在线视频 | 免费国产黄线在线观看视频 | 超碰97免费观看 | 97综合网| 日韩三级免费观看 | 久草在线电影网 | 天天激情 | 国产精品观看 | 中国一级片在线观看 | 中文字幕国语官网在线视频 | 国产美女黄网站免费 | 91免费网站在线观看 | 免费视频国产 | 久久99精品国产99久久6尤 | 99免费| 91精彩视频在线观看 | 国产精品美女久久久久aⅴ 干干夜夜 | 日韩毛片在线免费观看 | 999久久久 | 伊人久久一区 | 在线观看视频国产 | 日韩视频图片 | 久草91视频 | 精品免费视频. | 国产精品短视频 | a色视频| 日本三级吹潮在线 | 日韩高清www | 亚洲电影自拍 | 狠狠色伊人亚洲综合网站野外 | 91日韩在线播放 | 国产一级片一区二区三区 | 久久tv | 中文字幕亚洲在线观看 | 亚洲精品乱码久久久久久蜜桃欧美 | 欧美精品国产精品 | 在线观看黄网站 | 日韩精品视频免费 | 久久精品99国产国产 | 国产麻豆成人传媒免费观看 | 9999免费视频| 国产精彩视频一区 | 免费视频久久久 | 一区三区视频 | 激情欧美在线观看 | 国产手机精品视频 | 亚洲精品伦理在线 | 97成人资源| av一区在线 | 日日插日日干 | 欧美最猛性xxx | 三级av中文字幕 | 久久成人精品电影 | 青春草视频在线播放 | 国产精品久一 | 成人黄色小说视频 | 91精品电影 | 亚洲免费成人 | 中文字幕国内精品 | 97av.com| 97超碰成人在线 | 日日添夜夜添 | 国产成人精品av在线观 | 97自拍超碰 | 一区二区三区观看 | 国产成人福利在线 | 少妇bbw揉bbb欧美 | 色婷婷亚洲精品 | 免费观看黄色12片一级视频 | 成人在线一区二区三区 | 精品嫩模福利一区二区蜜臀 | 久久综合视频网 | 夜夜视频资源 | 在线黄色国产电影 | 天天操天天射天天插 | 日韩在线网| 久久国产美女 | 麻豆一区在线观看 | 97av影院| 香蕉视频最新网址 | www.天天成人国产电影 | 天堂av在线中文在线 | 香蕉在线播放 | 日韩精品中文字幕在线不卡尤物 | 99这里有精品 | 国产特级毛片aaaaaa | 久久免费视频网站 | 日韩羞羞 | 国产一区免费观看 | 人人爽人人爽人人爽人人爽 | 亚洲伊人婷婷 | 欧美成人h版 | 亚洲精品高清在线 | 91香蕉视频 mp4 | 国产又粗又硬又爽的视频 | 精品国产中文字幕 | 尤物九九久久国产精品的分类 | 日韩精品中文字幕在线播放 | 久久9精品 | 狠狠色丁香婷婷综合橹88 | 夜色资源站国产www在线视频 | av在线网站免费观看 | 4p变态网欧美系列 | 国产色网站 | 天天操操操操操 | 日韩欧美国产精品 | 日韩在线观看视频网站 | 成年人国产在线观看 | 亚洲 欧美 国产 va在线影院 | 草在线 | 久久久麻豆视频 | 人人干在线观看 | 成人在线视频免费看 | 日韩国产欧美视频 | 国产另类xxxxhd高清 | 伊人春色电影网 | 黄色在线看网站 | 亚洲欧美日韩一区二区三区在线观看 | 天天色综合久久 | 久久伊人综合 | www.久久色 | 精品国产a | 日本久久久久久科技有限公司 | 免费视频区 | 日韩久久精品一区二区三区 | 午夜精品久久久久久久99无限制 | 国产精品乱码一区二三区 | av电影不卡在线 | 亚洲激情六月 | 波多野结衣在线观看视频 | 免费三级av| 免费av的网站| 免费久久99精品国产 | 久久婷婷影视 | 久久久久久久久久亚洲精品 | 天天射天天操天天干 | 久久久免费看视频 | 成年人网站免费在线观看 | 欧美 亚洲 另类 激情 另类 | 免费毛片aaaaaa | 97精品国自产拍在线观看 | 日韩欧美视频免费在线观看 | 久久大香线蕉app | 久99久精品| 国产精品自产拍在线观看中文 | 成人电影毛片 | 天天爱天天舔 | 久久久久久久久福利 | 国产视频亚洲精品 | 天天在线视频色 | 国产精品一区二区av影院萌芽 | 国产精品精品国产 | 国产精品久久久亚洲 | 久久久久久久久久久网 | 亚洲高清视频在线播放 | 69精品视频在线观看 | 日韩av免费网站 | 丁香婷婷久久久综合精品国产 | www.xxxx变态.com| 亚洲人xxx| 久久久www成人免费毛片麻豆 | 99精品欧美一区二区三区黑人哦 | 国产手机在线观看视频 | 四虎欧美 | 麻豆精品视频在线 | 日韩在线视频线视频免费网站 | 成人av在线亚洲 | 久久这里只有精品久久 | 欧美成人精品欧美一级乱 | 国产色久| 精品国产一区二区三区久久久久久 | 国产精品观看在线亚洲人成网 | 精品久久久久久久久亚洲 | 操操操干干干 | 欧美乱熟臀69xxxxxx | 日韩丝袜在线观看 | 国产亚洲精品久久久久久久久久 | 伊人永久 | 国产精品字幕 | 久久久久影视 | 色综合天天射 | 91成人精品一区在线播放69 | 在线观看免费成人av | 久久五月情影视 | 综合成人在线 | 色资源网免费观看视频 | 久久人人97超碰com | 99这里有精品| 欧美日韩不卡在线观看 | 久久精品成人 | 91中文在线观看 | 美女网站在线观看 | 97小视频| www.com黄色 | 久久69精品 | 欧美激情另类 | 亚洲视频综合在线 | 久久国产影视 | 日韩欧美国产成人 | 国产日韩精品视频 | 欧美国产一区在线 | 99视频久| 亚洲精品视频网 | 超碰个人在线 | 国产精品热视频 | 国产做aⅴ在线视频播放 | 国产大尺度视频 | 成人一级视频在线观看 | 久久亚洲欧美日韩精品专区 | 久久艹综合 | 人人干人人做 | 91传媒免费在线观看 | 精品久久影院 | 看全黄大色黄大片 | 青青草国产精品 | 97操操操 | 91一区在线观看 | 国产成人精品999在线观看 | 91传媒在线播放 | 国产在线播放不卡 | 亚洲日本欧美 | 欧美日本在线观看视频 | а中文在线天堂 | 一区二区三区三区在线 | 高清在线观看av | 亚洲精品乱码白浆高清久久久久久 | 国产成人av网站 | 99精品视频在线观看 | 午夜av日韩| 99高清视频有精品视频 | 国色天香在线 | 操操操日日日干干干 | 亚洲黄色小说网址 | 精品免费一区二区三区 | 亚洲精品毛片一级91精品 | 98涩涩国产露脸精品国产网 | 中文字幕久久精品一区 | 最新日韩精品 | 久久久久久欧美二区电影网 | 午夜私人影院久久久久 | 国产精品一区二区三区久久久 | 久久婷婷亚洲 | 青青河边草免费直播 | 狠狠色丁香九九婷婷综合五月 | 日韩经典一区二区三区 | 精品黄色片 | 最近免费观看的电影完整版 | 91视频在线免费下载 | 国产精品一区二 | 日日夜夜网 | 国产成人一级电影 | 午夜精品久久久久久99热明星 | 婷婷丁香综合 | 黄色av电影在线观看 | 69夜色精品国产69乱 | 国产在线 一区二区三区 | av一区二区三区在线观看 | 黄色小网站免费看 | 色资源网免费观看视频 | 日韩欧美在线影院 | 中文字幕免费在线看 | 色吊丝在线永久观看最新版本 | 国产成人av电影在线观看 | 日韩在线观看视频中文字幕 | 国产精品成人一区二区 | 人人插人人看 | 天天天色综合a | 久久在线免费观看视频 | 日韩精品一区二区三区视频播放 | 亚洲日本国产精品 | 中文字幕丝袜一区二区 | 天堂资源在线观看视频 | www.夜夜操| 日韩视频中文 | 狠狠狠狠狠狠操 | 成人黄色影片在线 | 亚洲电影网站 | 人人澡超碰碰97碰碰碰软件 | 91精品久久香蕉国产线看观看 | 久久一区国产 | av五月婷婷 | 96看片| 日韩欧美精品在线 | 日韩精品中文字幕在线观看 | 日日草夜夜操 | 亚洲视屏 | 免费男女网站 | 在线观看韩国av | 最近能播放的中文字幕 | 免费a现在观看 | 黄色资源在线 | 四虎影视www | 日本韩国精品一区二区在线观看 | 亚洲国产黄色片 | 狠狠五月婷婷 | 成年人视频免费在线 | 国产91精品高清一区二区三区 | 久久婷婷一区二区三区 | 一级黄色免费网站 | 日韩在线观看网址 | 欧美成人a在线 | 美女网站黄在线观看 | 国产精品久久久免费 | 久久精品一区二区 | 国产中文字幕一区 | 久久久久久高潮国产精品视 | 国产精品第一页在线 | 麻豆91在线看 | 天天射天天操天天干 | www.黄色片网站 | 国产黄色片在线免费观看 | 欧美日本在线视频 | 国产视频一区二区在线播放 | 2023年中文无字幕文字 | 久久一区二区三区超碰国产精品 | 天天操夜夜拍 | 久久视频国产精品免费视频在线 | 操操碰| 成人97人人超碰人人99 | 99热国产精品 | 欧美在线久久 | 在线国产中文字幕 | 国产免费视频一区二区裸体 | 91在线九色 | 国产高清99 | 黄色免费网站大全 | 久久久精品久久日韩一区综合 | 中文字幕文字幕一区二区 | 99精品国产成人一区二区 | 国产精品一区二区中文字幕 | 久久久久久综合 | 碰天天操天天 | 在线看片成人 | 国产在线va | 亚洲国产精品成人女人久久 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 中文字幕在线免费播放 | 中文字幕成人一区 | 国产二区av | 91视频网址入口 | 久久黄网站 | 欧美一级黄大片 | 激情网综合 | 爱爱av网站| 亚洲91网站 | 天天综合日日夜夜 | 久久国产精品小视频 | 夜夜躁狠狠躁日日躁 | 黄色av三级在线 | 久久综合色8888 | 夜夜躁狠狠躁日日躁视频黑人 | 亚洲综合日韩在线 | 91成人精品观看 | 天天综合精品 | 亚洲做受高潮欧美裸体 | 婷婷精品在线视频 | 91精品国产综合久久婷婷香蕉 | 国产麻豆果冻传媒在线观看 | 国产一区二区在线免费播放 | 国产最顶级的黄色片在线免费观看 | 日本在线成人 | 中文字幕乱码亚洲精品一区 | 欧美国产91 | 永久免费精品视频 | 欧美性大战久久久久 | 亚洲国产精品电影在线观看 | 国产美女网 | 精品国产99国产精品 | 激情在线网址 | 深夜免费福利在线 | 国产精品视频免费观看 | 国产+日韩欧美 | 三级视频国产 | 日韩在线三区 | 婷婷深爱 | 不卡的av电影 | 日本久久成人中文字幕电影 | 91看片在线免费观看 | 丁香婷婷基地 | 香蕉看片 | 久久精品中文字幕少妇 | 麻豆视频国产 | 香蕉免费在线 | 久久99热精品这里久久精品 | 日韩高清久久 | 911免费视频| 97精品伊人 | 成片免费观看视频大全 | 国产精品免费观看国产网曝瓜 | 午夜免费久久看 | 国产99免费视频 | 国产精品久免费的黄网站 | 91精品国产91p65 | 国产99免费 | 粉嫩av一区二区三区四区五区 | 手机成人在线 | 97成人在线观看视频 | 亚洲va欧美va| 国产成人在线综合 | 在线观看精品视频 | 色福利网 | 免费观看一级特黄欧美大片 | 精品国产一区二区三区久久久久久 | 九色91在线 | 狠狠狠色狠狠色综合 | 亚洲精品在线视频网站 | 国产又粗又硬又爽视频 | 欧美日韩中字 | 中文字幕二区三区 | 久久综合久久久久88 | 99爱国产精品 | 久久久久久久久久久福利 | 97在线视频网站 | 国产精品免费一区二区三区 | 日韩经典一区二区三区 | 日本美女xx | 五月天色丁香 | 字幕网av| 婷婷av在线 | 久久婷五月 | 91成人在线看 | 国产一区二区三区四区大秀 | av在线影片 | 99精品热视频只有精品10 | 成人在线观看av | 国产小视频在线免费观看 | 国产精品电影一区 | 成人黄色电影在线播放 | 日韩理论在线观看 | 精品国产精品一区二区夜夜嗨 | 久久久精品视频网站 | 麻豆国产在线播放 | av蜜桃在线| 精品国产一区二区三区在线 | 日本中文字幕在线观看 | 久久av黄色 | 波多野结衣在线观看一区 | 五月婷婷一级片 | 可以免费观看的av片 | 在线观看视频精品 | 国产精品久久久久久久久免费 | 在线中文字幕av观看 | 日韩欧美视频一区二区三区 | 免费成人黄色片 | 国内少妇自拍视频一区 | 亚洲午夜av久久乱码 | 亚洲 欧洲av | 国产精品videossex国产高清 | 午夜精品久久久久久久久久 | 日韩精品久久一区二区三区 | a黄色一级片 | 国产一级片免费播放 | 久久午夜国产 | 中文国产在线观看 | 久久天天躁夜夜躁狠狠85麻豆 | 亚洲国产精品推荐 | 久草在线一免费新视频 | 夜夜操天天干 | 天天射狠狠干 | 欧美日韩精品在线免费观看 | www.色午夜.com | 人人澡超碰碰 | 热久久影视 | 亚洲精品一区二区在线观看 | 久久久国产精品一区二区三区 | 456免费视频 | 伊人影院在线观看 | 国产精品一区免费看8c0m | 在线免费观看成人 | 中文字幕91 | 天天做综合网 | 久久免费观看少妇a级毛片 久久久久成人免费 | 国内精品久久久久久久久久 | 又黄又刺激又爽的视频 | 国产女人40精品一区毛片视频 | 国产剧情在线一区 | 伊香蕉大综综综合久久啪 | 91精品国产92久久久久 | av在线精品 | 亚洲五月婷 | 天天草天天爽 | 国产九色在线播放九色 | 香蕉在线观看 | 亚洲天天在线 | 99这里都是精品 | 免费在线看成人av | 激情丁香综合五月 | 亚洲精品久久久久久久不卡四虎 | 日韩精品免费一区二区三区 | 国产啊v在线观看 | 久久这里只有精品1 | 免费三级网 | 久久九九视频 | 久久成电影 | 中文字幕一区2区3区 | 久久久久影视 | 日韩电影中文字幕在线 | 久久99亚洲热视 | 欧美精品亚洲二区 | 亚洲一级免费电影 | 久久免费毛片视频 | 欧美色图另类 | 国产精品18久久久久vr手机版特色 | 日韩久久午夜一级啪啪 | 免费看一及片 | 欧美日韩国产精品一区 | 免费在线播放黄色 | 奇米导航| 国产一级免费观看 | 一区二区三区四区影院 | 九九视频免费观看视频精品 | 日韩av中文 | 美女视频国产 | 99久久精品久久久久久动态片 | 国产高清在线看 | 51久久成人国产精品麻豆 | 亚洲乱码中文字幕综合 | 亚洲a网 | 免费看一级特黄a大片 | 麻豆激情电影 | 在线观看91视频 | 精品久久99| 综合精品久久久 | 五月天久久久 | 97超碰精品 | 夜夜操狠狠干 | 狠狠的日 | 六月激情 | 久色网| 国产成人黄色在线 | 婷婷免费视频 | 又色又爽又激情的59视频 | 久草在线视频国产 | 国产精品女人久久久久久 | 午夜的福利 | 欧洲激情在线 | 福利网址在线观看 | av免费播放| www国产亚洲精品久久网站 | 操久久网 | av先锋中文字幕 | 超碰在线9 | 日韩在线视频网站 | 手机av在线网站 | 视频在线精品 | 国产麻豆视频在线观看 | 久久久综合香蕉尹人综合网 | 激情偷乱人伦小说视频在线观看 | 国产精品一区二区在线 | 成人av免费| 一区二区伦理 | 国产一区视频导航 | 99亚洲国产| 91免费观看视频网站 | 亚洲最大av在线播放 | 国产美女精品 | x99av成人免费 | 999久久国精品免费观看网站 | 成人久久影院 | 久久久精品 一区二区三区 国产99视频在线观看 | 日韩3区 | 黄色视屏免费在线观看 | 成人免费观看网站 | 亚洲国产av精品毛片鲁大师 | 国产精品一区久久久久 | 国产在线国偷精品产拍 | 一区二区 不卡 | 国产一区二三区好的 | 黄色特级片 | 国产在线观看高清视频 | 久久久久久久久久电影 |