Ubuntu18.04 远程修改静态IP

首先介绍下怎么设置静态IP

2018年4月26日,ubuntu 18.04发行,第一时间下载安装了SERVER版本。使用VM14版本的虚拟机,开始使用DHCP获得IP地址,没有意外,可以直接上网。然而在更改VM的网络模式为桥接模式时,想把虚拟机设为固定IP时,出现故障,一直不能获得地址,也上不了网。经常无数次测试,有以下经验可供参考。

ubuntu从17.10开始,已放弃在/etc/network/interfaces里固定IP的配置,即使配置也不会生效,而是改成netplan方式 ,配置写在/etc/netplan/01-netcfg.yaml或者类似名称的yaml文件里,18.04的server版本安装好以后,配置文件是:/etc/netplan/50-cloud-init.yaml,修改配置以后不用重启,执行 netplan apply 命令可以让配置直接生效。以前的重启网络服务命令/etc/init.d/networking restart或者services network restrart也都会提示为无效命令。

sudo vi /etc/netplan/01-network-manager-all.yaml,配置文件可按如下内容修改。

network:
  version: 2
  renderer: networkd
  ethernets:
    ens33:   #配置的网卡名称
      dhcp4: no    #dhcp4关闭
      dhcp6: no    #dhcp6关闭
      addresses: [192.168.1.55/24]   #设置本机IP及掩码
      gateway4: 192.168.1.254   #设置网关
      nameservers:
          addresses: [114.114.114.114, 8.8.8.8]   #设置DNS

这里简单介绍下 [192.168.1.55/24] ,里的192.168.1.55就是设置的静态IP,IP地址后面跟/24表示掩码位是24位,子网掩码是255.255.255.0的IP地址,其主机位最多有254个。

注意点:
1.以上配置文件共11行,其中第2,3,6,7四行可以不写,测试过没有这四行,网络也能工作正常,第5行的ens33为虚拟网卡,可以使用ifconfig -a查看本机的网卡。
2.配置文件里在冒号:号出现的后面一定要空一格,不空格则在运行netplan apply时提示出错。
3.关键之关键是看清配置总共分为五个层次,逐层向后至少空一格,
第一层-network:
第二层-- ethernets:
第三层--- ens33:
第四层----addresses: [192.168.1.55/24]
第四层----gateway4: 192.168.1.254
第四层----nameservers:
第五层-----addresses: [114.114.114.114, 8.8.8.8]

出现类似错误:line8 column 6:cloud not find expected ':' #提示是冒号:后面没加空格
出现类似错误:netplan found character that cannot start any token,#提示是没有按五个层次写配置文档,一定要下一层比上一层多空一格或以上。

启用生效

sudo netplan apply

到这里就可以设置静态IP了,接下来结合ssh,sftp实现远程修改

直接上代码

    def updateIP(self):
        try:
            IP = self.lineEdit_50.text()
            name = self.lineEdit_51.text()
            if IP == '' or name == '':
                QMessageBox.warning(self, "警告", "请正确输入修改的IP!")
                return
            self.createFilr(IP,name)
            hostname = self.lineEdit.text()
            username = '****'
            password = '****'
            rootdir = '01-network-manager-all.yaml'
            dir_path = '/etc/netplan/'
            scp = paramiko.Transport((hostname, 22))
            scp.connect(username=username, password=password)
            sftp = paramiko.SFTPClient.from_transport(scp)
            ssh = paramiko.SSHClient()
            # 允许连接不在know_hosts文件中的主机
            ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())  # 第一次登录的认证信息
            # 连接服务器
            ssh.connect(hostname=hostname, port=22, username=username, password=password)
          #修改配置文件权限,777是最高权限 
            command = "chmod 777 /etc/netplan/ -R"
            stdin, stdout, stderr = ssh.exec_command('echo %s|sudo -S %s' % (password, command))
           
            res, err = stdout.read(), stderr.read()
            result = res if res else err
            sftp.put(rootdir,dir_path+rootdir)
#启用生效
            command = "netplan apply"
            stdin, stdout, stderr = ssh.exec_command('echo %s|sudo -S %s' % (password, command))
           
            res, err = stdout.read(), stderr.read()
            result = res if res else err
      
            scp.close()
            ssh.close()
        
            QMessageBox.warning(self, "提示", "修改成功!")
            return 0
        except:
            QMessageBox.warning(self, "警告", "修改失败!")

#创建网络配置文件
    def createFilr(self,IP,name):
        file = open('01-network-manager-all.yaml', 'wb')
        str_f = '# Let NetworkManager manage all devices on this system\n' + 'network:\n' + '  version: 2\n' + '  # renderer: NetworkManager\n' \
                + '  ethernets:\n' + '          '+ name +':\n' \
                + '                  addresses: [' + IP + '/24]\n'
        b_f = str.encode(str_f)
        file.write(b_f)
        file.close()

这里结合了pyqt,创建一个窗口工具,更方便的通过远程去修改IP

你可能感兴趣的:(Ubuntu18.04 远程修改静态IP)