linux dup2,linux版软件网站

大家好,如果您还对linux dup2不太了解,没有关系,今天就由本站为大家分享linux dup2的知识,包括linux版软件网站的问题都会给大家分析到,还望可以解决大家的问题,下面我们就开始吧!

在linux中移植嵌入式Boa服务器时出错

第一步完成Boa程序的移植。从www.boa.org下载Boa源码,当前最新版本为0.94.13,将其解压并进入源码目录的src子目录

# tar xzf boa-0.94.13.tar.gz

# cd boa-0.94.13/src

生成Makefile文件

#./configure

修改Makefile文件,找到CC=gcc,将其改成CC= arm-linux-gcc,再找到CPP= gcc–E,将其改成CPP= arm-linux-gcc–E,并保存退出。

然后运行make进行编译,得到的可执行程序为boa,将调试信息剥去,得到的最后程序只有约60KB大小。

# make

# arm-linux-strip boa

第二步完成Boa的配置,使其能够支持CGI程序的执行。Boa需要在/etc目录下建立一个boa目录,里面放入Boa的主要配置文件boa.conf。在Boa源码目录下已有一个示例boa.conf,可以在其基础上进行修改,下面解释一下该文件的含义:

#监听的端口号,缺省都是80,一般无需修改

Port 80

# bind调用的IP地址,一般注释掉,表明绑定到INADDR_ANY,通配于服务器的所有IP地址

#Listen 192.68.0.5

#作为哪个用户运行,即它拥有该用户的权限,一般都是nobody,需要/etc/passwd中有

#nobody用户

User nobody

#作为哪个用户组运行,即它拥有该用户组的权限,一般都是nogroup,需要在/etc/group文

#件中有nogroup组

Group nogroup

#当服务器发生问题时发送报警的email地址,目前未用,注释掉

#ServerAdmin root@localhost

#错误日志文件。如果没有以/开始,则表示从服务器的根路径开始。如果不需要错误日志,则用#/dev/null。在下面设置时,注意一定要建立/var/log/boa目录

ErrorLog/var/log/boa/error_log

#访问日志文件。如果没有以/开始,则表示从服务器的根路径开始。如果不需要错误日志,则用#/dev/null或直接注释掉。在下面设置时,注意一定要建立/var/log/boa目录

#AccessLog/var/log/boa/access_log

#是否使用本地时间。如果没有注释掉,则使用本地时间。注释掉则使用UTC时间

#UseLocaltime

#是否记录CGI运行信息,如果没有注释掉,则记录,注释掉则不记录

#VerboseCGILogs

#服务器名字

ServerName www.hyesco.com

#是否启动虚拟主机功能,即设备可以有多个网络接口,每个接口都可以拥有一个虚拟的Web服

#务器。一般注释掉,即不需要启动

#VirtualHost

#非常重要,HTML文档的主目录。如果没有以/开始,则表示从服务器的根路径开始。

DocumentRoot/var/www

#如果收到一个用户请求的话,在用户主目录后再增加的目录名

UserDir public_html

#HTML目录索引的文件名,也是没有用户只指明访问目录时返回的文件名

DirectoryIndex index.html

#当HTML目录没有索引文件时,用户只指明访问目录时,boa会调用该程序生成索引文件然后

#返回给用户,因为该过程比较慢最好不执行,可以注释掉或者给每个HTML目录加上#DirectoryIndex指明的文件

#DirectoryMaker/usr/lib/boa/boa_indexer

#如果DirectoryIndex不存在,并且DirectoryMaker被注释,那么就用Boa自带的索引

#生成程序来生成目录的索引文件并输出到下面目录,该目录必须是Boa能读写

# DirectoryCache/var/spool/boa/dircache

#一个连接所允许的HTTP持续作用请求最大数目,注释或设为0都将关闭HTTP持续作用

KeepAliveMax 1000

#HTTP持续作用中服务器在两次请求之间等待的时间数,以秒为单位,超时将关闭连接

KeepAliveTimeout 10

#指明mime.types文件位置。如果没有以/开始,则表示从服务器的根路径开始。可以注释掉

#避免使用mime.types文件,此时需要用AddType在本文件里指明

MimeTypes/etc/mime.types

#文件扩展名没有或未知的话,使用的缺省MIME类型

DefaultType text/plain

#提供CGI程序的PATH环境变量值

CGIPath/bin:/usr/bin:/usr/local/bin

#将文件扩展名和MIME类型关联起来,和mime.types文件作用一样。如果用mime.types

#文件,则注释掉,如果不使用mime.types文件,则必须使用

#AddType application/x-httpd-cgi cgi

#指明文档重定向路径

#Redirect/bar

#为路径加上别名

Alias/doc/usr/doc

#非常重要,指明CGI脚本的虚拟路径对应的实际路径。一般所有的CGI脚本都要放在实际路径

#里,用户访问执行时输入站点+虚拟路径+CGI脚本名

ScriptAlias/cgi-bin//var/www/cgi-bin/

用户可以根据自己需要,对boa.conf进行修改,但必须要保证其他的辅助文件和设置必须和boa.conf里的配置相符,不然Boa就不能正常工作。在上面的例子中,我们还需要创建日志文件所在目录/var/log/boa,创建HTML文档的主目录/var/www,将mime.types文件拷贝到/etc目录,创建CGI脚本所在目录/var/www/cgi-bin/。mime.types文件用来指明不同文件扩展名对应的MIME类型,一般可以直接从Linux主机上拷贝一个,大部分也都是在主机的/etc目录下。

Linux编程--文件原子操作

当多个进程同时访问一个文件的时候,普通的write/read在执行的时候,无法保证操作的原子性,可能会导致文件被污染,达不到预期的结果。

任何一个需要多个函数调用的操作都不可能是原子操作,因为在两个函数调用间,内核可能会将进程挂起执行另外的进程。

如果想要避免这种情况的话,则需要使用pread/pwrite函数

ssize_t pread(int fd,void*buffer,size_t size,off_t offset)

返回真正读取到的字节数,offset是指的从文件开始位置起的offset个字节数开始读。其余的参数与read无异。

PS:

pread是无法中断的原子操作,无法中断它的定位和读取操作

pread读取过后的文件偏移量不会发生改变

同理pwrite也是一样的

而在文件创建的时候也是一样的,当需要做文件创建同步的时候,我们需要在O_CREATE的时候,加上O_EXCL标志位,当已经创建过的话,会返回fd,否则返回错误

int dup( int filedes):

传入一个文件描述符,返回当前可用的最小文件描述符。

int dup2(int filedes,int filedes2):

传入文件描述符,以及新的文件描述符,如果新的文件描述符所指向的文件已经打开,则会强行将其关闭后,将该文件描述符指向到已存在的文件描述符。

如果filedes和filedes2指向同一个文件,则不做任何处理,直接返回filedes2,不会关闭文件

新返回回来的filedes2会共享filedes的文件状态标识,文件偏移量等等信息。因为它们的文件指针会指向文件表的同一个位置。只是fd不一样而已。

shell程序中2>/dev/null代表什么意思

学习没有捷径,速成往往只是暂时的。在理解命令"2>/dev/null"之前,你实际上已经绕过了多个关联知识点。

首先,让我们回到基础概念:File descriptor(简称fd)。这个概念在类Unix系统中,包括Linux系统中非常关键。你可能在学习编程语言如C语言时首次接触到它,或是通过《深入理解Linux内核》一书。文件描述符实际是一个整数,它用于追踪系统中打开的文件或其他资源。

每个进程都有一个fdtable,其中文件描述符作为索引值,关联着打开的文件和系统信息。当打开一个文件时,系统创建文件描述符、关联数据,并将索引值返回给你。通常,文件描述符与文件之间没有必然联系,但三个特殊值(0, 1, 2)固定对应标准输入(stdin)、标准输出(stdout)和标准错误(stderr)。

标准输入、输出和错误在现代计算机上抽象为操作终端,键盘输入为stdin,显示器输出为stdout,而stderr是独立的错误输出流。在交互式shell中,它们可能都指向字符终端,实现输入、输出。

重定向是Shell(如bash)的概念,它允许你改变文件描述符的源点或目标。例如,你可以将输入流重定向到文件,或输出流重定向到文件或设备。这通常通过命令语法完成,如将"1>ofile"用于重定向标准输出。

在Linux系统中,重定向操作主要依赖于dup()和dup2()系统调用,用于复制或覆盖文件描述符,从而实现重定向。dup()创建文件描述符的副本,而dup2()将一个文件描述符覆盖到另一个上,同时关闭被覆盖的文件描述符。

最后,关于"2>/dev/null",它意味着将标准错误重定向到名为/dev/null的特殊设备。这个设备几乎不改变数据,即写入数据后返回成功,但实际上数据被丢弃。这在编程中用于捕获错误输出,避免它们污染程序日志。

理解这些概念和系统调用,不仅有助于正确使用命令,还能深入理解Linux内核的工作原理。记住,深入理解背后的原理是提高编程能力的关键,而不仅仅是执行命令。

阅读剩余
THE END