AWSEC2镜像构建器无法生成authorized_keys文件
创始人
2024-09-25 00:32:21
0

在AWS EC2镜像构建器中,当使用Packer创建自定义安装包时,会遇到创建用户时无法生成authorized_keys文件的问题。在用户数据中使用的bash脚本无法找到默认SSH密钥对。解决方法是在用户数据中添加生成SSH密钥对的脚本。

步骤如下:

  1. 在用户数据中创建一个新脚本,以生成SSH密钥对。

例如:

cat /dev/zero | ssh-keygen -q -N "" > /dev/null
mkdir -p /home/ec2-user/.ssh
cat /root/.ssh/id_rsa.pub >> /home/ec2-user/.ssh/authorized_keys
chmod 600 /home/ec2-user/.ssh/authorized_keys
chown -R ec2-user:ec2-user /home/ec2-user/.ssh
  1. 在Packer模板中添加用户数据脚本,以使用新密钥对创建用户。

例如:

  "provisioners": [
    {
      "type": "shell",
      "inline": [
        "sudo useradd -m -s /bin/bash ec2-user",
        "echo 'ec2-user:' | sudo chpasswd -e",
        "sudo usermod -aG wheel ec2-user"
      ]
    }
  ],
  "user_data": "#!/bin/bash\n"

替换为新的SSH密钥对脚本。

  1. 运行Packer进行自定义AMI的构建。

  2. 在EC2实例中使用新的AMI启动实例,并使用新的SSH密钥对连接到该实例。

  3. 确认/home/ec2-user/.ssh/authorized_keys文件已经正确生成。

相关内容

热门资讯

安卓换鸿蒙系统会卡吗,体验流畅... 最近手机圈可是热闹非凡呢!不少安卓用户都在议论纷纷,说鸿蒙系统要来啦!那么,安卓手机换上鸿蒙系统后,...
app安卓系统登录不了,解锁登... 最近是不是你也遇到了这样的烦恼:手机里那个心爱的APP,突然就登录不上了?别急,让我来帮你一步步排查...
安卓系统拦截短信在哪,安卓系统... 你是不是也遇到了这种情况:手机里突然冒出了很多垃圾短信,烦不胜烦?别急,今天就来教你怎么在安卓系统里...
安卓系统要维护多久,安卓系统维... 你有没有想过,你的安卓手机里那个陪伴你度过了无数日夜的安卓系统,它究竟要陪伴你多久呢?这个问题,估计...
windows官网系统多少钱 Windows官网系统价格一览:了解正版Windows的购买成本Windows 11官方价格解析微软...
安卓系统如何卸载app,轻松掌... 手机里的App越来越多,是不是感觉内存不够用了?别急,今天就来教你怎么轻松卸载安卓系统里的App,让...
怎么复制照片安卓系统,操作步骤... 亲爱的手机控们,是不是有时候想把自己的手机照片分享给朋友,或者备份到电脑上呢?别急,今天就来教你怎么...
安卓系统应用怎么重装,安卓应用... 手机里的安卓应用突然罢工了,是不是让你头疼不已?别急,今天就来手把手教你如何重装安卓系统应用,让你的...
iwatch怎么连接安卓系统,... 你有没有想过,那款时尚又实用的iWatch,竟然只能和iPhone好上好?别急,今天就来给你揭秘,怎...
iphone系统与安卓系统更新... 最近是不是你也遇到了这样的烦恼?手机更新系统总是失败,急得你团团转。别急,今天就来给你揭秘为什么iP...