【Linux】使用腾讯云搭建CentOS的Linux编程学习环境,实现多用户使用同一个云服务器

为了帮助自己系统地学习Linux系统和命令行操作,我购入了腾讯云的轻量云服务器,预装了 CentOS7.6 系统

本篇博客是一个笔记,记录了创建过程中遇到的一些问题,包括:

  • 云服务器多用户隔离使用(因为我的服务器是和同学一起拼购的)
  • git仓库ssh密匙设置
  • 设置Xshell用户名的显示颜色

感谢你关注 慕雪 ,欢迎来我的寒舍坐坐 ❄慕雪的寒舍

以下是一个导读。其实不管是服主还是个人用户,都推荐使用以下阅读顺序

  • 如果你是服主,看本文的顺序是1→2(其中 2.1 跳过)→6→8→ 4.1
  • 配置好环境并 下载好git 后,服主就不需要做其他什么的了,就和其他人一起看完本文👇
  • 如果你不是服主,只需要看 2.2.4 连接上你的账户,即可开始操作 第3、4、5、7点 ,可跳过4.2和4.3

1.云服务器初始化

这部分tx云其实是有帮助文档的,但是它就是不在一个文档里面从头到尾写全,导致你需要翻来翻去找具体的操作,很恼火

1.1购买云服务器

选择腾讯云的理由很简单,现在它比阿里云便宜,2核心4GB的版本只需要168一年(作为对比,同时期 阿里云没有打折 ,1核2GB的版本99一年)

腾讯云校园计划https://cloud.tencent.com/act/campus

注意:如果你只买 一年 ,请不要购买下面的校园服务器!!!! 购买校园服务器的资格只有一次 ,只买一年就花掉这个资格太不划算了!!!

而且校园云服务器因为是“首单特惠”,是不支持 同价续费 的,续费价格也是天价!!!(续费要900多一年)

image-20220506124940333
在轻量应用服务器里面还有一个便宜的版本, 2核2GB只要58一年 ,但是那个 只能买一年 ,续费的价格很贵!!!(续费要900多一年)

  • 如果要买2-3年,请购买上面的校园服务器
  • 如果只买一年,请购买下面的这个 58/年 的版本 【链接】

在这里插入图片描述


注册腾讯云账户并实名认证后,就可以正常购买。这里不赘述了。

我选择的系统是 CentOS7.6 ,这个系统非常适合我们初学Linux

image-20220506125135372


1.2控制台管理

创建完实例后,你应该就能在控制台里面看到你的云服务器了,右下角显示的是公网IP,我们后续使用 Xshell链接 的时候需要它

image-20220506125230460

进入后做的第一件事,就是重置你的 root 账户密码。建议设置的稍微复杂一点,一定要用小本本记下来!

image-20220506125458720

1.3下载Xshell

我们需要用Xshell和Xftp作为我们的linux链接终端,点击官网链接下载

https://www.xshell.com/zh/free-for-home-school/

家庭和校园使用是免费的(个人用户)填了邮箱就可以了,官方会往你的邮箱里面发一个下载软件的链接

完成上面三步后,现在已经可以连接我们的云服务器了


2.连接云服务器

2.0直接连接root账户

你可以先使用root的账户密码以及公网ip连接服务器

image-20220506130027463

输入公网IP,端口号22不要改

image-20220506130046521

然后点击确认,在点击黄色的文件夹图标打开这个会话
在这里插入图片描述

系统会让你输入用户名和密码,使用用户名root和你刚刚设置的root密码就可以登录了


还可以在tx云这里直接点登录,会使用 tx云的默认账户lighthouse 连接你的云主机

image-20220506133550563

image-20220506133640401

这个方法只适合基础使用,下面讲解两个不同的方法


2.1使用SSH密钥

因为Xshell比较聪明,会帮我们记住账户密码,自动输入。
但是在很多软件(比如putty)每次开启连接都需要输入账户和密码。这时候我们可以使用更加安全的加密SSH方式连接我们的终端

如果你想达到多人一机的目的,请跳过本步骤,直接看 2.2

2.1.1创建本地密钥

在Xshell的选项卡中,新建一个密匙

image-20220506130309080

无需修改默认参数

image-20220506130431153

这里会让你输入密匙名称和密码,请记住这里的密码!如果忘记了就只能重新生成一个密匙了

image-20220506130450261


生成完毕后,点击 用户密匙管理者

image-20220506130533147

找到刚刚生成的密匙,点击 属性-公钥 ,把这里的内容复制下来

image-20220506130615084

2.1.2绑定实例

然后来到tx云控制台,密钥,点击创建密钥

image-20220506130712353

选择已有公钥,把刚刚复制的内容丢进去并起个名字。注意这里的地域必须和云服务选择的相同!

image-20220506130821602

搞定后,在云服务器的 密钥对 界面中绑定密钥(需要先把云服务器关机)

image-20220506130927104

绑定成功后,重启云服务器

2.1.3Xshell会话设置

新建一个会话,这里同样填公网ip

image-20220506131050906

然后需要设置 用户身份验证 ,这里很重要!Xshell提示“ 密钥没有和云服务器绑定 ”都是因为这里没有设置!

image-20220506131146674

选择你创建的本地密匙,输入 创建密匙 时的密码!

image-20220506131306753

不出意外,设置完毕后,你就可以免登录连接到云服务器的root用户了


这个方案只适用于 单用户使用 ,如果多个用户想用这个方法连接同一个云服务器,就会出现大家一起用一个文件路径的问题(就比如我和同学拼,大家都用SSH连接了root用户,白搞)

但实际上,使用linux的大部分时候 不应该用root 。所以即便是单用户使用,也可考虑直接使用 2.2 的账户密码方式登录

目前我没找到如何用SSH密匙连接到云服务器指定用户下

2.2使用账户密码登录实现多人一机

Linux系统是可以实现多用户管理的,首先我们要创建一个新的用户

参考https://cloud.tencent.com/developer/ask/24465

2.2.1创建新用户

先用root连接终端,输入

sudo useradd -g root 用户名

这个命令的含义是在root分组下(这个是默认的分组)建立一个新的用户,用户名自定义

sudo passwd 用户名

然后使用这个命令设置刚刚创建的那个用户的密码

注意,Linux输入密码不会有任何提示,直接盲打就行了

随后,使用下面命令测试进入另外一个用户

su - 用户名

因为我们是从具有最高权限的root用户进入子用户,所以是不需要输入密码的,但是如果你从子用户往root跑,就需要输入root用户的密码!

image-20220506132432269

你可以在root用户和子用户终端下用 mkdir 文件夹名字 创建两个不同的文件夹, ls 查看当前路径下的文件夹

你会发现,root和另外一个用户直接是相互看不到对方的文件夹的,这就是我们要达到的 隔离 效果!相当于互不干扰!

子用户A 跑到 子用户B 中,需要 输入子用户B的密码

这需要root用户在里面创建新的用户,所以服主是知道每个用户的密码的。这就看你们的信任问题了。如果真的信不过, 就让每个人进root账户,自己设置自己账户的密码 ,那就没啥问题了

2.2.2修改密码

实际上,在自己的用户名下,是可以更改当前用户名的密码的

passwd

image-20220506135432652

注意,Linux输入密码不会有任何提示,直接盲打就行了

所以可以让服主创建好用户后,自己登陆进去,把自己的密码改掉

注意: Linux学习中有时候会有一些指令只有root用户能干,所以最好是不要那么在乎这些“隐私问题”,root也公开给大家使用就行了

一般情况下,直接在某一个语句之前加 sudo ,就会用上root权限

2.2.3腾讯云多用户管理

另外,腾讯云支持多用户管理,你可以在用户组这里邀请其他人,他们就能在自己的控制台里面看到你的云服务器了

image-20220506133404135


2.2.4Xshell使用账户密码连接

这时候我们就不能使用ssh密钥登录了,而是使用账户和密码

使用这个方式前,貌似需要在云服务器控制台解绑所有SSH密钥

刚开始直接连接会显示“SSH服务器拒绝了密码”,这是因为我们没有开启允许密码登录

image-20220508070947625

参考https://cloud.tencent.com/developer/article/1909909

在root用户下,使用vim打开下面这个文件。如果你不会使用vim编辑器,请见本文的第三点

vim /etc/ssh/sshd_config

在最后添加下面的这个语句, :wq! 保存并退出

PasswordAuthentication=yes

image-20220508071753946

搞定后,重启云主机,即可用账号密码登录其他账户

如果设置了这个还是不行,可以在控制台中直接重置root密码。重置密码的时候会自动帮你设置好这个(如果没有就再手动设置一下,哈哈)


image-20220507182442436

在Xshell中直接用对应的 账户和密码登录 ,就可以打开每个单独的账户

image-20220506134009468

X11警告是正常现象,请忽略它

image-20220506133944195

到这里,你就可以和好基友分享这个服务器了! 成本大大降低

2.3查看当前使用云服务器的用户

在Xshell终端中输入 who ,可以查看当前有谁连接了云服务器

这里会显示连接云服务器的 时间 pts 代表远程连接, /2 代表不同的远程连接端口

image-20220507175054277


3.一些基本的Linux指令

之前写博客的时候,忽略了大家可能都是第一次上手linux,对linux命令行一窍不通的。有朋友反应后面的git操作, 很多部分都搞不明白怎么用

这里列出本篇博客需要用到的一些linux指令和vim编辑器的指令。注意,这个只是帮助你完成本篇博客向导后续的git设置,并不是一个完整的命令行教学。 建议自行搜索git命令行以及Linux命令行进行学习

3.1Linux指令

ls #显示当前路径下的所有文件
ls -a #显示当前路径下包括隐藏文件的所有文件

cd 文件路径   #打开对应文件路径
cd ..   #回到上一个文件目录
cd ~   #回到用户的根目录

touch 文件名  #创建对应的文件
mkdir 文件夹名字 #创建一个文件夹
mv 源路径 目标路径 #移动文件夹或者文件
#mv语句还用于重命名文件,操作是
mv 原来的名字 新名字

cat 文件名字  #显示对应文本文件的内容
#如cat .gitconfig,会显示.gitconfig文件中的所有内容

下图演示了部分语句,能帮助你理解这些命令的作用

image-20220507174854931

如果你不小心输错了某些指令或者指令没输入完毕就按了回车,可以使用 ctrl+c 终止当前操作,linux会另起一个新的入口给你输入命令

image-20220507181246137

3.2vim编辑器操作

vim 文件名 #打开对应的文件进行写入

这里我直接以编辑一个C++程序为例,演示vim的操作

image-20220507175346538

打开后是这样的,因为你的vim编辑器还没有设置( 见本文第5点 ),所以和我的不一样,但是这不影响我们的操作。

注意左下角是vim指令输入的位置以及vim当前模式的提示位置

image-20220508072430088

现在往这个文件中键入内容,你会发现无法键入,这是因为vim是查看模式,我们需要在 英文模式下 按键盘上的的 i (中文模式按i是没有反应的)开启vim的插入模式(也就是insert模式)

image-20220507175636394

开启插入模式后,你就可以往这个文件里面写入内容了。注意vim编辑器是基于键盘的,你需要用键盘方向键定位位置,而不是用鼠标

image-20220507175855562

我往文件中新增了c++语法的内容,现在我想保存这个文件,并退出vim编辑器

操作是先在英文模式下 按键盘的ESC退出插入模式 ,然后输入 :wq 保存并退出文件

image-20220507180244337

这就回到了之前的linux命令行界面

image-20220507180121116

下面给出一些常用的vim指令,后续配置git的时候会用到

:w  #保存文件,相当于windows的ctrl+s
:q  #退出文件,前提是这个文件没有被更改
#如果你不想保存刚刚的更改,可以使用
:q! #强制退出文件
:wq #保存并退出文件
:wq! #因为部分文件是配置文件,系统权限不够,所以需要加!绕开
#后续在编辑gitconfig文件的时候,就需要使用:wq!
  • 如果你想从windows中复制内容,粘贴到终端中,需要使用 shift+ins 键而不是使用 ctrl+v
  • 复制 ctrl+ins ,粘贴 shift+ins
  • 如果你不小心习惯性地按了 ctrl+s 并发现系统卡住了,那是因为这个快捷键在Linux中是暂停终端,可以按 ctrl+q 复原

上面讲述了vim的一些操作,下面让我们来尝试一下编一个代码

3.3尝试编译代码

C++需要使用 g++ 编译器来编译代码,如果是C语言内容,则使用 gcc 来编译,操作是一样的

以下面的指令编译我们刚刚写的代码文件,生成可执行文件TEST

g++ test.cpp -o TEST

可以看到编译器报错了,我们再vim回去修改代码

image-20220507180426510

修改完毕后,重新编译我们的代码,可以看到没有报错,生成了可执行文件TEST

image-20220507180524679

使用 ./TEST 语句运行可执行文件TEST,即可看到程序输出结果

image-20220507180631540

好了,学会这些后,你应该就能完成后面git的配置操作了!😋


4.Linux的git设置

这里我们使用账户密码方式来配置我们的git,因为ssh密钥的方式出现了些许bug

4.1下载git

输入下面的指令查看git的版本,如果没有出现,那说明git没有被安装

git --version

CentOS 使用下面的指令安装, 必须使用root用户 。其他LINUX系统需要把 yum 改成 apt-get

sudo yum install git

image-20220506141253738

因为我之前用了树莓派,使用的是 apt-get 。在这上面不管用,我还去搜了好久为啥 sudo: apt-get: command not found 😥

后面才知道CentOS使用的方法不一样

4.2创建SSH密匙

为了避免产生误导,且在我的环境下ssh配置git失败。这部分单独成文
我建议是直接使用下面4.3的方式哈

SSH方式不知为何,在我的云主机上,只有当次设置有效,重新打开终端连接云服务器(云服务器没有重启)SSH就会失效。 在我的Linux用户目录下以及我朋友的用户目录下都出现了这个问题!

image-20220507135346748

如果你也出现了这个问题,请直接跳过4.2,使用4.3提到的账户密码方式

如果你想学习SSH的方式,那也可以试试👉 传送门

22-06-19更新:这个问题已经被我解决,直接看传送门的那篇文章即可

注: 如果你是github用户,且使用 https仓库链接 时,多次遇到各种各样的无法连接问题,则需要切换使用ssh方式与github通信!这能解决大部分类似 time out 的网络问题


4.3使用账户密码方式操作git

其实在配置之 前,我也不知道 git config 可不可以实现多用户独立上传,但是我 知道 以为 )SSH肯定可以😂

现在ssh确认出了点问题,所以该用账户密码方式

①配置全局git设置

直接使用下面3个语句来设置某个Linux用户下的 全局 git邮箱和用户名

git config --global user.email "you@example.com"
git config --global user.name "Your Name"
git config --global push.default current

测试了一下 --global 指令后,发现它保存的文件是我们 用户路径 下的,而 不是root下的全局目录 。经过我和同学的测试,这个方法可以在每一次连接终端的时候都保存下来,不会出现SSH那个需要重新设置的情况

使用下面这个指令可以查看git配置文件的内容,每个不同的Linux用户中,配置文件互不影响

cat .gitconfig 

image-20220506142554556

使用SSH的好处是不需要输入密码,不过我们可以用git指令来让git保存你的密码,这样也能在之后的上传中不需要输入密码,操作是编辑 .gitconfig 文件,在最后加上这两行:作用是在下一次执行 git push 操作的时候,保存用户名和密码

[credential]      
    helper = store

使用 vim .gitconfig 修改后的配置文件应该和我这个相同

[user]
	email = 你的gitee邮箱
	name = 用户名
[push]
	default = current

[credential]
	helper = store

image-20220507133438729

②克隆和上传操作

使用 mkdir 文件夹名 创建一个文件夹, cd 进去后,执行clone工作,这时候需要使用的是 HTTPS 链接

image-20220507181739530

git clone 远程仓库的https链接

image-20220508232517550

如果你之前使用了SSH克隆了仓库,可以考虑重新克隆,也可以使用下面的语句更改仓库 URL ,注意这里的URL是 新的地址

git remote set-url origin URL 

cd 进入仓库目录,即可修改仓库中的文件

image-20220507202952129

修改完毕后,先用 git status 查看当前状态

image-20220507203142788

可以看到这里列出来我们的 README文件 被修改了,下面执行一次 git push 操作。这部分涉及到git命令行操作,如果你不会,可以搜几篇git的博客学习一下

git add 文件夹 #添加需要上传的文件路径
git commit -m "输入push信息" #git push的信息

这里的 git add 可以添加单个文件,也可以添加整个文件夹

image-20220507203330008

git push #和远程仓库同步

最后 git push 的时候,会提示让你输入远程仓库的用户名和密码

我同学尝试的时候,这里出现了报错。本来我们以为是 用户名或者密码有问题 ,一直在找到底是哪里出错了

fatal: Authentication failed for 'https://gitee.com/……'

实际上是因为我们填错了!!! 链接

image-20220507134559185

正确的填写方法应该是这样!!!我们 错误的把第一个填了gitee的用户名 ,应该要填写的是gitee账户的 邮箱

Username for 'https://gitee.com': 你的gitee邮箱
Password for 'https://xxxxx@gitee.com': 填gitee密码

注:这里填写密码的时候是 不会显示内容的 ,直接盲打就可以了

修改正确之后就可以正常PUSH代码了

image-20220507135118044

经过 我和同学的测试 ,这个方法 不会 因为终端关闭而重置,可以多次复用且不需要每次都输入git的账户和密码,计划通!

git命令行语句的进阶学习👉 传送门


5.vim编辑器设置

腾讯云的CentOS已经默认安装了vim编辑器,但是vim编辑器本身的默认设置和我们的习惯不同,比如tap它默认是8个空格(windows下是4个)以及缩进的一些问题,这就需要我们自己设置一下vim编辑器

vim  ~/.vimrc

用上面的语句打开vim编辑器后,用 i 开启vim的插入模式,输入下面的命令

syntax on #开启语法高亮
set nu  #显示行号
set tabstop=4 #设置tap为4个空格
set softtabstop=4 
set shiftwidth=4 
set autoindent #自动对齐

写完后, :wq! 保存即可

这里我给出了注释,实际写入配置文件的时候,请去掉注释

6.将Linux命令行设置为中文

CentOS 为例,默认的命令行显示是全英文的(但这不代表你不能在里面设置中文的文件夹名字)

我们打开云服务器的 root账户 (必须是root账户)

locale

使用上面的这个指令查看现在的语言,发现是en英文

image-20220506190942040

locale -a

使用上述命令查看 当前支持的语言 ,会显示一大堆,滑到最底部,可以看到我这个系统里面已经有了 zh-CN ,支持中文!

image-20220509123826825

如果 locale -a 发现没有出现zh,那就下载中文支持包

yum install kde-l10n-Chinese

腾讯云的CentOS里面已经有中文了,所以不需要进行这一步操作


修改系统语言为中文

localectl set-locale LANG=zh_CN.utf8

重启Xshell终端(不是重启云服务器),再次使用 locale 指令查看,发现已经设置成了中文语言包

image-20220507135957731

重启Xshell终端(不是重启云服务器),就可以看到,git这里的提示已经变成了中文。不然就是上文出现过的的英文页面👉 回到上头康康

image-20220506190618425

修改Xshell中文显示字体

如果你觉得默认的中文字体很难看,可以在Xshell中修改一下,点击左上角的 文件-当前会话属性

image-20220507140140107

找到 外观 ,把亚洲字体改成黑体,看起来就舒服多了

image-20220507140236380

这里还可以更改 游标 的样式,我改成了在windows中更熟悉的 竖线 样式

7.Xshell设置用户名显示颜色

参考https://blog.csdn.net/nmb_jiang/article/details/105195981

默认情况下,Xshell显示的服务器用户名和名字都是白色的

image-20220506134202855

敲的命令多了之后,就分不清啥是啥了,眼睛都得瞎掉

我们可以设置一下,以CentOS为例,需要用vim编辑器打开 .bashrc 文件

vim .bashrc

在打开的文件中,键入 i 开启vim的编辑模式,在文件的末尾输入

PS1='[\[\033[01;32m\]\u@\h\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\]]\$ '

输入完毕后,按 esc 退出插入模式,输入 :wq! 保存该文件

然后运行下面的指令使其生效

source .bashrc

image-20220506134547990

看起来就舒服多了

另外,建议把root改成黄色+绿色的组合,和子用户区分开来。修改的方法是一样的

PS1='[\[\033[01;33m\]\u@\h\[\033[00m\]:\[\033[01;32m\]\w\[\033[00m\]]\$ '

8.出现is not in the sudoers file解决方法

当我们使用sudo命令切换用户的时候可能会遇到提示以下错误: 用户名 is not in the sudoers file.

我们需要把当前用户加入sudo的配置文件中

在root用户下,打开 sudo 的配置文件

vim /etc/sudoers

打开这个文件,你会发现腾讯云的默认用户 lighthouse 已经添加过这个语句了。我们在最后加上 xxx ALL=(ALL) ALL ,其中xxx代表用户名

img

结语

看到这里,云Linux编程学习环境就搭建好啦!

速速开始学习Linux命令行吧!👍

QQ图片20220504102516

有什么问题可以在评论区提出哦!


版权声明:本文为muxuen原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。