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

通常我们在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)
上一篇 2015-03-27 17:07
下一篇 2015-03-27 17:15

相关推荐

  • 马哥教育网络班21期+第11周课程练习

    1、详细描述一次加密通讯的过程,结合图示最佳。 首先发送方用单向加密的方法提取数据的特征码,用自己的私钥加密这段特征码,并附加到数据的后面。     发送方用对称加密算法把数据及特征码整个进行加密。     发送方用接收发的公钥加密对称密钥并附加到数据后面。  &nbs…

    Linux干货 2016-09-19
  • 文件元数据信息的含义、查看方法,和文件时间戳信息的修改方法

    文件数据分成两类 元数据,英文叫metadata,是数据的属性; 数据,英文叫data,是数据本身; 使用stat命令查看元数据信息 [0][root@localhost mylinux]# stat /etc/passwd File: ‘/etc/passwd’ Size: 889 Blocks: 8 IO Block: 4096 regular file…

    Linux干货 2018-03-01
  • 修改Linux命令终端提示符

    作业1. 设置自己的终端提示符,要求字符终端登录时:     a> 需要带颜色     b> 需要显示当前执行到了第几条命令     c> 显示当前登录终端,主机名和当前时间     这可以通…

    Linux干货 2016-10-17
  • httpd服务归纳:httpd基本配置(https原理以及配置 )

    一 https介绍以及实现机制   1. https协议:      在传统的http协议中,文档是明文传送的,网页涉及敏感信息是,将变得很不安全。为了保证敏感信息的安全,httpd结合加密库openssl或openssh 产生了https 协议。这就好比两个黑社会团伙交易,都怕出事被抓,…

    Linux干货 2015-05-23
  • 第七周 N21 总有刁民想害朕

    1、创建一个10G分区,并格式为ext4文件系统;    (1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl;        mke2fs -t ext4 /dev/sdb5 -b 2048 -m 2 -L "MYDATA&quot…

    Linux干货 2016-08-08
  • 软链接和硬链接的区别

    软链接和硬链接的区别 什么是链接: 文件都是文件名和数据组成的,在linux中被分成两部分:数据和元数据。数据是记录文件的真实内容的地方;元数据是记录文件属性的地方:创建者、大小、创建时间等信息。元数据中的inode号这是唯一标识文件身份的属性。在linux中,文件的inode号可以通过ls –i命令查看。在linux中为了解决文件共享使用,引入了两种链接:…

    Linux干货 2016-10-20