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

简介: 本文介绍了如何将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容器

相关实践学习
基于ECS搭建FTP服务
本教程介绍如何在Linux实例上安装并配置vsftpd,在被动模式下,使用本地用户访问FTP服务器的配置方法。。
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情: https://www.aliyun.com/product/ecs
相关文章
|
7月前
|
Kubernetes Docker Python
Docker 与 Kubernetes 容器化部署核心技术及企业级应用实践全方案解析
本文详解Docker与Kubernetes容器化技术,涵盖概念原理、环境搭建、镜像构建、应用部署及监控扩展,助你掌握企业级容器化方案,提升应用开发与运维效率。
1084 108
|
8月前
|
存储 监控 测试技术
如何将现有的应用程序迁移到Docker容器中?
如何将现有的应用程序迁移到Docker容器中?
634 57
|
5月前
|
监控 Kubernetes 安全
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
蒋星熠Jaxonic,技术探索者,以代码为笔,在二进制星河中书写极客诗篇。专注Docker与容器化实践,分享从入门到企业级应用的深度经验,助力开发者乘风破浪,驶向云原生新世界。
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
|
5月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
695 6
|
5月前
|
监控 Linux 调度
【赵渝强老师】Docker容器的资源管理机制
本文介绍了Linux CGroup技术及其在Docker资源管理中的应用。通过实例演示了如何利用CGroup限制应用程序的CPU、内存和I/O带宽使用,实现系统资源的精细化控制,帮助理解Docker底层资源限制机制。
548 6
|
8月前
|
存储 监控 Java
如何对迁移到Docker容器中的应用进行性能优化?
如何对迁移到Docker容器中的应用进行性能优化?
535 59
|
7月前
|
缓存 Ubuntu Docker
Ubuntu环境下删除Docker镜像与容器、配置静态IP地址教程。
如果遇见问题或者想回滚改动, 可以重启系统.
484 16