chroot环境的快速构建
作者 佚名技术
来源 Linux系统
浏览
发布时间 2012-05-11
在配置linux服务器安全时,我们有时需要将一些服务放到chroot环境中运行.但共享库的依赖关系往往使管理员望而却步.我们可以通过一段shell脚本,帮助我们解决共享库的依赖关系,使chroot环境的配置变得迅速和简单. 我 们以构建bash的chroot环境为例子,当却少相应的共享库依赖关系时,chroot命令会报“cannot run command `/bin/bash'': No such file or directory”的这样一个错误.当依赖关系解决后就可以顺利的进入chroot环境. [root@Hafid tmp]# mkdir tmproot [root@Hafid tmp]# mkdir tmproot/bin [root@Hafid tmp]# cp -v /bin/bash tmproot/bin/ `/bin/bash'' -> `tmproot/bin/bash'' [root@Hafid tmp]# chroot tmproot/ chroot: cannot run command `/bin/bash'': No such file or directory [root@Hafid tmp]# ./create_lib.sh tmproot/ /lib/ld-linux.so.2 /lib/libc.so.6 /lib/libdl.so.2 /lib/libtermcap.so.2 mkdir: created directory `tmproot//lib'' `/lib/ld-linux.so.2'' -> `tmproot//lib/ld-linux.so.2'' `/lib/ld-2.5.so'' -> `tmproot//lib/ld-2.5.so'' `/lib/libc.so.6'' -> `tmproot//lib/libc.so.6'' `/lib/libc-2.5.so'' -> `tmproot//lib/libc-2.5.so'' `/lib/libdl.so.2'' -> `tmproot//lib/libdl.so.2'' `/lib/libdl-2.5.so'' -> `tmproot//lib/libdl-2.5.so'' `/lib/libtermcap.so.2'' -> `tmproot//lib/libtermcap.so.2'' `/lib/libtermcap.so.2.0.8'' -> `tmproot//lib/libtermcap.so.2.0.8'' Done! [root@Hafid tmp]# chroot tmproot/ bash-3.1# bash-3.1# bash-3.1# bash-3.1# exit exit [root@Hafid tmp]# create_lib.sh的代码如下: #!/bin/sh 拥有帝国一切,皆有可能。欢迎访问phome.net ROOT=$1 libs=`find $ROOT -type f -perm /111 -exec "ldd" {} ;|cut -d > -f 2|cut -d ( -f 1|sort |uniq` echo $libs for lib in $libs do if [ -f $lib ] ;then if [ ! -f $ROOT/$lib ] ;then dir=`dirname $ROOT$lib` if [ ! -d $dir ];then mkdir -pv $dir fi cp -av $lib $ROOT$lib if [ -h $lib ]; then source=`dirname $lib`/`readlink $lib` cp -av $source $ROOT$source #echo $source >> liblist fi fi fi done echo "Done!" 拥有帝国一切,皆有可能。欢迎访问phome.net |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |
你可能对下面的文章感兴趣
上一篇: 用shell用户或虚拟用户登录pureftpd下一篇: LVS配置指南
关于chroot环境的快速构建的所有评论