设为首页 收藏本站
查看: 1183|回复: 0

[Cloudstack] CloudStack 脚本封装分析

[复制链接]

尚未签到

发表于 2015-4-18 09:15:07 | 显示全部楼层 |阅读模式
     cloud.keystore是这样生成的
  
     String dname = "cn=\"" + cn + "\",ou=\"" + ou + "\",o=\"" + o + "\",c=\"" + c + "\"";     
        Script script = new Script(true, "keytool", 5000, null);      
        script.add("-genkey");      
        script.add("-keystore", keystorePath);      
        script.add("-storepass", "vmops.com");      
        script.add("-keypass", "vmops.com");      
        script.add("-keyalg", "RSA");      
        script.add("-validity", "3650");      
        script.add("-dname", dname);      
        String result = script.execute();      
        if (result != null) {      
            throw new IOException("Fail to generate certificate!: " + result);      
        }
    手动生成该文件
  sudo keytool -genkey -keystore "/etc/cloudstack/management/cloud.keystore" -storepass "vmops.com" -keypass "vmops.com" -keyalg "RSA" -validity 3650 -dname "CN=cloud.com,OU=sjcloud CA,O=sjcloud Inc,L=sjcloud,S=sjcloud,C=SE"
  
DSC0000.png
  injectkeys.sh 脚本
  # Copies keys that enable SSH communication with system vms   
# $1 = new public key   
# $2 = new private key
  #set -x   
source /etc/bashrc   
source /etc/profile   
TMP=/tmp
  
clean_up() {   
  sudo umount $MOUNTPATH   
}
  inject_into_iso() {   
  local isofile=${systemvmpath}   
  local newpubkey=$2   
  local backup=${isofile}.bak   
  local tmpiso=${TMP}/$1   
  mkdir -p $MOUNTPATH   
  [ ! -f $isofile ] && echo "$(basename $0): Could not find systemvm iso patch file $isofile" && return 1   
  sudo mount -o loop $isofile $MOUNTPATH   
  [ $? -ne 0 ] && echo "$(basename $0): Failed to mount original iso $isofile" && clean_up && return 1   
  diff -q $MOUNTPATH/authorized_keys $newpubkey &> /dev/null && clean_up && return 0   
  sudo cp -b $isofile $backup   
  [ $? -ne 0 ] && echo "$(basename $0): Failed to backup original iso $isofile" && clean_up && return 1   
  sudo rm -rf $TMPDIR   
  sudo mkdir -p $TMPDIR   
  [ ! -d $TMPDIR  ] && echo "$(basename $0): Could not find/create temporary dir $TMPDIR" && clean_up && return 1   
  sudo cp -fr $MOUNTPATH/* $TMPDIR/   
  [ $? -ne 0 ] && echo "$(basename $0): Failed to copy from original iso $isofile" && clean_up && return 1   
  sudo cp $newpubkey $TMPDIR/authorized_keys   
  sudo umount $MOUNTPATH   
  [ $? -ne 0 ] && echo "$(basename $0): Failed to unmount old iso from $MOUNTPATH" && return 1   
  sudo cp -f $tmpiso $isofile   
  [ $? -ne 0 ] && echo "$(basename $0): Failed to overwrite old iso $isofile with $tmpiso" && return 1   
  sudo rm -rf $TMPDIR   
}
  copy_priv_key() {   
  local newprivkey=$1   
  diff -q $newprivkey $(dirname $0)/id_rsa.cloud && return 0   
  sudo cp -f $newprivkey $(dirname $0)/id_rsa.cloud   
  sudo chmod 644 $(dirname $0)/id_rsa.cloud   
  return $?   
}
  sudo mkdir -p $MOUNTPATH
  [ $# -ne 3 ] && echo "Usage: $(basename $0)    " && exit 3   
newpubkey=$1   
newprivkey=$2   
systemvmpath=$3   
[ ! -f $newpubkey ] && echo "$(basename $0): Could not open $newpubkey" && exit 3   
[ ! -f $newprivkey ] && echo "$(basename $0): Could not open $newprivkey" && exit 3
  command -v mkisofs > /dev/null   || (echo "$(basename $0): mkisofs not found, please install or ensure PATH is accurate" ; exit 4)
  inject_into_iso systemvm.iso $newpubkey
  [ $? -ne 0 ] && exit 5
  copy_priv_key $newprivkey
  exit $?
  加入部分sudo
      DSC0001.png

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-58328-1-1.html 上篇帖子: 搭建自己的XenServer+CloudStack云平台,提供IaaS服务(一)环境搭建 下篇帖子: CloudStack云基础架构的一些概念
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表