目录

  • Linux
  • y总原文
  • 我写在Acwing的
  • 一、概述
  • 云平台的作用:
  • 1核 2GB(后期可以动态扩容,前期配置低一些没关系)
  • 二、租云服务器
  • 登录`root`
  • 切换用户`User`
  • ①阿里云和腾讯云如下:
  • 创建工作用户`acs`并赋予`sudo`权限
  • 配置免密登录方式
  • 安装`tmux`和`docker`
  • ②腾讯云如下:
  • 创建工作用户`acs`并赋予`sudo`权限
  • 配置免密登录方式
  • 安装`tmux`和`docker`
  • 三、docker教程
  • 安装docker
  • docker教程
  • 镜像(images)
  • 容器(container)
  • 实战
  • 小Tips


一、概述

云平台的作用:
  1. 存放我们的docker容器,让计算跑在云端。
  2. 获得公网IP地址,让每个人可以访问到我们的服务。
  3. 任选一个云平台即可,推荐配置:
1核 2GB(后期可以动态扩容,前期配置低一些没关系)
  1. 网络带宽采用按量付费,最大带宽拉满即可(费用取决于用量,与最大带宽无关)
  2. 系统版本:ubuntu 20.04 LTS(推荐用统一版本,避免后期出现配置不兼容的问题)

二、租云服务器

阿里云地址:https://www.aliyun.com/ 腾讯云地址:https://cloud.tencent.com/ 华为云地址:https://www.huaweicloud.com/

登录root
sudo su
切换用户User
su userName
①阿里云和腾讯云如下:
创建工作用户acs并赋予sudo权限

登录到新服务器。打开AC Terminal,然后:

ssh root@xxx.xxx.xxx.xxx  # xxx.xxx.xxx.xxx替换成新服务器的公网IP

创建acs用户:

adduser acs  # 创建用户acs
usermod -aG sudo acs  # 给用户acs分配sudo权限
配置免密登录方式

退回AC Terminal,然后配置acs用户的别名和免密登录,可以参考4. ssh——ssh登录。

配置新服务器的工作环境
将AC Terminal的配置传到新服务器上:

scp .bashrc .vimrc .tmux.conf server_name:  # server_name需要换成自己配置的别名
安装tmuxdocker

登录自己的服务器,然后安装tmux

sudo apt-get update
sudo apt-get install tmux

打开tmux。(养成好习惯,所有工作都在tmux里进行,防止意外关闭终端后,工作进度丢失)

然后在tmux中根据docker安装教程安装docker即可。

②腾讯云如下:
创建工作用户acs并赋予sudo权限

登录到新服务器。打开AC Terminal,然后:

ssh ubuntu@xxx.xxx.xxx.xxx  # xxx.xxx.xxx.xxx替换成新服务器的公网IP

创建acs用户:

sudo adduser acs  # 创建用户acs
sudo usermod -aG sudo acs  # 给用户acs分配sudo权限
配置免密登录方式

退回AC Terminal,然后配置acs用户的别名和免密登录,可以参考4. ssh——ssh登录。

配置新服务器的工作环境
将AC Terminal的配置传到新服务器上:

scp .bashrc .vimrc .tmux.conf server_name:  # server_name需要换成自己配置的别名
安装tmuxdocker

登录自己的服务器,然后安装tmux

sudo apt-get update
sudo apt-get install tmux

打开tmux。(养成好习惯,所有工作都在tmux里进行,防止意外关闭终端后,工作进度丢失)

然后在tmux中根据docker安装教程安装docker即可。

三、docker教程

安装docker

官方文档 进入官网之后按照如下步骤进入:Manuals/Docker Engine/Installation per distro/Install on Ubuntu 进入之后按照教程一步一步安装就行

docker教程

acwingy总上传的docker镜像路径:~/var/lib/acwing/docker/images/docker_lesson_1_0.tar

将当前用户添加到docker用户组
为了避免每次使用docke命令都需要加上sudo权限,可以将当前用户加入安装中自动创建的docker用户组(可以参考官方文档):
在官方文档路径:Manuals/Docker Engine/Optional post-installation steps

sudo usermod -aG docker $USER
镜像(images)
  1. docker pull ubuntu:20.04:拉取一个镜像
  2. docker images:列出本地所有镜像
  3. docker image rm ubuntu:20.04docker rmi ubuntu:20.04:删除镜像ubuntu:20.04
  4. docker [container] commit CONTAINER IMAGE_NAME:TAG:创建某个container的镜像
  5. docker save -o ubuntu_20_04.tar ubuntu:20.04:将镜像ubuntu:20.04导出到本地文件ubuntu_20_04.tar
  6. docker load -i ubuntu_20_04.tar:将镜像ubuntu:20.04从本地文件ubuntu_20_04.tar中加载出来
容器(container)
  1. docker [container] create -it ubuntu:20.04:利用镜像ubuntu:20.04创建一个容器。
  2. docker ps -a:查看本地的所有容器
  3. docker [container] start CONTAINER:启动容器(其中CONTAINERcontaineridname, idname 等效)
  4. docker [container] stop CONTAINER:停止容器
  5. docker [container] restart CONTAINER:重启容器
  6. docker [contaienr] run -itd ubuntu:20.04:创建并启动一个容器
  7. docker [container] attach CONTAINER:进入容器
  • 先按Ctrl-p,再按Ctrl-q可以挂起容器
  1. docker [container] exec CONTAINER COMMAND:在容器中执行命令
  2. docker [container] rm CONTAINER:删除容器
  3. docker container prune:删除所有已停止的容器
  4. docker export -o xxx.tar CONTAINER:将容器CONTAINER导出到本地文件xxx.tar
  5. docker import xxx.tar image_name:tag:将本地文件xxx.tar导入成镜像,并将镜像命名为image_name:tag
  6. docker export/importdocker save/load的区别:
  • export/import会丢弃历史记录和元数据信息,仅保存容器当时的快照状态
  • save/load会保存完整记录,体积更大
  1. docker top CONTAINER:查看某个容器内的所有进程
  2. docker stats:查看所有容器的统计信息,包括CPU、内存、存储、网络等信息
  3. docker cp xxx CONTAINER:xxxdocker cp CONTAINER:xxx xxx:在本地和容器间复制文件(将前面的copy到后面里)
  4. docker rename CONTAINER1 CONTAINER2:重命名容器
  5. docker update CONTAINER --memory 500MB:修改容器限制
实战

进入AC Terminal,然后:

# 将docker镜像上传到自己租的云端服务器
scp /var/lib/acwing/docker/images/docker_lesson_1_0.tar server_name:

# 登录自己的云端服务器
ssh server_name

# 将镜像加载到本地
docker load -i docker_lesson_1_0.tar

# 创建并运行docker_lesson:1.0镜像,并将22端口映射到20000端口,名字为my_docker_server
docker run -p 20000:22 --name my_docker_server -itd docker_lesson:1.0

# 进入创建的docker容器
docker attach my_docker_server  

# 设置root密码
passwd  

# 得自己下载sudo命令
apt-get install sudo

去云平台控制台中修改安全组配置,放行端口20000

返回AC Terminal,即可通过ssh登录自己的docker容器:

# 登录到指定服务器指定端口,将xxx.xxx.xxx.xxx替换成自己租的服务器的IP地址
ssh root@xxx.xxx.xxx.xxx -p 20000

然后,可以仿照上节课内容,创建工作账户acs

最后,可以参考4. ssh——ssh登录配置docker容器的别名和免密登录。

小Tips

如果apt-get下载软件速度较慢,可以参考清华大学开源软件镜像站中的内容,修改软件源。

  • 手动修改源:
# 进入路径并更换源
sudo vim /etc/apt/sources.list