ECS使用初体验——将本地docker容器上传到ECS服务器

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 本文介绍了如何将docker容器打包成镜像并上传到ECS,避免了在本地容器内配置好环境后,还需要在ECS重新配置的问题

ECS服务器添加用户

登录ECS服务器后先添加用户

sudo adduser [用户名]

为用户配置sudo权限

sudo usermod -aG sudo [用户名]

配置完成后执行sudo apt-get update

在本地ubuntu服务器配置ssh

配置config

使用命令cd ~/.ssh

vim config

格式如下,其中myserver1,myserver2是要远程服务器的别名,这里假设我配置了myserver1

Host myserver1
    HostName: IP地址或域名(ECS服务器ip)
    User: 用户名(上面设置的用户名)
Host myserver2
    HostName: IP地址或域名
    User: 用户名

配置密钥

使用命令ssh-keygen,一直enter到底,会在.ssh文件夹下生成两个文件

id_rsa是私钥(不要外泄),id_rsa.pub是公钥(可以放在要远程的服务器上)

在本地执行ssh-copy-id [servername],将公钥上传到ECS,其中servername是上面config配置的,比如是myserver1。

在本地ubuntu登录ECS

使用命令ssh [myserver1],即可登录到ECS,myserver1是上面config配置的,可以根据自己情况更改。

ECS安装docker

我的ECS默认的是ubuntu,要根据自己的情况来安装

# 更新package index
sudo apt-get update
# 安装必备的包
sudo apt-get install \
    ca-certificates \
    curl \
    gnupg \
    lsb-release
# 添加docker官方GPG key
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg
# 用这个命令建立一个稳定的repository
 echo \
  "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu \
  $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
# 安装docker engine
 sudo apt-get update
 sudo apt-get install docker-ce docker-ce-cli containerd.io

添加docker用户组,将当前用户添加到组中

 sudo groupadd docker
 sudo usermod -aG docker $USER

将本地docker容器上传到ECS

假设本地已经有了一个实验环境的docker容器,名字为mydocker1

# 创建容器的镜像
docker commit [容器名或者容器id] [镜像名]:[tag]
# 例如我将自己容器mydocker1提交为镜像ubuntu:v1(自己起名字)
docker commit mydocker1 ubuntu:v1
# 将镜像打包成tar
docker save -o [文件名.tar] [镜像名]:[tag]
# 例如我将上面提交的镜像ubuntu:v1打包成ubuntu:v1.tar
docker save -o ubuntu:v1.tar ubuntu:v1
# 为ubuntu:v1.tar添加可读权限
chmod +r ubuntu:v1

将ubuntu:v1.tar上传到ECS

scp ubuntu:v1.tar myserver1

登录到ECS后将刚刚上传的文件生成镜像

docker load -i [文件名.tar]
# 例如我将刚刚上传的ubuntu:v1.tar生成镜像
docker load -i ubuntu:v1.tar

使用docker images可以查看到刚刚生成的镜像

使用docker run命令生成容器

docker run -it ubuntu:v1 /bin/bash

到此,我们用了和本地ubuntu相同配置的docker容器

相关实践学习
通义万相文本绘图与人像美化
本解决方案展示了如何利用自研的通义万相AIGC技术在Web服务中实现先进的图像生成。
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情: https://www.aliyun.com/product/ecs
相关文章
|
30天前
|
存储 弹性计算 运维
阿里云服务器ECS是什么?你真的了解吗?云服务器解析
阿里云服务器ECS是阿里云提供的虚拟服务器服务,用户可按需租赁使用,无需自建机房。它具备高可用、高安全、弹性伸缩、节约成本等优势,适用于网站搭建、数据应用、运维测试等多种场景。本文详解ECS组成、架构、使用方法及与传统服务器的区别。
130 1
|
18天前
|
机器学习/深度学习 弹性计算 编解码
阿里云服务器4核8G配置:ECS实例规格、CPU型号及使用场景说明
阿里云4核8G服务器提供多种ECS实例规格,如高主频计算型hfc8i、ecs.c9i、计算型c8i、通用算力型u1、经济型e等,适配不同应用场景,涵盖高性能计算、AI推理、Web服务、数据分析等领域。
|
1月前
|
存储 弹性计算 运维
阿里云服务器全解析:ECS是什么、应用场景、租用流程及优缺点分析
阿里云ECS(Elastic Compute Service)是阿里云提供的高性能、高可用的云计算服务,支持弹性扩展、多样化实例类型和多种计费模式。适用于网站搭建、数据处理、运维测试等多种场景,具备分钟级交付、安全可靠、成本低、易运维等优势,是企业及开发者上云的理想选择。
333 5
|
1月前
|
弹性计算 负载均衡 安全
阿里云轻量应用服务器与ECS区别
阿里云轻量应用服务器与ECS云服务器对比:轻量版适合新手和小型应用,套餐化设计,含大流量,易上手但性能和灵活性有限;ECS为专业版,配置灵活,性能强,适合企业级应用,但操作复杂,生态丰富,按需计费。两者定位不同,适用于不同场景。
|
1月前
|
存储 弹性计算 缓存
阿里云ECS通用算力型u2i服务器性能测评、CPU型号及配置参数解析
阿里云ECS通用算力型u2i实例,搭载Intel® Xeon® Platinum处理器,支持第五、六代至强平台,适用于Web、Java、中小型数据库等场景。提供1:1至1:8多种vCPU与内存配比,最大32vCPU,标配ESSD Entry云盘,网络性能随规格提升增强,支持IPv4/IPv6,适用于企业级应用、数据分析、缓存集群等业务,兼顾性能与成本效益。
|
12月前
|
Linux Docker 容器
Docker操作 :容器命令
Docker操作 (四)
329 56
|
11月前
|
安全 Shell Linux
docker进入容器命令
docker进入容器命令
746 1
|
应用服务中间件 Shell nginx
Docker容器操作基础命令
关于Docker容器操作基础命令的教程,涵盖了从启动、查看、删除容器到端口映射和容器信息获取的一系列常用命令及其使用方法。
354 14
|
Linux 开发者 Docker
如何构建在 Docker 容器中运行命令?
【1月更文挑战第6天】
239 0
|
存储 Docker 容器
在Docker中,容器退出后,通过docker ps命令查看不到,数据会丢失么?
在Docker中,容器退出后,通过docker ps命令查看不到,数据会丢失么?