当前位置: 首页 > news >正文

做资讯网站网站优化包括哪些内容

做资讯网站,网站优化包括哪些内容,二极管 东莞网站建设,企业免费自助建站系统一、单循环服务器模型 1. 核心特征 while(1){newfd accept();recv();close(newfd);}2. 典型应用场景 HTTP短连接服务#xff08;早期Apache#xff09;CGI快速处理简单测试服务器 3. 综合代码 #include stdio.h #include sys/types.h /* See NO…一、单循环服务器模型 1. 核心特征 while(1){newfd accept();recv();close(newfd);}2. 典型应用场景 HTTP短连接服务早期ApacheCGI快速处理简单测试服务器 3. 综合代码 #include stdio.h #include sys/types.h /* See NOTES */ #include sys/socket.h #include netinet/in.h #include netinet/ip.h /* superset of previous */ #include arpa/inet.h #include strings.h #include unistd.h #include stdlib.h #include string.hint main(int argc, const char *argv[]) {if (argc ! 3){printf(Usage: %s port ip\n,argv[0]);return -1;}//1.socket 创建通信一端 int fd socket(AF_INET,SOCK_STREAM,0);if (fd 0){perror(socket fail\n);return -1;}struct sockaddr_in seraddr;bzero(seraddr,sizeof(seraddr));seraddr.sin_family AF_INET;seraddr.sin_port htons(atoi(argv[1]));seraddr.sin_addr.s_addr inet_addr(argv[2]);printf(fd %d\n,fd);//2.bind -- 绑定服务器端的地址信息 if (bind(fd,(const struct sockaddr*)seraddr,sizeof(seraddr)) 0){perror(connect fail);return -1;}printf(connect success!\n);//3.listen -- 设置监听 if (listen(fd,5) 0){perror(listen fail);return -1;}while (1){//4.acceptint connfd accept(fd,NULL,NULL);if (connfd 0){perror(accept fail);return -1;}printf(----client --- connectted\n);char buf[1024];char sbuf[1024];while (1){recv(connfd,buf,sizeof(buf),0);printf(c: %s\n,buf);if (strncmp(buf,quit,4) 0){close(connfd);break;}sprintf(sbuf,server %s\n,buf);send(connfd,sbuf,strlen(sbuf)1,0);}}close(fd);return 0; }4. 优缺点分析 优点缺点实现简单无法处理并发请求无资源竞争问题长连接会阻塞后续请求适合低负载场景吞吐量低QPS 100 二、多进程并发模型 1. 核心实现 while(1) {int newfd accept(listen_fd, ...);pid_t pid fork();if (pid 0) { // 子进程close(listen_fd);handle_connection(newfd);close(newfd);exit(0);} else if (pid 0) { // 父进程close(newfd);waitpid(-1, NULL, WNOHANG); // 非阻塞回收} }2. 进程管理优化 // 使用信号处理避免僵尸进程 signal(SIGCHLD, SIG_IGN); // 忽略子进程结束信号// 或使用waitpid循环 while (waitpid(-1, NULL, WNOHANG) 0);3. 典型应用 传统Apache的prefork模式FTP服务器数据库连接池 4. 资源消耗对比 资源类型进程创建开销示例系统调用内存需要复制整个PCBfork()CPU上下文切换成本高schedule()文件描述符需要显式关闭继承的fdclose() 5. 优缺点分析 优点缺点可以完成多个进程的实时交互回收资源不方便信息的完整性可以保证。每次fork 占用系统资源多适合低负载场景可能出现僵尸进程 6. 综合代码 #include stdio.h #include sys/types.h /* See NOTES */ #include sys/socket.h #include netinet/in.h #include netinet/ip.h /* superset of previous */ #include arpa/inet.h #include strings.h #include unistd.h #include stdlib.h #include string.h #include signal.h #include sys/wait.hvoid handler(int signo) {wait(NULL); }int init_server(const char *ip,unsigned short port) {//1.socket 创建通信一端 int fd socket(AF_INET,SOCK_STREAM,0);if (fd 0){perror(socket fail\n);return -1;}struct sockaddr_in seraddr;bzero(seraddr,sizeof(seraddr));seraddr.sin_family AF_INET;seraddr.sin_port htons(port);seraddr.sin_addr.s_addr inet_addr(ip);//2.bind -- 绑定服务器端的地址信息 if (bind(fd,(const struct sockaddr*)seraddr,sizeof(seraddr)) 0){perror(connect fail);return -1;}//3.listen -- 设置监听 if (listen(fd,5) 0){perror(listen fail);return -1;}return fd; }int client_handler(int connfd) {char buf[1024];char sbuf[1024];int ret 0;while (1){ret recv(connfd,buf,sizeof(buf),0);if (ret 0){perror(client_handler recv fail);ret -1;}printf(c: %s\n,buf);if (strncmp(buf,quit,4) 0){close(connfd);ret 1;break;}sprintf(sbuf,server %s\n,buf);ret send(connfd,sbuf,strlen(sbuf)1,0);if (ret 0){perror(client_handler send fail);ret -1;}}return ret;}int main(int argc, const char *argv[]) {if (argc ! 3){printf(Usage: %s ip port\n,argv[0]);return -1;}signal(SIGCHLD,handler);int fd init_server(argv[1],atoi(argv[2]));if (fd 0){printf(init_server fail\n);return -1;}while (1){//4.acceptint connfd accept(fd,NULL,NULL);if (connfd 0){perror(accept fail);return -1;}pid_t pid fork();if (pid 0){perror(fork fail);return -1;}if (pid 0){int ret 0;if ((ret client_handler(connfd)) 0){printf(client_handler fail);return -1;}if (ret 1){printf(child exit...\n);exit(EXIT_SUCCESS);}}}close(fd);return 0; }三、多线程并发模型 1. 核心实现POSIX线程 while(1) {int newfd accept(listen_fd, ...);pthread_t tid;pthread_create(tid, NULL, thread_handler, (void*)newfd);pthread_detach(tid); // 分离线程自动回收 }void* thread_handler(void* arg) {int fd (int)arg;// 处理请求close(fd);return NULL; }2. 线程安全控制 // 使用互斥锁保护共享资源 pthread_mutex_t lock PTHREAD_MUTEX_INITIALIZER;void safe_write(int fd, const char* data) {pthread_mutex_lock(lock);write(fd, data, strlen(data));pthread_mutex_unlock(lock); }3. 典型应用 Java TomcatIIS应用池实时通信服务器 4. 性能指标对比 指标进程模型线程模型创建速度慢10-100ms快0.1-1ms上下文切换成本高切换页表等低共享地址空间内存占用高独立资源低共享资源 5. 优缺点分析 优点缺点可以完成多个进程的实时交互线程共享进程资源创建速度快调度快稳定性 较差适合低负载场景安全性 较差  6. 综合代码 #include stdio.h #include pthread.h #include sys/types.h /* See NOTES */ #include sys/socket.h #include netinet/in.h #include netinet/ip.h /* superset of previous */ #include arpa/inet.h #include strings.h #include unistd.h #include stdlib.h #include string.h #include signal.h #include sys/wait.h #include errno.hint init_server(const char *ip,unsigned short port) {//1.socket 创建通信一端 int fd socket(AF_INET,SOCK_STREAM,0);if (fd 0){perror(socket fail\n);return -1;}struct sockaddr_in seraddr;bzero(seraddr,sizeof(seraddr));seraddr.sin_family AF_INET;seraddr.sin_port htons(port);seraddr.sin_addr.s_addr inet_addr(ip);//2.bind -- 绑定服务器端的地址信息 if (bind(fd,(const struct sockaddr*)seraddr,sizeof(seraddr)) 0){perror(connect fail);return -1;}//3.listen -- 设置监听 if (listen(fd,5) 0){perror(listen fail);return -1;}return fd; }void* client_handler(void *arg) {int connfd *(int *)arg;char buf[1024];char sbuf[1024];long int ret 0;while (1){ret recv(connfd,buf,sizeof(buf),0);if (ret 0){perror(client_handler recv fail);ret -1;}printf(c: %s\n,buf);if (strncmp(buf,quit,4) 0){close(connfd);ret 1;break;}sprintf(sbuf,server %s\n,buf);ret send(connfd,sbuf,strlen(sbuf)1,0);if (ret 0){perror(client_handler send fail);ret -1;}}return (void*)ret;}int main(int argc, const char *argv[]) {if (argc ! 3){printf(Usage: %s ip port\n,argv[0]);return -1;}int fd init_server(argv[1],atoi(argv[2]));if (fd 0){printf(init_server fail\n);return -1;}while (1){//4.acceptint connfd accept(fd,NULL,NULL);if (connfd 0){perror(accept fail);return -1;}pthread_t tid;int ret pthread_create(tid,NULL,client_handler,connfd);if(ret ! 0){errno ret;perror(pthread_create fail);return -1;}pthread_detach(tid);//设置分离属性,由系统回收资源}close(fd);return 0; }四、并发的服务器模型 ---更高程度上的并发  一fcntl 函数与 I/O 模型详解 1. 函数原型 #include unistd.h #include fcntl.hint fcntl(int fd, int cmd, ... /* arg */ );2. 主要操作类型 命令功能描述参数要求F_DUPFD复制文件描述符指定最小可用fd值F_GETFD/F_SETFD获取/设置文件描述符标志标志值F_GETFL/F_SETFL获取/设置文件状态标志新标志值F_GETOWN/F_SETOWN获取/设置异步I/O所有权进程ID或组ID 二非阻塞I/O设置示例 1. 设置流程 int flag fcntl(connfd,F_GETFL,0);flag flag | O_NONBLOCK;fcntl(connfd,F_SETFL,flag); 2. 行为变化对比 操作阻塞模式非阻塞模式read()阻塞直到数据到达立即返回无数据时返回EAGAINwrite()阻塞直到缓冲区空间可用立即返回空间不足返回EAGAINaccept()阻塞直到有新连接立即返回无连接时返回EAGAIN 三I/O 模型对比 1. 阻塞I/O模型 2. 非阻塞I/O模型 #include stdio.h #include sys/types.h /* See NOTES */ #include sys/socket.h #include netinet/in.h #include netinet/ip.h /* superset of previous */ #include arpa/inet.h #include strings.h #include unistd.h #include stdlib.h #include string.h#include fcntl.h int main(int argc, const char *argv[]) {if (argc ! 3){printf(Usage: %s port ip\n,argv[0]);return -1;}//1.socket 创建通信一端 int fd socket(AF_INET,SOCK_STREAM,0);if (fd 0){perror(socket fail\n);return -1;}struct sockaddr_in seraddr;bzero(seraddr,sizeof(seraddr));seraddr.sin_family AF_INET;seraddr.sin_port htons(atoi(argv[1]));seraddr.sin_addr.s_addr inet_addr(argv[2]);printf(fd %d\n,fd);//2.bind -- 绑定服务器端的地址信息 if (bind(fd,(const struct sockaddr*)seraddr,sizeof(seraddr)) 0){perror(connect fail);return -1;}printf(connect success!\n);//3.listen -- 设置监听 if (listen(fd,5) 0){perror(listen fail);return -1;}while (1){//4.acceptint connfd accept(fd,NULL,NULL);if (connfd 0){perror(accept fail);return -1;}printf(----client --- connectted\n);char buf[1024];char sbuf[1024];int flag fcntl(connfd,F_GETFL,0);flag flag | O_NONBLOCK;fcntl(connfd,F_SETFL,flag);while (1){recv(connfd,buf,sizeof(buf),0);printf(c: %s\n,buf);if (strncmp(buf,quit,4) 0){close(connfd);break;}sprintf(sbuf,server %s\n,buf);send(connfd,sbuf,strlen(sbuf)1,0);}}close(fd);return 0; }四信号驱动 I/O 详解 1. 设置异步标志 // 获取当前文件状态标志 int flags fcntl(fd, F_GETFL); if (flags -1) {perror(fcntl F_GETFL);exit(EXIT_FAILURE); }// 添加异步I/O标志 if (fcntl(fd, F_SETFL, flags | O_ASYNC) -1) {perror(fcntl F_SETFL);exit(EXIT_FAILURE); }2. 指定信号接收者 // 设置当前进程为信号接收者 if (fcntl(fd, F_SETOWN, getpid()) -1) {perror(fcntl F_SETOWN);exit(EXIT_FAILURE); }3. 注册信号处理函数 // 更安全的sigaction替代signal struct sigaction sa; sa.sa_flags SA_RESTART; sa.sa_handler sigio_handler; sigemptyset(sa.sa_mask);if (sigaction(SIGIO, sa, NULL) -1) {perror(sigaction);exit(EXIT_FAILURE); }4. 基本处理逻辑 #include stdio.h #include sys/types.h #include sys/stat.h #include fcntl.h #include unistd.h #include errno.h #include string.h #include signal.hint g_fd;void handler(int signo) {char buf[1024];read(g_fd,buf,sizeof(buf));if (strncmp(buf,quit,4) 0)return;printf(buf %s\n,buf);}int main(int argc, const char *argv[]) {if (mkfifo(argv[1],0666) 0 errno ! EEXIST){perror(mkfifo fail);return -1;}printf(mkfifo success\n);int fd open(argv[1], O_RDONLY);if (fd 0){perror(open fail);return -1;}g_fd fd;int flag fcntl(fd,F_GETFL,0);flag flag | O_ASYNC;//设置为异步通信fcntl(fd,F_SETFL,flag);fcntl(fd,F_SETOWN,getpid());//所有者signal(SIGIO,handler);int i 0;while (1){printf(i %d\n,i);sleep(1);i;}close(fd);return 0; }5.核心局限性分析 问题类型具体表现解决思路信号合并快速连续信号可能被合并使用实时信号SIGRTMIN多fd区分困难无法直接判断哪个fd触发信号每个fd绑定不同信号不现实异步安全限制信号处理函数中操作受限仅设置标志主循环处理性能瓶颈高频率信号导致CPU占用高配合epoll使用 五select 函数详解 一、函数原型与参数解析 #include sys/select.hint select(int nfds, fd_set *readfds, fd_set *writefds,fd_set *exceptfds, struct timeval *timeout);参数说明 参数类型说明nfdsint监控的文件描述符最大值 1优化内核检查范围readfdsfd_set*监控可读事件的描述符集合可NULLwritefdsfd_set*监控可写事件的描述符集合可NULLexceptfdsfd_set*监控异常事件的描述符集合可NULLtimeouttimeval*超时时间br• NULL阻塞等待br• 0立即返回br• 正数定时等待 返回值 成功返回就绪的文件描述符总数可能为0失败返回-1并设置errno超时返回0 二、核心操作宏 宏功能示例FD_ZERO清空描述符集合FD_ZERO(read_fds);FD_SET添加描述符到集合FD_SET(sockfd, read_fds);FD_CLR从集合中移除描述符FD_CLR(sockfd, read_fds);FD_ISSET检测描述符是否在集合中if(FD_ISSET(sockfd, read_fds)) 三、典型使用流程 1. 初始化描述符集合 fd_set read_fds; FD_ZERO(read_fds); FD_SET(listen_fd, read_fds); int max_fd listen_fd;2. 等待事件就绪 struct timeval tv {5, 0}; // 5秒超时 fd_set tmp_fds read_fds;int ready select(max_fd 1, tmp_fds, NULL, NULL, tv); if (ready -1) {if (errno EINTR) continue; // 处理信号中断perror(select error);break; } else if (ready 0) {printf(Timeout\n);continue; }3. 处理就绪事件 for (int fd 0; fd max_fd; fd) {if (FD_ISSET(fd, tmp_fds)) {if (fd listen_fd) {// 处理新连接int new_fd accept(listen_fd, ...);FD_SET(new_fd, read_fds);max_fd (new_fd max_fd) ? new_fd : max_fd;} else {// 处理客户端数据ssize_t n read(fd, ...);if (n 0) {close(fd);FD_CLR(fd, read_fds);}}} }四、关键注意事项 集合重用问题 select返回后集合会被修改为就绪的fd集合每次调用前必须重新初始化 fd_set tmp_fds read_fds; // 使用临时集合超时时间重置 timeout参数会被修改为剩余时间循环调用时需要重新设置 struct timeval tv {5, 0}; while(1) {select(..., tv);tv.tv_sec 5; // 必须重置 }最大fd限制 受FD_SETSIZE限制通常1024超出会导致未定义行为 性能问题 每次调用需要从用户态复制整个fd_set到内核态时间复杂度O(n) #include stdio.h #include sys/types.h #include sys/stat.h #include fcntl.h #include unistd.h #include errno.h #include string.h int main(int argc, const char *argv[]) {if (mkfifo(argv[1],0666) 0 errno ! EEXIST){perror(mkfifo fail);return -1;}printf(mkfifo success\n);int fd open(argv[1], O_RDONLY);if (fd 0){perror(open fail);return -1;}char buf[1024] {0};//1.建表fd_set readfds;FD_ZERO(readfds);//2.添加要关心的fdFD_SET(0,readfds);FD_SET(fd,readfds);//3.select函数监控fd_set backfds;struct timeval tv {5,0};while(1){backfds readfds;//每次循环回来拿到的都是最原始数据int nfds fd 1;//因为另一个是0,所以最大也就是int ret select(nfds,backfds,NULL,NULL,tv);if(ret 0){perror(select fail);return -1;}if(ret 0){for(int i 0;i nfds;i)//也可以是1024,但没必要 {if(FD_ISSET(i,backfds)){if(i 0){fgets(buf,sizeof(buf),stdin);if (strncmp(buf,quit,4) 0)break;printf(buf %s\n,buf);}else if(i fd){read(fd,buf,sizeof(buf));if (strncmp(buf,quit,4) 0)break;printf(buf %s\n,buf);}}}}}close(fd);return 0; }可以从客户端读取数据也可以自身从键盘输入 tcp多客户端连接到服务器 #include stdio.h #include sys/types.h /* See NOTES */ #include sys/socket.h #include netinet/in.h #include netinet/ip.h /* superset of previous */ #include arpa/inet.h #include strings.h #include unistd.h #include stdlib.h #include string.h #include sys/select.hint main(int argc, const char *argv[]) {if (argc ! 3){printf(Usage: %s port ip\n,argv[0]);return -1;}//1.socket 创建通信一端 int fd socket(AF_INET,SOCK_STREAM,0);if (fd 0){perror(socket fail\n);return -1;}struct sockaddr_in seraddr;bzero(seraddr,sizeof(seraddr));seraddr.sin_family AF_INET;seraddr.sin_port htons(atoi(argv[1]));seraddr.sin_addr.s_addr inet_addr(argv[2]);printf(fd %d\n,fd);//2.bind -- 绑定服务器端的地址信息 if (bind(fd,(const struct sockaddr*)seraddr,sizeof(seraddr)) 0){perror(connect fail);return -1;}printf(connect success!\n);//3.listen -- 设置监听 if (listen(fd,5) 0){perror(listen fail);return -1;}//1.准备表 fd_set readfds;FD_ZERO(readfds);//2.添加要监控的fdFD_SET(fd,readfds);int connfd 0;fd_set backfds;int i 0;int nfds fd 1;while (1){backfds readfds;int ret select(nfds,backfds,NULL,NULL,NULL);if (ret 0){perror(select fail);return -1;}if (ret 0){for (i 0; i nfds; i){if (FD_ISSET(i,backfds)){if (i fd){//4.acceptconnfd accept(fd,NULL,NULL);if (connfd 0){perror(accept fail);return -1;}FD_SET(connfd,readfds);nfds nfds connfd 1 ? nfds:connfd 1;}else {char buf[1024];char sbuf[1024];recv(i,buf,sizeof(buf),0);printf(c: %s\n,buf);if (strncmp(buf,quit,4) 0){ close(i);FD_CLR(i,readfds); }sprintf(sbuf,server %s\n,buf);send(i,sbuf,strlen(sbuf)1,0);}}}}}close(fd);return 0; }并发模型对比 模型实现方式优点缺点多进程fork()隔离性好资源消耗大多线程pthread_create()资源共享高效同步复杂度高I/O多路复用select/poll/epoll高并发低开销编程复杂度较高信号驱动SIGIOfcntl实时性好信号处理复杂异步I/Oaio_*系列函数真正的异步操作系统支持不统一
文章转载自:
http://www.morning.elsemon.com.gov.cn.elsemon.com
http://www.morning.zsthg.cn.gov.cn.zsthg.cn
http://www.morning.3ox8hs.cn.gov.cn.3ox8hs.cn
http://www.morning.pkrb.cn.gov.cn.pkrb.cn
http://www.morning.yesidu.com.gov.cn.yesidu.com
http://www.morning.rzczl.cn.gov.cn.rzczl.cn
http://www.morning.dtzsm.cn.gov.cn.dtzsm.cn
http://www.morning.xbxks.cn.gov.cn.xbxks.cn
http://www.morning.nzsx.cn.gov.cn.nzsx.cn
http://www.morning.jmmzt.cn.gov.cn.jmmzt.cn
http://www.morning.ypwlb.cn.gov.cn.ypwlb.cn
http://www.morning.nzlqt.cn.gov.cn.nzlqt.cn
http://www.morning.fzlk.cn.gov.cn.fzlk.cn
http://www.morning.qdlr.cn.gov.cn.qdlr.cn
http://www.morning.xkwrb.cn.gov.cn.xkwrb.cn
http://www.morning.skrrq.cn.gov.cn.skrrq.cn
http://www.morning.qnpyz.cn.gov.cn.qnpyz.cn
http://www.morning.rcttz.cn.gov.cn.rcttz.cn
http://www.morning.hhpkb.cn.gov.cn.hhpkb.cn
http://www.morning.jjxnp.cn.gov.cn.jjxnp.cn
http://www.morning.fbbmg.cn.gov.cn.fbbmg.cn
http://www.morning.kjxgc.cn.gov.cn.kjxgc.cn
http://www.morning.rnqbn.cn.gov.cn.rnqbn.cn
http://www.morning.ttdbr.cn.gov.cn.ttdbr.cn
http://www.morning.tcxk.cn.gov.cn.tcxk.cn
http://www.morning.cybch.cn.gov.cn.cybch.cn
http://www.morning.bpmfl.cn.gov.cn.bpmfl.cn
http://www.morning.ckctj.cn.gov.cn.ckctj.cn
http://www.morning.xhftj.cn.gov.cn.xhftj.cn
http://www.morning.fjtnh.cn.gov.cn.fjtnh.cn
http://www.morning.wgdnd.cn.gov.cn.wgdnd.cn
http://www.morning.tjcgl.cn.gov.cn.tjcgl.cn
http://www.morning.bnkcl.cn.gov.cn.bnkcl.cn
http://www.morning.kdxzy.cn.gov.cn.kdxzy.cn
http://www.morning.ztcwp.cn.gov.cn.ztcwp.cn
http://www.morning.cfynn.cn.gov.cn.cfynn.cn
http://www.morning.wjyyg.cn.gov.cn.wjyyg.cn
http://www.morning.jbpodhb.cn.gov.cn.jbpodhb.cn
http://www.morning.demoux.com.gov.cn.demoux.com
http://www.morning.kqrql.cn.gov.cn.kqrql.cn
http://www.morning.xqnzn.cn.gov.cn.xqnzn.cn
http://www.morning.buyid.com.cn.gov.cn.buyid.com.cn
http://www.morning.dzfwb.cn.gov.cn.dzfwb.cn
http://www.morning.cyfsl.cn.gov.cn.cyfsl.cn
http://www.morning.wgdnd.cn.gov.cn.wgdnd.cn
http://www.morning.irqlul.cn.gov.cn.irqlul.cn
http://www.morning.lrplh.cn.gov.cn.lrplh.cn
http://www.morning.hhxkl.cn.gov.cn.hhxkl.cn
http://www.morning.tgmwy.cn.gov.cn.tgmwy.cn
http://www.morning.wrlxt.cn.gov.cn.wrlxt.cn
http://www.morning.qwmpn.cn.gov.cn.qwmpn.cn
http://www.morning.kghhl.cn.gov.cn.kghhl.cn
http://www.morning.bfybb.cn.gov.cn.bfybb.cn
http://www.morning.tgpgx.cn.gov.cn.tgpgx.cn
http://www.morning.rfkyb.cn.gov.cn.rfkyb.cn
http://www.morning.lanyee.com.cn.gov.cn.lanyee.com.cn
http://www.morning.wkcl.cn.gov.cn.wkcl.cn
http://www.morning.xxfxxf.cn.gov.cn.xxfxxf.cn
http://www.morning.syqtt.cn.gov.cn.syqtt.cn
http://www.morning.jhxtm.cn.gov.cn.jhxtm.cn
http://www.morning.fmry.cn.gov.cn.fmry.cn
http://www.morning.bmqls.cn.gov.cn.bmqls.cn
http://www.morning.incmt.com.gov.cn.incmt.com
http://www.morning.bwmm.cn.gov.cn.bwmm.cn
http://www.morning.rdsst.cn.gov.cn.rdsst.cn
http://www.morning.wmmjw.cn.gov.cn.wmmjw.cn
http://www.morning.qhrlb.cn.gov.cn.qhrlb.cn
http://www.morning.wnhml.cn.gov.cn.wnhml.cn
http://www.morning.fcpjq.cn.gov.cn.fcpjq.cn
http://www.morning.qgjp.cn.gov.cn.qgjp.cn
http://www.morning.kltmt.cn.gov.cn.kltmt.cn
http://www.morning.bssjz.cn.gov.cn.bssjz.cn
http://www.morning.msfqt.cn.gov.cn.msfqt.cn
http://www.morning.znsyn.cn.gov.cn.znsyn.cn
http://www.morning.gkmwk.cn.gov.cn.gkmwk.cn
http://www.morning.knryp.cn.gov.cn.knryp.cn
http://www.morning.wypyl.cn.gov.cn.wypyl.cn
http://www.morning.dwxqf.cn.gov.cn.dwxqf.cn
http://www.morning.jyknk.cn.gov.cn.jyknk.cn
http://www.morning.rcklc.cn.gov.cn.rcklc.cn
http://www.tj-hxxt.cn/news/241476.html

相关文章:

  • 上市公司网站建设报价腾讯云建wordpress
  • 企业网站制作模板闵行10路
  • 网站怎么开发代码怎样提高网站的打开速度
  • 建设京东类的网站需要什么流程图网络推广工具有哪些
  • 东莞网上做公司网站有哪些新手做外链的网站
  • 建设银行北京市分行网站wordpress长文章分页插件
  • 站点地址和wordpress区别推广普通话作文300字
  • 郑州市汉狮做网站wordpress特定用户特定分类
  • 网站的栏目关键词北京设计院排名100强
  • 网站建设推广费会计分录广州网站推广建设
  • 马云为什么做网站网站优化合同
  • 茂港手机网站建设公司自己做的网站打开太慢
  • 如何给自己的网站做优化桂林创新大厦网站
  • php网站开发核心技术wordpress图片像素
  • 网站建设包括两个方面东营最新通知
  • 百度网站官网网址手机怎么建立网站
  • 佛山网站关键词优化公司制作企业网站的流程
  • 商务网站建设组成包括网站优化ceac网页设计师
  • 黑白网站设计广州建设集团股份有限公司
  • 不付费免费网站wordpress分类随机文章
  • 高科技公司网站模板建设网站广州
  • 织梦网站模板官网券商 做网站
  • 成品网站设计网站广东网站设计公司价格
  • 网络服务器与网站建设有创意营销型网站建设
  • 安陆市城乡建设局网站wordpress阿里云oss插件
  • 网站建设费属于广告费用吗怎么通过ip查看自己做的网站
  • 台州免费自助建站模板个人网站效果图
  • 免费分站网站优化方案语文
  • 北京市网站制作做ppt模板的网站
  • 个人网站的设计与制作论文承德专业做网站的公司