zoukankan      html  css  js  c++  java
  • OpenStack(企业私有云)万里长征第五步——虚拟机Migrate&Resize

    一、前言

    上一篇文章讲了OpenStack的部署和简单操作,今天介绍一下如何实现虚拟机的Migrate以及Resize。Migrate操作和Resize操作基本上属于同一种操作,Migrate操作只是Resize操作的一个特例,无需更改虚拟机的配置。

    二、操作

    2.1 应用需求

    这两个需求的应用场景如下:

    1. 某台宿主机不再使用需要将其内虚拟机迁出。
    2. 当前宿主机内虚拟机数量过多,迁出一部分。理论上这种情况不存在,因为OpenStack在建立虚拟机的时候会考虑这些问题,但是如果新添加了宿主机节点则有可能出现此问题。
    3. 虚拟机的配置过低,需要提高配置。

    2.2 实操

    理论上此操作很简单,只需要在web管理界面中点下按钮即可。但是我实际测试却木有反应,是何道理?检查日志发现是因为不能进行从当前宿主机到目标宿主机的ssh,于是操作失败。经过多次测试发现如下解决方案。

    首先通过ps -ef命令可以发现nova-compute进程的启动用户是stack。所以是stack用户之间不能进行ssh造成的上述问题。解决方案便是实现宿主机集群内所有服务器两两之间的ssh无密码登录。(参考https://funcptr.net/2014/09/29/openstack-resizing-of-instances/)

    1. 生成公钥

    切换到stack用户(以下操作全在stack用户下),执行

    ssh-keygen -t rsa
    
    1. 关闭host校验

    执行

    cat << EOF > ~/.ssh/config
    Host *
        StrictHostKeyChecking no
        UserKnownHostsFile=/dev/null
    EOF
    
    1. 将公钥拷入.authorized_keys
    cat ~/.ssh/id_rsa.pub > .ssh/authorized_keys
    chmod 600 .ssh/authorized_keys
    
    1. 将.ssh复制到所有主机
    scp .ssh youruser@remotehost:~/
    

    当然如果当前用户是无密码的,那么你需要先用有密码的用户将.ssh远程拷贝到此无密码用户的根目录下,然后修改此目录的权限为无密码用户。当然逐台操作过于麻烦,可以写脚本如下:

    for node in node1 node2 node3 ;do ssh -t $node 'sudo chown -R stack:stack /opt/stack/.ssh';done;
    

    当然上述scp也可以写个脚本一次执行。执行完如果虚拟机的状态不对,可以执行

    nova reset-state --active <instance>
    

    来激活当前主机。

    三、总结

    以上便是解决Migrate以及Resize无法正常操作的方法,欢迎留言交流。天太热,今天就不喝鸡汤了。

  • 相关阅读:
    Perl 计算平均值
    Linux_SELinux使用
    Linux_SELinux使用
    【案例实战】餐饮企业分店财务数据分析系统解决方案:业务需求
    【案例实战】餐饮企业分店财务数据分析系统解决方案:系统功能开发
    【案例实战】餐饮企业分店财务数据分析系统解决方案:系统功能开发
    mysql binlog 分析
    perl 回调函数
    Linux_NFS/Samba服务器
    第六章 模块
  • 原文地址:https://www.cnblogs.com/shoufengwei/p/7161812.html
Copyright © 2011-2022 走看看