Jan
17
2022
将本地docker容器上传到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容器
本公司销售:阿里云、腾讯云、百度云、天翼云、金山大米云、金山企业云盘!可签订合同,开具发票。
我有话说: