轻松实现源码打包安装[原创]

通常我们在Linux/Unix下安装一平台时往往需要十几甚至更多安装包,这些源码包来源于网络、本地硬盘、移动设备。有时碰到网络不畅通或下载地址失效会带来很多麻烦,一个好方法便是将常用的软件包下载到本地硬盘存放。问题是久而久之连自己都不晓得哪些包才是适用的。现用makeself来实现自解压倒安装倒是一个很好的解决方案,下面以制作Func客户端安装包为例。

一、整理软件包

#cd /home
#mkdir FuncPack1.0
将所需的软件包都往FuncPack1.0目录丢:)
#ls FuncPack1.0
-rw-r--r-- 1 root root    50878 Sep 28  2009 certmaster-0.25.tar.gz
-rw-r--r-- 1 root root      249 Oct  8  2009 certmaster.conf
-rw-r--r-- 1 root root   152871 Sep 28  2009 func-0.25.tar.gz
-rw-r--r-- 1 root root      137 Oct  8  2009 minion.conf
-rw-r--r-- 1 root root   197981 Sep 28  2009 pyOpenSSL-0.9.tar.gz
-rw-r--r-- 1 root root 11060830 May 22  2008 Python-2.5.1.tgz

二、编写安装shell

#cd FuncPack1.0

#vi install.sh

#!/bin/sh  
#  
# ---------------------------------------------------  
# A python&func install shell  
# ---------------------------------------------------  
#   
#       Writed by Liu  tiansi  
#       Mail:liutiansi@gmail.com  
#       Blog:http://blog.liuts.com  
#       QQ groups:106651547  
# ---------------------------------------------------  
  
  
_pwd=$(pwd)  
cd $_pwd/FuncPack1.0  
  
echo "==================*install python2.5*============================"  
/bin/tar -zxvf Python-2.5.1.tgz  
cd Python-2.5.1  
./configure && make && make install  
echo "export PATH=\$PATH:/usr/local/bin" >> /etc/profile  
source /etc/profile  
cd ..  
  
echo "=================*install Func/certmaster/pyOpenSSL*================="  
  
/bin/tar -zxvf pyOpenSSL-0.9.tar.gz  
cd pyOpenSSL-0.9  
/usr/local/bin/python setup.py install  
cd ..  
  
/bin/tar -zxvf certmaster-0.25.tar.gz  
cd certmaster-0.25  
/usr/local/bin/python setup.py install  
cd ..  
  
/bin/tar -zxvf func-0.25.tar.gz  
cd func-0.25  
/usr/local/bin/python setup.py install  
cd ..  
  
/bin/ln -s /usr/local/bin/certmaster /usr/bin/certmaster  
/bin/ln -s /usr/local/bin/funcd /usr/bin/funcd  
  
/bin/sed -i 's/'`hostname`'//g' /etc/hosts  
  
/bin/rm -rf /etc/certmaster/certmaster.conf  
/bin/rm -rf /etc/certmaster/minion.conf  
/bin/cp certmaster.conf /etc/certmaster  
/bin/cp minion.conf  /etc/certmaster  
  
/bin/sed -i -e '/^listen_port/{ s/51234/1999/; }' /etc/func/minion.conf  
/bin/sed -i -e "/^minion_name/{ s@=@= `hostname`@; }" /etc/func/minion.conf  
  
/sbin/chkconfig --level 345 certmaster on  
/sbin/service certmaster start  
  
/sbin/chkconfig --level 345 funcd on  
/sbin/service funcd start  
  
echo "Install over!"  
#chmod +x install.sh

三、打包

#cd /home
#wget http://megastep.org/makeself/makeself-2.1.5.run
#chmod +x makeself-2.1.5.run
#./makeself-2.1.5.run
#cd makeself-2.1.5

开始打包!

#./makeself.sh  --notemp ../FuncPack1.0/ FuncPack1.0.bin "system start install ..." ./install.sh

运行结果:

Header is 402 lines long
About to compress 11280 KB of data...
Adding files to archive named "FuncPack1.0.bin"...
./
./func-0.25.tar.gz
./Python-2.5.1.tgz
./pyOpenSSL-0.9.tar.gz
./install.sh
./minion.conf
./certmaster.conf
./certmaster-0.25.tar.gz
CRC: 853861468
MD5: 14463177b627f0e85f3591e88fb02b1d
Self-extractible archive "FuncPack1.0.bin" successfully created.

命令说明:
1、–notemp 不生成临时目录,在当前目录下创建一新的目录(推荐)
2、../FuncPack1.0/ 打包的源目录
3、FuncPack1.0.bin 生成自运行解压文件
4、"system start install …" 安装提示信息
5、./install.sh 解压后所要执行的安装脚本
6、CRC、MD5(防止被篡改)

更多说明见官方http://megastep.org/makeself/

四、运行包
1、将生成的FuncPack1.0.bin文件scp到其它主机
2、运行FuncPack1.0.bin即可

如大家有什么疑问或感兴趣的话题可以通过weibo与我交流:http://t.qq.com/yorkoliu

转自:http://blog.liuts.com/post/212/#entrymore

原创文章,作者:s19930811,如若转载,请注明出处:http://www.178linux.com/1744

(0)
s19930811s19930811
上一篇 2015-03-27
下一篇 2015-03-27

相关推荐

  • 马哥教育网络班20期+第四周博客作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@llww3317 ~]# cp -r /etc/skel /home [root@llww3317 ~]# mv /home/ske…

    Linux干货 2016-07-05
  • 日常练习加部分步骤注释

                                                      …

    2017-07-30
  • 用户管理、组管理、权限管理、文本处理工具应用示例

    用户管理、组管理、权限管理、文本处理工具应用示例 1.复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其他用户均没有任何访问权限 [root@localhost ~]# cp -a /etc/skel/ /home/tuser1/ [root@localhost ~]# chmod -R go= /hom…

    Linux干货 2017-07-23
  • 用户和权限管理

    一、用户 Linux中用户是资源获取的标识符,资源分配,文件系统安全权限模型的核心要素之一。密码则是用户认证的凭证,用户信息和密码信息都存放在相应的文本文件中,密码信息在存放的过程用了一定的加密算法进行加密。   1.加密算法: 资源分派:    Authentication:认证(确认身份,也有可能好几个人一个身份) &nbs…

    Linux干货 2016-08-05
  • 权限命令总结

    修改文件权限:chmod 1 2 3 4 [root@centos7 ~]# man chmod        chmod [OPTION]… MODE[,MODE]… FILE…    …

    Linux干货 2016-08-04
  • N25-第四周作业

    第四周 1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@zf ~]# cp -r /etc/skel/ /home/tuser1 [root@zf ~]# chmod -R&nbs…

    Linux干货 2016-12-21