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

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
简介: 本文介绍了如何将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容器

相关实践学习
借助OSS搭建在线教育视频课程分享网站
本教程介绍如何基于云服务器ECS和对象存储OSS,搭建一个在线教育视频课程分享网站。
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情: https://www.aliyun.com/product/ecs
相关文章
|
17天前
|
负载均衡 网络协议 开发者
掌握 Docker 网络:构建复杂的容器通信
在 Docker 容器化环境中,容器间的通信至关重要。本文详细介绍了 Docker 网络的基本概念和类型,包括桥接网络、宿主网络、覆盖网络和 Macvlan 网络等,并提供了创建、管理和配置自定义网络的实用命令。通过掌握这些知识,开发者可以构建更健壮和灵活的容器化应用,提高应用的可扩展性和安全性。
|
22天前
|
弹性计算 运维 持续交付
探索Docker容器化技术及其在生产环境中的应用
探索Docker容器化技术及其在生产环境中的应用
70 5
|
14天前
|
Linux iOS开发 Docker
Docker:容器化技术的领航者 —— 从基础到实践的全面解析
在云计算与微服务架构日益盛行的今天,Docker作为容器化技术的佼佼者,正引领着一场软件开发与部署的革命。它不仅极大地提升了应用部署的灵活性与效率,还为持续集成/持续部署(CI/CD)提供了强有力的支撑。
192 69
|
2天前
|
Kubernetes Cloud Native 持续交付
云原生之旅:Docker容器化与Kubernetes集群管理
【9月更文挑战第33天】在数字化转型的浪潮中,云原生技术如同一艘航船,带领企业乘风破浪。本篇文章将作为你的航海指南,从Docker容器化的基础讲起,直至Kubernetes集群的高级管理,我们将一起探索云原生的奥秘。你将学习到如何封装应用、实现环境隔离,以及如何在Kubernetes集群中部署、监控和扩展你的服务。让我们启航,驶向灵活、可伸缩的云原生未来。
|
15天前
|
运维 Cloud Native Docker
云原生技术入门:Docker容器化实战
【9月更文挑战第20天】本文将引导你走进云原生技术的世界,通过Docker容器化技术的实战演练,深入理解其背后的原理和应用。我们将一起探索如何在云平台上利用Docker简化部署、扩展和管理应用程序的过程,并揭示这一技术如何改变现代软件的开发和运维模式。
|
10天前
|
Cloud Native 持续交付 Docker
云原生技术入门与实践:Docker容器化部署示例
【9月更文挑战第25天】在数字化转型的浪潮下,云原生技术成为推动企业创新的重要力量。本文旨在通过浅显易懂的语言,为初学者揭示云原生技术的核心概念及其应用价值。我们将以Docker容器为例,逐步引导读者了解如何将应用程序容器化,并在云端高效运行。这不仅是对技术趋势的跟随,更是对资源利用和开发效率提升的探索。
29 4
|
8天前
|
Kubernetes Linux 开发者
深入探索Docker容器化技术的奥秘
深入探索Docker容器化技术的奥秘
16 1
|
11天前
|
存储 Docker 容器
Docker中容器间的通信方式有哪些13
Docker中容器间的通信方式有哪些13
14 4
|
17天前
|
运维 Ubuntu Linux
深入理解并实践Docker容器化技术
深入理解并实践Docker容器化技术
44 6
|
22天前
|
运维 Docker 微服务
掌握 Docker Compose:简化你的多容器应用部署
在微服务架构和容器化技术普及的今天,管理多容器部署变得颇具挑战。Docker Compose 通过一个 YAML 文件定义和运行多容器应用,简化了部署和运维。本文介绍其基本概念、使用方法及优势,包括服务、项目、卷和网络等核心概念,并提供从安装到管理服务的详细步骤,助你轻松掌握 Docker Compose,提高开发效率和应用运维质量。
下一篇
无影云桌面