首页 > 如何优雅在多台机器上进行源码安装某个程序?

如何优雅在多台机器上进行源码安装某个程序?

有一个程序,修改代码后要在多台机器(数量比较大)进行源码编译安装,请问有没有比较好的方法?

自己的一个想法

源码修改后,通过rsync把源码分发到每台机器,然后,每台机器写个编译安装脚本,通过并行SSH来执行每台机器的编译安装脚本


这个一般都是如下几种做法:

  1. 如果是比较固定并且量很小的,自己可以写自动化安装编译脚本,或者使用别人的.再用批量的方式进行安装.优雅就在于脚本是否够强大了.
  2. 另外如果是bin文件的安装部署,环境一致,如prosper所说肯定是只可以直接同步bin文件的.但一般我们的安装的开源软件依赖很多.像c golang这种程序的好处就是没有多余的依赖.(mac的app也是依赖少)
  3. 使用一些开源的包管理工具(包括rpm和编译安装),有些公司内部都有自己的,但原理基本类似.有一个编译安装的方法,大家可以提交这个安装包配置,并且有一个地方可以存储这些大家可以共用,并且提供好了安装查找卸载的工具.如mac下的brew, Arch PKGBUILD,等等就不一一列举.

如果操作系统是centos/redhst 并且的版本完全一致,你可以通过先在一台上编译好,然后打包成rpm,通过puppet 或者是yum 直接进行升级安装。如果操作系统版本不一致,那么也可以通过puppet,或者是salt 之类的自动化运维工具去执行编译升级工作

【热门文章】
【热门文章】