Linux教程

AcWing《Linux基础课》第8讲 租云服务器及配环境

本文主要是介绍AcWing《Linux基础课》第8讲 租云服务器及配环境,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

8 租云服务器及配环境

8.1 介绍

云平台的作用

  • 存放docker容器,让计算在云端进行
  • 获得公网IP地址,让别人能访问到我们的服务

任选一个云平台,按如下方式配置

  • 1核 2GB(后期可以动态扩容,前期配置低一些没关系)
  • 网络带宽采用按量付费,最大带宽拉满即可(费用取决于用量,与最大带宽无关)
  • 系统版本:Ubuntu 20.04 LTS(推荐用统一版本,避免后期出现配置不兼容的问题)

租到的服务器

  • 毛坯
    • 框架(DJango)
    • Thrift
  • 服务(MySQL等)
    • socket方式:IP:Port
    • http方式

不建议直接在毛坯服务器搭房子,而是先搭建docker,方便后期迁移到其它平台,而且用于标准化,提高开发效率。因此主要开发工作在毛坯服务器中的docker里。

8.2 基本配置

创建用户

用ssh登录后,创建用户acs

adduser acs

分配sudo权限

usermod -aG sudo acs  # 给acs用户sudo权限

配置免密登录方式

在本地配置~/.ssh/config

把本地~/.ssh/id_rsa.pub复制到服务器的~/.ssh/authorzied_keys

配置新服务器的工作环境

把Ac Terminal的bashvimrctmux配置复制到服务器上

scp .bashrc .vimrc .tmux.conf server_name:

安装tmux

sudo apt-get update
sudo apt-get install tmux

打开tmux,在tmux安装docker,这样可防止终端异常关闭后,还能恢复到之前的进度。

8.3 docker安装与使用

8.3.1 安装

安装可参考官网教程

(1)配置仓库

sudo apt-get update

sudo apt-get install \
    ca-certificates \
    curl \
    gnupg \
    lsb-release

curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg

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

(2)安装docker

sudo apt-get update
sudo apt-get install docker-ce docker-ce-cli containerd.io

安装后可通过docker --version查看版本,如果出现则安装成功。

在使用前,可以给docker命令加上sudo权限,避免每次使用docker都要加上sudo$USER表示当前用户。执行下面命令后,会自动创建docker组,并让当前用户加入。

sudo usermod -aG docker $USER

8.3.2 使用教程

(1)基本原理

云平台有多种:轻量级云平台、ECS等。为了解决迁移困难,可把服务器配置到docker里,这样就能通过docker更换到不同的平台,减少迁移代价。

一个docker可以有多个镜像image,一个image可以有多个容器container。但这只是逻辑结构,而不是存储结构,docker不会真的一个个独立存储。镜像和容器的关系可以看做是印章和图案的关系。

在实际应用时,一个container是一个服务器。需要迁移时,在旧的云平台把container封装成image,然后在新的云平台读取image即可。

(2)镜像(Images)

  • 拉取镜像:docker pull ubuntu:20.04
  • 列举本地镜像:docker images
  • 删除镜像:docker image rm ubuntu:20.04docker rmi ubuntu:20.04
  • 创建某个container镜像:docker [container] commit CONTAINER IMAGE_NAME:TAG
  • 导出镜像ubuntu:20.04到文件ubuntu_20_04.tardocker save -o ubuntu_20_04.tar ubuntu:20.04
  • 从文件ubuntu_20_04.tar加载镜像ubuntu:20.04docker load -i ubuntu_20_04.tar

(3)容器(container)

  • 通过镜像创建容器:docker [container] create -it ubuntu:20.04
  • 列举本地容器:docker ps -a
  • 启动容器:docker [container] start CONTAINER
  • 停止容器:docker [container] stop CONTAINER
  • 重启容器:docker [container] restart CONTAINER
  • 通过镜像创建容器并启动:docker [container] run -itd ubuntu:20.04
  • 进入容器:docker [container] attach CONTAINER
    • 挂起容器:先按Ctrl-p,再按Ctrl-q
  • 在容器中执行命令:docker [container] exec CONTAINER COMMAND
  • 删除容器:docker [container] rm CONTAINER
  • 删除所有已停止的容器:docker container prune
  • 将容器CONTAINER导出到文件xxx.tardocker export -o xxx.tar CONTAINER
  • 将本地文件xxx.tar导入成镜像image_name:tagdocker import xxx.tar image_name:tag
  • 查看容器内进程:docker top CONTAINER
  • 查看所有容器状态:docker stats
  • 复制(类似scp):docker cp xxx CONTAINER:xxx
  • 重命名:docker rename CONTAINER1 CONTAINER2
  • 修改内存限制:docker update CONTARINER --memory 500MB

docker export./importdocker save/load的区别

  • export/import会丢弃历史记录和元数据信息,仅保存容器当时的快照状态
  • save/load会保存完整记录,体积更大

8.3.3 SSH登录docker

进入AC Terminal,然后

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 run -p 20000:22 --name my_docker_server -itd docker_lesson:1.0  # 将容器内的22端口(容器内的SSH端口)映射到本地的20000端口,然后创建并运行docker_lesson:1.0镜像

docker attach my_docker_server  # 进入创建的docker容器
passwd  # 设置root密码

注意,要先去云平台控制修改安全组配置,开放端口20000,IP填0.0.0.0/0表示所有都允许,协议选TCP,否则绑定端口的命令无效。

然后以云平台服务器的IP作为docker的IP,20000为端口号,就能以SSH方式访问docker

设置完就可使用SSH登录到docker内的服务器,可按照SSH一节设置免密登录等优化SSH登录方式,注意ssh需要加上参数-p 20000

如果apt-get下载软件较慢,可修改软件源到清华大学开源软件镜像站。

初次使用容器,用命令apt-get install sudo先安装sudo

8.4 作业核心代码

task1

(1)首先在腾讯云租一台云服务器。获取到公网IP后,在云服务器登录root账户,用passwd设置root账户密码,然后在目录~/.ssh下创建文件authorized_keys,把AC Terminal的公钥复制到该文件中。

(2)在AC Terminal修改~/.ssh/config文件

Host acs
	HostName xxx.xxx.xxx.xxx
	User root

(3)保存服务器别名

在AC Terminal执行

cd ~/homework/lesson_8/homework_0
echo "acs" > server_name.txt

task2

在AC Terminal用ssh acs登录到云服务器,执行如下命令

sudo apt-get update

sudo apt-get install \
    ca-certificates \
    curl \
    gnupg \
    lsb-release

curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg

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
  
sudo apt-get update
sudo apt-get install docker-ce docker-ce-cli containerd.io

sudo usermod -aG docker $USER

task3

(1)复制镜像

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

(2)加载镜像

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

(3)打开端口

在云服务器控制台开启端口20000,IP设置为0.0.0.0/0,协议选TCP

(4)用镜像创建容器并绑定端口

docker run -p 20000:22 --name my_docker_server -itd docker_lesson:1.0  # 创建并运行docker_lesson:1.0镜像

(5)打开容器

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

(6)创建新用户

passwd  # 设置root密码

adduser acs  # 创建用户acs
su acs  # 切换到acs用户

(7)添加SSH公钥

把AC Terminal的SSH公钥拷贝至服务器acs用户的~/.ssh/authorized_keys

cd ~
mkdir .ssh
vim .ssh/authorized_keys

(8)配置docker容器别名

在AC Terminal修改~/.ssh/config,加入如下配置信息,其中IP是云平台的服务器公网IP。

Host acs_docker
	HostName xxx.xxx.xxx.xxx
	User acs

(9)保存docker容器别名

在AC Terminal执行

cd ~/homework/lesson_8/homework_2
echo "acs_docker" > server_name.txt
这篇关于AcWing《Linux基础课》第8讲 租云服务器及配环境的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!