亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? manager.cpp

?? C++ web POSIX framewark
?? CPP
字號:
#ifdef HAVE_CONFIG_H# include "config.h"#endif#include "manager.h"#include "cgicc_connection.h"#include <dlfcn.h>#include <dirent.h>#include <poll.h>#include <signal.h>#include <errno.h>#include <unistd.h>#include <stdlib.h>#include <sys/mman.h>#include <sys/wait.h>#include <sys/types.h>#include <algorithm>#include "thread_cache.h"#include "scgi.h"#include "cgi.h"#include "session_cookies.h"#include "session_file_storage.h"#include "session_cache_backend.h"#include "session_dual.h"#ifdef EN_SQLITE_SESSIONS# include "session_sqlite_storage.h"#endif#ifdef EN_FORK_CACHE# include "process_cache.h"#endif#ifdef EN_FCGI_BACKEND# include "fcgi.h"#endif#ifdef EN_TCP_CACHE# include "tcp_cache.h"# include "session_tcp_storage.h"#endifnamespace {	void set_signal_handler(int sig,void (*handler)(int))	{		struct sigaction sac;		memset(&sac,0,sizeof(sac));		sac.sa_handler=handler;		sigaction(sig,&sac,NULL);	}}namespace cppcms {namespace details {class single_run : public web_application{public:	single_run(manager &m) : web_application(m)	{	};	virtual void execute()	{		base_factory &factory=*app.workers;		shared_ptr<worker_thread> worker(factory(app));		cgi_session *session=app.api->accept_session();		if(session) {			try {				if(session->prepare()) {					worker->run(session->get_connection());				}			}			catch(...) {				delete session;				throw;			}			delete session;		}	}};fast_cgi_application *fast_cgi_application::handlers_owner=NULL;fast_cgi_application::event_t fast_cgi_application::wait(){	while(!the_end) {		struct pollfd fds;		fds.fd=app.api->get_socket();		fds.events=POLLIN | POLLERR;		fds.revents=0;		/* Wait for two events:		 * 1. New connection and then do accept		 * 2. Exit message - exit and do clean up */		if(poll(&fds,1,-1)<0) {			if(errno==EINTR && !the_end)				continue;			return EXIT;		}		else if(fds.revents) {			if(fds.revents & POLLERR)				return EXIT;			return ACCEPT;		}	}	return EXIT;}void fast_cgi_application::shutdown(){	// Rise exit signal on	// the selfpipe	the_end=true;}void fast_cgi_application::handler(int id){	fast_cgi_application *ptr=fast_cgi_application::get_instance();	if(ptr) {		ptr->shutdown();	}}void fast_cgi_application::set_signal_handlers(){	handlers_owner=this;	/* Signals defined by standard */	set_signal_handler(SIGTERM,handler);	set_signal_handler(SIGUSR1,handler);	/* Additional signal */	set_signal_handler(SIGINT,handler);}fast_cgi_single_threaded_app::fast_cgi_single_threaded_app(manager &m) :		fast_cgi_application( m){	base_factory &factory=*app.workers;	worker=factory(app);}bool fast_cgi_single_threaded_app::run(){	// Blocking loop	event_t event=wait();	if(event==EXIT) {		return false;	} // ELSE event==ACCEPT	cgi_session *session=app.api->accept_session();	if(session) {		try {			if(session->prepare()) {				worker->run(session->get_connection());			}		}		catch(...) {			delete session;			throw;		}		delete session;	}	return true;};void fast_cgi_application::execute(){	the_end=false;	set_signal_handlers();	while(run()){		/* Do Continue */	}}fast_cgi_multiple_threaded_app::fast_cgi_multiple_threaded_app(manager &m):	fast_cgi_application(m){	int threads_num=app.config.lval("server.threads",5);	int buffer=app.config.lval("server.buffer",10);	int i;	threads_info=NULL;	pids=NULL;	size=threads_num;	// Init Worker Threads	workers.resize(size);	base_factory &factory=*app.workers;	for(i=0;i<size;i++) {		workers[i]=factory(app);	}	// Setup Jobs Manager	jobs.init(buffer);	start_threads();}void *fast_cgi_multiple_threaded_app::thread_func(void *p){	info_t *params=(info_t *)p;	int id=params->first;	fast_cgi_multiple_threaded_app *self=params->second;	cgi_session *session;	while((session=self->jobs.pop())!=NULL) {		try{			if(session->prepare()){				self->workers[id]->run(session->get_connection());			}		}		catch(...){			delete session;			return NULL;		}		delete session;	}	return NULL;}void fast_cgi_multiple_threaded_app::start_threads(){	int i;	pids = new pthread_t [size];	threads_info = new info_t [size];	for(i=0;i<size;i++) {		threads_info[i].first=i;		threads_info[i].second=this;		pthread_create(pids+i,NULL,thread_func,threads_info+i);	}}void fast_cgi_multiple_threaded_app::wait_threads(){	int i;	for(i=0;i<size;i++) {		pthread_join(pids[i],NULL);	}}bool fast_cgi_multiple_threaded_app::run(){	if(wait()==ACCEPT) {		cgi_session *session=app.api->accept_session();		if(session){			jobs.push(session);		}		return true;	}	else {// Exit event		int i;		for(i=0;i<size;i++) {			jobs.push(NULL);		}		wait_threads();		return false;	}}// Single instance of preforkprefork *prefork::self;void prefork::parent_handler(int s_catched){	int i;	int s;	if(self->exit_flag==0) {		self->exit_flag=1;		s=SIGTERM;	}	else {		s=SIGKILL;	}	set_signal_handler(SIGALRM,parent_handler);	alarm(3);	for(i=0;i<self->procs;i++) {		kill(self->pids[i],s);	}}void prefork::chaild_handler(int s){	self->exit_flag=1;	set_signal_handler(SIGALRM,chaild_handler);	alarm(1);}void prefork::run(){	/* Signals defined by standard */	set_signal_handler(SIGTERM,chaild_handler);	set_signal_handler(SIGUSR1,chaild_handler);	/* Additional signal */	set_signal_handler(SIGINT,chaild_handler);	base_factory &factory=*app.workers;	shared_ptr<worker_thread> worker=factory(app);	int limit=app.config.lval("server.iterations_limit",-1);	if(limit!=-1) {		srand(getpid());		limit=limit+(limit / 10 *(rand() % 100))/100;	}	int counter=0;	while(!exit_flag){		if(limit!=-1 && counter>limit)			return;		counter++;		auto_ptr<cgi_session> session;		try{			session.reset(app.api->accept_session());			if(session.get() && session->prepare()) {				worker->run(session->get_connection());			}		}		catch(exception const &e){			cerr<<e.what()<<endl;		}	}}prefork::prefork(manager &m) :	web_application(m){	procs=app.config.lval("server.procs",5);	exit_flag=0;	pids.resize(procs);	self=this;}void prefork::execute(){	int i;	for(i=0;i<procs;i++) {		pid_t pid=fork();		if(pid<0) {			perror("fork:");			int j;			for(j=0;j<i;j++) {				kill(pids[j],SIGKILL);				wait(NULL);			}			exit(1);		}		if(pid>0) {			pids[i]=pid;		}		else { // pid==0			run();			return;		}	}	/* Signals defined by standard */	set_signal_handler(SIGTERM,parent_handler);	set_signal_handler(SIGUSR1,parent_handler);	/* Additional signal */	set_signal_handler(SIGINT,parent_handler);	while(!prefork::exit_flag) {		int stat;		pid_t pid=wait(&stat);		if(pid<0) {			continue;		}		if(exit_flag) break;		for(i=0;i<procs;i++) {			if(pids[i]==pid) {				if(!WIFEXITED(stat) || WEXITSTATUS(stat)!=0){					if(WIFEXITED(stat)) {						cerr<<"Chaild "<<pid<<" exited with "<<WEXITSTATUS(stat)<<endl;					}					else if(WIFSIGNALED(stat)) {						cerr<<"Chaild "<<pid<<" killed by "<<WTERMSIG(stat)<<endl;					}					else {						cerr<<"Chaild "<<pid<<" exited for unknown reason"<<endl;					}				}				pid=fork();				if(pid==0) {					run();					return;				}				pids[i]=pid;				break;			}		}	}	for(i=0;i<procs;i++)  {		while(wait(NULL)<0 && errno==EINTR)			;	}}} // END oF Detailscache_factory *manager::get_cache_factory(){	string backend=config.sval("cache.backend","none");	if(backend=="none") {		return new cache_factory();	}	else if(backend=="threaded") {		int n=config.lval("cache.limit",100);		return new thread_cache_factory(n);	}#ifdef EN_FORK_CACHE	else if(backend=="fork") {		#ifndef HAVE_PTHREADS_PSHARED			// without pshared mutexes fork cache uses fcnlt for locking 			// and becomes not thread safe			if(config.sval("server.mod","")=="thread") {				throw cppcms_error("Can't use fork cache backend with mod_thread");			}		#endif		size_t s=config.lval("cache.memsize",64);		string f=config.sval("cache.file","");		return new process_cache_factory(s*1024U,f=="" ? NULL: f.c_str());	}#endif#ifdef EN_TCP_CACHE	else if(backend=="tcp") {		vector<int> const &ports=config.llist("cache.ports");		vector<string> const &ips=config.slist("cache.ips");		return new tcp_cache_factory(ips,ports);	}#endif	else {		throw cppcms_error("Unkown cache backend:" + backend);	}}cgi_api *manager::get_api(){	string api=config.sval("server.api");	if(api=="cgi") {		return new cgi_cgi_api();	}	string socket=config.sval("server.socket","");	int backlog=config.lval("server.buffer",1);	if(api=="scgi" ) {		return new scgi_api(socket.c_str(),backlog);	}#ifdef EN_FCGI_BACKEND	if(api=="fastcgi"){		return new fcgi_api(socket.c_str(),backlog);	}#endif	throw cppcms_error("Unknown api:"+api);}web_application *manager::get_mod(){	if(config.sval("server.api","")=="cgi") {		return new details::single_run(*this);	}	string mod=config.sval("server.mod");	if(mod=="process") {		return new details::fast_cgi_single_threaded_app(*this);	}	if(mod=="thread") {		return new details::fast_cgi_multiple_threaded_app(*this);	}	if(mod=="prefork") {		return new details::prefork(*this);	}	throw cppcms_error("Unknown mod:" + mod);}namespace {	struct empty_backend {		shared_ptr<session_api> operator()(worker_thread &a)		{			return shared_ptr<session_api>(); // EMPTY		}	};}session_backend_factory manager::get_sessions(){	string lock=config.sval("session.location","none");	if(lock=="none")		return empty_backend();		session_backend_factory clnt;	session_backend_factory srv;		if(lock=="client" || lock=="both") {		clnt=session_cookies::factory();	}	if(lock=="server" || lock=="both") {		string srv_backend=config.sval("session.backend","files");		if(srv_backend=="cache")			srv=session_cache_backend::factory();		else if(srv_backend=="files")			srv=session_file_storage::factory(config);#ifdef EN_SQLITE_SESSIONS		else if(srv_backend=="sqlite")			srv=session_sqlite_storage::factory(config);#endif#ifdef EN_TCP_CACHE		else if(srv_backend=="tcp")			srv=session_tcp_storage::factory(config);#endif	else			throw cppcms_error("Unknown backend:"+srv_backend);	}	if(lock=="server") 		return srv;	if(lock=="client")		return clnt;	if(lock=="both") {		int limit=config.ival("session.client_size_limit",2048);		return session_dual::factory(clnt,srv,limit);	}		throw cppcms_error("Unknown location:"+lock);}void manager::execute(){	if(!workers.get()) {		throw cppcms_error("No workers factory set up");	}	if(!cache.get()) {		set_cache(get_cache_factory());	}	if(sessions.empty()) {		set_sessions(get_sessions());	}	if(!api.get()) {		set_api(get_api());	}	if(!gettext.get()){		set_gettext(get_gettext());	}	if(!web_app.get()) {		set_mod(get_mod());	}	load_templates();	web_app->execute();}void manager::load_templates(){	string ext=config.sval("templates.ext",		#ifdef __CYGWIN__		".dll"		#else		".so"		#endif		);	// FIXME to something that works with autotools	unsigned len=ext.size();	vector<string> const &dirs=config.slist("templates.dirs");	for(vector<string>::const_iterator dir=dirs.begin();dir!=dirs.end();++dir) {		DIR *d=::opendir(dir->c_str());		if(!d) continue;		for(struct dirent *entry=::readdir(d);entry;entry=::readdir(d)) {			string filename=entry->d_name;			if(	filename.size()>len &&				filename.substr(filename.size()-len,len) == ext )			{				void *handler=::dlopen((*dir + "/" + filename).c_str(),RTLD_LAZY);				if(handler) templates_list.push_back(handler);			}		}		::closedir(d);	}}manager::~manager(){	for_each(templates_list.begin(),templates_list.end(),::dlclose);}void manager::set_sessions(session_backend_factory s){	sessions=s;}void manager::set_worker(base_factory *w){	workers=auto_ptr<base_factory>(w);}void manager::set_cache(cache_factory *c){	cache=auto_ptr<cache_factory>(c);}void manager::set_api(cgi_api *a){	api=auto_ptr<cgi_api>(get_api());}void manager::set_mod(web_application *m){	web_app=auto_ptr<web_application>(m);}transtext::trans_factory *manager::get_gettext(){	transtext::trans_factory *tmp=NULL;	try{		tmp=new transtext::trans_factory();		tmp->load(	config.sval ("locale.dir",""),				config.slist("locale.lang_list"),				config.sval ("locale.lang_default",""),				config.slist ("locale.domain_list"),				config.sval ("locale.domain_default",""));		return tmp;	}	catch(...){		delete tmp;		throw;	}}void manager::set_gettext(transtext::trans_factory *s){	gettext=auto_ptr<transtext::trans_factory>(s);}manager::manager(){	config.load(0,NULL);}manager::manager(char const *f){	config.load(0,NULL,f);}manager::manager(int argc, char **argv){	config.load(argc,argv);}} // END OF CPPCMS

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美视频你懂的| 99久久99久久精品国产片果冻| 久久蜜桃av一区精品变态类天堂| 99久久久无码国产精品| 奇米一区二区三区| 18成人在线观看| 精品久久人人做人人爽| 91国产视频在线观看| 国产河南妇女毛片精品久久久| 午夜电影网亚洲视频| 国产精品国产三级国产aⅴ中文| 日韩欧美在线网站| 欧美日韩一区二区在线视频| 成人黄色777网| 国产自产2019最新不卡| 肉色丝袜一区二区| 亚洲人成影院在线观看| 久久久久国产免费免费| 日韩免费观看高清完整版| 91久久线看在观草草青青| 国产成人高清在线| 激情五月婷婷综合网| 午夜亚洲福利老司机| 玉米视频成人免费看| 中文字幕第一区| 国产日韩欧美精品在线| 精品国一区二区三区| 91麻豆精品国产综合久久久久久 | 亚洲日本一区二区| 国产日韩精品久久久| 精品国产乱码久久| 日韩欧美一区二区视频| 51久久夜色精品国产麻豆| 欧美性xxxxxx少妇| 色天使久久综合网天天| 99精品热视频| 91香蕉视频污| 色老头久久综合| 欧美亚洲国产一卡| 欧美日韩综合在线| 日本高清不卡视频| 欧美亚洲自拍偷拍| 欧美日韩国产美| 91精品国产综合久久福利| 91精品国产日韩91久久久久久| 欧美一区在线视频| 欧美不卡一区二区| 久久亚洲精精品中文字幕早川悠里| 欧美tickle裸体挠脚心vk| 久久免费偷拍视频| 国产精品女上位| 亚洲精品欧美专区| 午夜欧美大尺度福利影院在线看| 亚洲成人av一区二区三区| 男女男精品网站| 国产美女娇喘av呻吟久久| 国产99久久久精品| 一本大道综合伊人精品热热| 欧美午夜精品久久久| 91精品国产高清一区二区三区| 日韩女优av电影| 国产欧美一区二区精品性色超碰| 中文字幕在线不卡一区| 亚洲一级在线观看| 日本成人在线一区| 高清视频一区二区| 91搞黄在线观看| 日韩欧美国产电影| 国产精品无遮挡| 一区二区三区四区在线播放| 奇米影视一区二区三区小说| 粉嫩av一区二区三区在线播放| av电影在线观看一区| 欧美日韩国产一二三| 久久久一区二区三区捆绑**| 自拍偷拍亚洲欧美日韩| 日本中文一区二区三区| 国产91精品在线观看| 欧美亚洲尤物久久| 久久久久久免费网| 亚洲一区二区三区美女| 国产一区亚洲一区| 色综合天天性综合| 国产拍欧美日韩视频二区| 亚洲欧美色一区| 久99久精品视频免费观看| 色综合网站在线| xvideos.蜜桃一区二区| 亚洲一区中文日韩| 国产成人自拍高清视频在线免费播放| 91久久香蕉国产日韩欧美9色| 久久亚洲精品国产精品紫薇| 午夜精品国产更新| av在线不卡网| 欧美精品一区二区在线播放| 亚洲国产精品久久一线不卡| 国产成人三级在线观看| 777xxx欧美| 一区二区三区欧美| 国产精品一区二区在线观看不卡 | 韩国精品主播一区二区在线观看| 色素色在线综合| 国产日产欧产精品推荐色 | 国产午夜精品一区二区| 五月婷婷激情综合| 91网站视频在线观看| 久久一区二区三区国产精品| 一区二区三区蜜桃| 成人开心网精品视频| 精品美女一区二区| 天天综合天天综合色| 色哟哟国产精品免费观看| 久久久精品tv| 国产在线播精品第三| 日韩天堂在线观看| 五月婷婷综合在线| 欧美少妇一区二区| 有坂深雪av一区二区精品| www.色综合.com| 中文字幕乱码久久午夜不卡 | 石原莉奈在线亚洲二区| 91黄色免费看| 日韩毛片精品高清免费| 成年人国产精品| 国产欧美日韩一区二区三区在线观看| 久久成人免费日本黄色| 欧美一区二区三区性视频| 亚洲成a人片在线观看中文| 日本高清不卡aⅴ免费网站| 亚洲精品自拍动漫在线| 97精品电影院| 亚洲精品一二三区| 色噜噜狠狠成人网p站| 艳妇臀荡乳欲伦亚洲一区| 在线一区二区三区| 亚洲一区在线观看网站| 在线观看视频欧美| 亚洲成人av电影在线| 337p亚洲精品色噜噜噜| 日本不卡的三区四区五区| 日韩欧美色电影| 国产一区在线视频| 欧美激情一区在线| 99久久精品国产毛片| 一区二区三区在线看| 欧美伊人久久久久久久久影院| 三级在线观看一区二区| 欧美电视剧免费观看| 国产美女视频一区| 国产精品久久久久一区二区三区 | av不卡在线播放| 亚洲中国最大av网站| 这里只有精品视频在线观看| 久久99精品久久久久| 欧美韩国日本一区| 一本久道中文字幕精品亚洲嫩| 五月天激情小说综合| 欧美成人精品高清在线播放| 国产成人丝袜美腿| 一级做a爱片久久| 日韩一区二区免费电影| 国产成人欧美日韩在线电影| **欧美大码日韩| 制服.丝袜.亚洲.另类.中文| 国产高清在线精品| 亚洲青青青在线视频| 欧美日产国产精品| 国产精品一区二区男女羞羞无遮挡| 亚洲国产精品成人久久综合一区 | 久久精品一区四区| 一本久久综合亚洲鲁鲁五月天| 日本大胆欧美人术艺术动态| 国产日韩欧美在线一区| 欧美探花视频资源| 国产精选一区二区三区| 亚洲精品免费在线观看| 精品美女一区二区| 日本丶国产丶欧美色综合| 蜜臀av性久久久久蜜臀aⅴ| 亚洲国产精品99久久久久久久久| 欧美色视频一区| 国产精品伊人色| 亚洲成a人片在线不卡一二三区| 国产色91在线| 欧美妇女性影城| www.66久久| 久久成人av少妇免费| 亚洲欧洲另类国产综合| 日韩视频一区在线观看| 91麻豆国产在线观看| 国内精品久久久久影院色| 亚洲激情五月婷婷| 国产亚洲精久久久久久| 欧美高清视频在线高清观看mv色露露十八| 国产精品系列在线播放| 日韩电影在线观看电影| 亚洲精品中文在线影院| 中文字幕av一区二区三区| 日韩欧美国产精品| 欧美日韩一区二区电影|