大神写的打包脚本
众所周知绿色软件是windows下的一个概念,指的是仅仅一个文件夹硬copy过来就可以运行的软件,卸载时也同理:删除这个文件夹即可。说白了就是不会向系统文件夹、注册表这些地方乱丢东西的软件。
Linux下安装软件通常是编译安装,不同发行版本也有自己的二进制安装包,例如RedHat的rpm、Ubuntu的deb等。安装的最终结果往往也是向/usr/bin, /usr/lib, /usr/sbin…等诸如此类的文件夹下放上自己需要的东东。二进制包安装的话,卸载起来倒是不麻烦,但如果你是编译安装,而想卸载时又搞丢了当时的Makefile文件,那就比较讨厌了。有方法可以制作类似于Winodws下的绿色软件包吗?
答案是肯定的。我们可以利用ldd来实现这样的功能。ldd会告诉我们对应二进制可执行程序所用到的共享库文件,我们要做的第一步是在已安装好完整应用的机器上把这些共享库文件拿到。第二步便可以在其他干净的机器上利用LD_LIBRARY_PATH指定运行软件时的动态库文件地址,运行对应的二进制程序。
这里我写了一个实现第一步的脚本:
这个脚本的接收二进制可执行程序的路径作为参数,利用ldd找到对应的so位置,并将它们连同二进制可执行程序本身拷贝到一个文件夹中。脚本正确执行完毕后,这个文件夹就可以拿到其他的干净的机器上运行了。
举个在CentOS5.3上的例子吧,例如我在A机器上已经编译安装(或者rpm 安装)好了ffmpeg。于是乎我就可以执行我的脚本fetchsofiles.sh,以/usr/bin/ffmpeg作为参数:
#!/bin/sh if [ $# -ne 1 ]; then echo "You should specify a dynamically executable file" exit 1 fi if [ ! -x $1 ]; then echo "You should specify a executable file" exit 1; fi path=$1 ############# check file type ############# result=$(ldd $path) filter=$(file $path|grep dynamically|grep executable) if [ -z "$filter" ]; then echo "$path is not a dynamically executable file!" file $path exit 1 fi ########### mkdir for .so files ############ packagename=$(basename $path)-pack mkdir -p $packagename IFS=" " ######### copy .so files ############ for line in $result; do sofile=notexitsfile if [ -z "$(echo $line | grep =)" ]; then sofile=$(echo $line | awk '{print $1}') else # has soft link sofile=$(echo $line | awk '{print $3}') fi if [ ! -f $sofile ]; then echo "ERROR FILE: $sofile" else echo "copying $sofile now..." cp $sofile $packagename fi done cp $path $packagename echo DONE
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了