libyaml源代码在linux下解压、安装及试用
简简单单说明下:由于这几天项目需要调查YAML格式,所以我找了很多相关的信息,在忙中匆忙写了这篇文章,不足之处愿与您一起来检讨(回钦波 QQ:444084929)
应用场合举例
由于libyaml包的权限是MIT权限,所以我们可以进行个人及商业使用。。。。
所以做为用户我们可以重新配置、自由修改源代码,加入新的功能
源代码包发布格式
libyaml 封包:
.tar.gz 和 .tar.bz2 格式居多
md5sum校验工具
计算MD5校验和,并与官方提供的值相比较,判断是否一致
源码编译安装的基本过程
解包 —— tar
解包、释放出源代码文件
配置 —— ./configure
针对当前系统、软件环境,配置好安装参数
编译 —— make
将源代码文件变为二进制的可执行程序
安装 —— make install
将编译好的程序文件复制到系统中
确认源代码编译环境
需安装支持 C/C++程序语言的 编译器
一步步安装介绍:
解压源代码包
tar –zxf 命令解压以.tar.gz结尾的源代码包
tar -jxf命令解压以.tar.bz2结尾的源代码包
参数-C 解压到指定目录
说明:我个人是在WONDOWS XP 下解压的,然后传到了Linux上
需将工作目录切换到软件源码所在目录
使用源码目录中的 configure 脚本
注:当时我运行./configure 时总报:
-bash: ./configure: No such file or directory
这个错误,后来才发现是我没有权限导致的,那我来给它设置一个高权限就OK了
chmode a+x configure
即可!!
执行“./configure --help” 可以查看帮助
典型的配置选项:
--prefix=软件安装目录 (若不指定任何配置选项,将采用默认值)编译
执行 make 命令安装
执行 make install 命令
可用命令make ;make install将2个命令一起执行,意思是先执行make,执行成功后再执行make install
一般编译安装需要执行3、4分钟,请耐心等待!
--------------------------------------------结束------------------------------------------------------------
离下班还有点时间,我再来说下权限的事情吧:
刚才上面提到过,当我执行./configure时总是报错误,后来查明是权限不够,那么除了我用a+x来设置权限还有没有其它方式呢?或者来说a代表什么意思呢 +又代表什么意思呢?x又代表什么呢?
让我们带着这样的疑问来看下面的解释。
这里涉及到CHMOD命令的解释,
使用的口令是 chmod a+x 文件名
who 用户类型 说明
u
user
文件所有者
g
group
文件所有者所在组
o
others
所有其他用户
a
all
所用用户, 相当于 ugo
operator的符号模式表:
Operator 说明
+
为指定的用户类型增加权限
-
去除指定用户类型的权限
=
设置指定用户权限的设置,即将用户类型的所有权限重新设置
permission的符号模式表:
模式 名字 说明
r
读
设置为可读权限
w
写
设置为可写权限
x
执行权限
设置为可执行权限
X
特殊执行权限
只有当文件为目录文件,或者其他类型的用户有可执行权限时,才将文件权限设置可执行
s
setuid/gid
当文件被执行时,根据who参数指定的用户类型设置文件的setuid或者setgid权限
t
粘贴位
设置粘贴位,只有超级用户可以设置该位,只有文件所有者u可以使用该位
如果你还有时间,参照下我从网站找的有关例子:
符号模式实例
对目录的所有者u和关联组g增加读r和写w权限:
$ chmod ug+rw mydir $ ls -ld mydir drw-rw---- 2 unixguy uguys 96 Dec 8 12:53 mydir
对文件的所有用户ugo删除写w权限:
$ chmod a-w myfile $ ls -l myfile -r-xr-xr-x 2 unixguy uguys 96 Dec 8 12:53 myfile
对mydir的所有者u和关联组g设置成读r和可执行x权限:
$ chmod ug=rx mydir $ ls -ld mydir dr-xr-x--- 2 unixguy uguys 96 Dec 8 12:53 mydir
命令使用实例
命令
说明
chmod a+r file
增加读权限对file的所有用户
chmod a-x file
删除执行权限对file的所有用户
chmod a+rw file
增加读写权限对file的所有用户
chmod +rwx file
增加读写执行权限对file的所有用户
chmod u=rw,go= file
设置读写权限对file的所有者,清空所有权限对file的用户组和其他用户
chmod -R u+r,go-r docs
对目录docs和其子目录层次结构中的所有文件增加所有用户的读权限,而对用户组和其他用户删除读权限
chmod 664 file
设置读写权限对file的所有者和用户组, 为其其他用户设置读权限
chmod 0755 file
相当于u=rwx (4+2+1),go=rx (4+1 & 4+1)。0 没有特殊模式。
chmod 4755 file
4设置了设置用户ID位,剩下的相当于 u=rwx (4+2+1),go=rx (4+1 & 4+1)。
find path/ -type d -exec chmod a-x {} \;
删除可执行权限对path/以及其所有的目录(不包括文件)的所有用户,使用‘-type f'匹配文件
find path/ -type d -exec chmod a+x {} \;
允许所有用户浏览或通过目录path/
好了先写到这里。
更多交流、更多了解:
qq:444084929 (回钦波)