Linux知识入门(一)
文章目录
- vi编辑器介绍
- 关于vim
- vim三种模式(重点)
- Vim的打开文件的方式
- 命令模式
- 光标移动
- 复制操作
- 剪切/删除
- 撤销/恢复
- 光标的快速移动
- 模式间的切换(重点)
- 末行模式
- 编辑模式
- 实用功能
- 代码着色
- vim中计算器的使用
- vim配置(重点)
- 异常退出
- 别名机制
- 退出方式
- Linux自有服务
- 运行模式
- 用户与用户组管理(重点)
- 用户管理
- 认识passwd文件
- 用户组管理
- 网络设置
- 扩展一 —— 修改网卡配置文件
- 扩展二 —— 重启网卡
- SSH服务(重点)
- 远程终端
- SSH服务文件传输
- 通过命令行工具来传输文件/文件夹
vi编辑器介绍
Vi
编辑器是所有Unix
及Linux
系统下标准的编辑器,类似于windows
系统下的记事本编辑器,由于在Unix
及Linux
系统的任何版本,Vi
编辑器是完全相同的,Vi
也是Linux
中最基本的文本编辑器,学会它后,我们将在Linux
的世界里畅行无阻,尤其是在终端中。
关于vim
vi
和vim
都是Linux中的编辑器,不同的是,vim
比较高级,可以视为vi
的升级版本。vi
使用于文本编辑,但是vim
更适用于coding
【写代码的】。vim
重点是光标的移动,模式切换,删除,查找,替换,复制,粘贴,撤销命令的使用。
vim三种模式(重点)
Vim
中存在三种模式:命令模式、编辑模式【输入模式】、末行模式【尾行模式】。
命令模式:在该模式下是不能对文件直接编辑,可以输入快捷键进行一些操作(删除行,复制行,移动光标,粘贴等等)【打开文件之后默认进入的模式】;
编辑模式:在该模式下可以对文件的内容进行编辑;
末行模式:可以在末行输入命令来对文件进行操作【搜索、替换、保存、退出、撤销、高亮等等】;
Vim的打开文件的方式
vim指令学习
vim 文件路径
:打开指定的文件vim +数字 文件的路径
:打开指定的文件,并且将光标移动到指定行vim +/关键词 文件的路径
:打开指定的文件,并且高亮显示关键词vim 文件路径1 文件路径2 文件路径3
:同时打开多个文件
命令模式
光标移动
-
光标移动到行首
按键:shift + 6
或^
-
光标移动到行尾
按键:shift + 4
或$
-
光标移动到首行
按键:gg
-
光标移动到末行
按键:G
-
翻屏
向上翻屏:按键ctrl + b
或PgUp
↑
向下翻屏:按键ctrl + f
或 PgDn↓
复制操作
-
复制光标所在行
按键:yy
粘贴:在想要粘贴的地方按下p
键 -
以光标所在行为准(包含当前行),向下复制指定的行数
按键:数字yy
-
可视化复制
按键:ctrl + v
(可视块)或V
(可视行)或v
(可视),然后按下↑↓←→
方向键来选中需要复制的区块,按下y键进行复制,最后按下p
键粘贴。
剪切/删除
-
剪切/删除光标所在行
按键:dd
【删除之后光标不动,下一行上移】
注意:dd
严格意义上说是剪切命令,但是如果剪切了不粘贴就是删除的效果。 -
剪切/删除光标所在行为准【包含当前行】,向下删除/剪切指定的行
按键:数字dd
【删除之后光标不动,下一行上移】 -
剪切/删除光标所在的当前行之后的内容,但是删除之后下一行不上移
按键:D
【删除之后当前行会变成空白行】 -
可视化删除
按键:ctrl + v
(可视块)或V
(可视行)或v
(可视),上下左右移动,按下D
表示删除选中行,d
表示删选中块。
撤销/恢复
撤销:输入:u
或者u
【全称undo
,不属于命令模式】
恢复:ctrl + r
恢复(取消)之前的撤销操作【windows
中使用ctrl + y
恢复】
光标的快速移动
-
快速将光标移动到指定的行
按键:数字G
-
以当前光标为准向上/向下移动n行
按键:数字↑
,数字↓
-
以当前光标为准向左/向右移动
n
字符
按键:数字←
,数字→
-
末行模式下的快速移动方式:移动到指定的行
按键:输入英文“:
”,其后输入行数数字,按下回车
模式间的切换(重点)
末行模式
进入方式:由命令模式进入,按下“:
”或者“/
(表示查找)”即可进入。
退出方式:
a. 按下
esc
b. 连按2次esc
键
c. 删除末行全部输入字符
-
保存操作(
write
)
输入:“:w
” : 保存文件
输入:“:w 路径
”: 另存为 -
退出(
quit
)
输入:“:q
” 退出文件 -
保存并退出
输入:“:wq
”: 保存并且退出 -
强制 (
!
)
输入:“:q!
” :表示强制退出,刚才做的修改操作不做保存 -
调用外部命令
输入:“:!外部命令
”
当外部命令执行结束之后按下任意键回到vim
编辑器打开的内容。 -
搜索/查找
输入:“/关键词
”
例如:我想在passwd
文件中搜索“sbin
”关键词
在搜索结果中切换上/下一个结果:N/n
如果需要取消高亮,则需要输入:“:nohl
”【no highlight
】 -
替换
:s/搜索的关键词/新的内容
:替换光标所在行的第一处符合条件的内容
:s/搜索的关键词/新的内容/g
:替换光标所在行的全部符合条件的内容
:%s/搜索的关键词/新的内容
:替换整个文档中每行第一个符合条件的内容
:%s/搜索的关键词/新的内容/g
:替换整个文档的符合条件的内容
%
表示整个文件
g
表示全局(global
) -
显示行号(临时)
输入:“:set nu
”
如果想取消显示,则输入:“:set nonu
” -
使用
vim
同时打开多个文件,在末行模式下进行切换文件
-
查看当前已经打开的文件名称:“
:files
”
在%a
的位置有2
种显示可能:
%a
:a=active
,表示当前正在打开的文件;
#
:表示上一个打开的文件。 -
切换文件的方式:
a. 如果需要指定切换文件的名称,则可以输入:“:open 已经打开的文件名
”
b. 可以通过其他命令来切换上一个文件/下一个文件
输入:“:bn
”切换到下一个文件【back next
】
输入:“:bp
”切换到上一个文件【back prev
】
编辑模式
重点看前2个进入方式:i
(insert)、a
(after)。
退出方式:按下esc
键
实用功能
代码着色
如何控制着色显示?
- 显示【默认】:“
:syntax on
” - 关闭显示:“
:syntax off
”
vim中计算器的使用
当在编辑文件的时候突然需要使用计算器去计算一些公式,则此时需要用计算器,但是需要退出,vim
自身集成了一个简易的计算器。
a
. 进入编辑模式;
b
. 按下按键“ctrl + R
”,然后输入“=
”,此时光标会变到最后一行;
c
. 输入需要计算的内容,按下回车。
vim配置(重点)
Vim是一款编辑器,编辑器也是有配置文件的。
Vim配置有三种情况:
a
. 在文件打开的时候在末行模式下输入的配置(临时的)
b
. 个人配置文件(~/.vimrc
,如果没有可以自行新建)
c
. 全局配置文件(vim
自带,/etc/vimrc
)
-
新建好个人配置文件之后进入编辑
-
在配置文件中进行配置
比如显示行号:set nu
配置好之后vim
打开文件就会永远显示行号 -
问题:如果某个配置项,在个人配置文件与全局配置文件产生冲突的时候应该以谁为准?
测试步骤:在两个配置文件中针对同一个配置项设置不同的值①先在全局的配置中设置不显示行号,在个人的配置文件中设置显示行号,观察结果
最后显示行号:说明以个人为准②先在全局中配置显示行号,在个人中设置不显示行号,观察结果
最后的显示是不显示行号,说明以个人为准结论:如果针对同一个配置项,个人配置文件中存在,则以个人配置文件为准,如果个人配置文件中不存在这一项,则以全局配置文件为准。
异常退出
什么是异常退出?
在编辑文件之后并没有正常的wq
(保存退出),而是遇到突然关闭终端或者断电的情况,则会显示下面的效果,这个情况称之为异常退出:
解决办法:将交换文件(在编程过程中产生的临时文件)删除掉即可
rm -f .passwd.swp
别名机制
作用:相当于创建一些属于自己的自定义命令
例如:在windows
下有cls
命令,在Linux
下可能因为没有这个命令而不习惯清屏。现在可以通过别名机制来解决这个问题,可以自己创造出cls
命令。
别名机制依靠一个别名映射文件:~/.bashrc
vim ~/.bashrc
注意:如果想新创造的命令生效,必须要重新登录当前用户。
退出方式
回顾:之前vim
中退出编辑的文件可以使用“:q
”或者“:wq
”。
除了上面的这个语法之外,vim
还支持另外一个保存退出方法“:x
”。
说明:
①“:x
”在文件没有修改的情况下,表示直接退出,在文件修改的情况下表示保存并退出;
②如果文件没有被修改,但是使用wq
进行退出的话,则文件的修改时间会被更新;但是如果文件没有被修改,使用x
进行退出的话,则文件修改时间不会被更新的;主要是会混淆用户对文件的修改时间的认定。
因此建议以后使用“:x
”来进行对文件的保存退出。
但是:不要使用X
,X
表示对文件进行加密操作。
Linux自有服务
自有服务,即不需要用户独立去安装的软件的服务,而是当系统安装好之后就可以直接使用的服务(内置)。
运行模式
-
运行模式也可以称之为运行级别。
-
在linux中存在一个进程:
init
【initialize,初始化】,进程id
是1
。
查看进程:ps -ef|grep init
-
该进程存在一个对应的配置文件:
inittab
【系统运行级别配置文件,位置/etc/inittab
】
文件的主要内容:
-
centos6.5
中存在7种运行级别/模式:
0
— 表示关机级别(不要将默认的运行级别设置成这个值)
1
— 单用户模式
2
— 多用户模式,不带NFS
(Network File Syetem)
3
— 多用户模式,完全的多用户模式(不带桌面的,纯命令行模式)
4
— 没有被使用的模式(被保留模式)
5
—X11
,完整的图形化界面模式
6
— 表示重启级别(不要将默认的运行级别设置成这个值)
与该级别相关的几个命令:
init 0
表示关机
init 3
表示切换到不带桌面的模式
init 5
切换到图形界面
init 6
重启电脑
注意:init
指令需要超级管理员的权限,普通用户无法执行。
这些命令其实都是调用的init
进程,将数字(运行级别)传递给进程,进程去读配置文件执行对应的操作。
① 切换到纯命令行模式下【临时切换,重启之后又恢复】
init 3
:切换之后需要输入用户名和密码,在输入密码的时候没有“*
”提示输入,只要自己确认输入的密码没有错误,按下回车即可。
② 回到桌面模式:init 5
③ 设置模式永久为命令行模式:将/etc/inittab
文件中的initdefault
值设置成3
,然后重启操作系统。
用户与用户组管理(重点)
-
Linux
系统是一个多用户多任务的操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统。 -
用户的账号一方面可以帮助系统管理员对使用系统的用户进行跟踪,并控制他们对系统资源的访问;另一方面也可以帮助用户组织文件,并为用户提供安全性保护。
-
每个用户账号都拥有一个惟一的用户名和各自的密码。
-
用户在登录时键入正确的用户名和密码后,就能够进入系统和自己的主目录。
-
要想实现用户账号的管理,要完成的工作主要有如下几个方面:
用户账号的添加、删除、修改以及用户密码的管理。
用户组的管理。 -
注意三个文件:
/etc/passwd
存储用户的关键信息
/etc/group
存储用户组的关键信息
/etc/shadow
存储用户的密码信息
用户管理
- 添加用户
常用语法:useradd 选项 用户名
常用选项:
-g
:表示指定用户的用户主组,选项的值可以是用户组的id
,也可以是组名
-G
:表示指定用户的用户附加组,选项的值可以是用户组的id
,也可以是组名
-u
:uid
,用户的id
(用户的标识符),系统默认会从500
之后按顺序分配uid
,如果不想使用系统分配的,可以通过该选项自定义【类似于腾讯QQ的自选账号情况】
-c comment
:添加注释
验证:
a
. 验证/etc/passwd
的最后一行,查看是否有zhangsan
的信息;
b
. 验证是否存在家目录(在Centos
下创建好用户之后随之产生一个同名家目录ls /home
);
认识passwd文件
用户名:密码:用户ID:用户组ID:注释:家目录:解释器shell
用户名:创建新用户名称,后期登录的时候需要输入;
密码:此密码位置一般情况都是“x
”,表示密码的占位;
用户ID
:用户的识别符;
用户组ID
:该用户所属的主组ID
;
注释:解释该用户是做什么用的;
家目录:用户登录进入系统之后默认的位置;
解释器shell
:等待用户进入系统之后,用户输入指令之后,该解释器会收集用户输入的指令,传递给内核处理;
注意:在不添加选项的时候,执行useradd
之后会执行一系列的操作
a
. 创建同名的家目录;
b
. 创建同名的用户组;
案例:添加选项,创建用户lisi,让lisi属于501主组,附加组500,自选靓号666。
注意:查看用户的主组可以查看passwd
文件,查看附加组可以查看group
文件。
- 修改用户
常用语法:usermod 选项 用户名
【Usermod
:user modify
,用户修改】
常用选项:
-g
:表示指定用户的用户主组,选项的值可以是用户组的id
,也可以是组名
-G
:表示指定用户的用户附加组,选项的值可以是用户组的id
,也可以是组名
-u
:uid
,用户的id
(用户的标识符),系统默认会从500
之后按顺序分配uid,如果不想使用系统分配的,可以通过该选项自定义【类似于腾讯QQ的自选账号情况】
-l
:修改用户名
案例1:修改zhangsan用户主组为500,附加组改为501
usermod -g 500 -G 501 zhangsan
案例2:修改zhangsan用户用户名,改为wangerma
usermod -l 新的用户名 旧的用户名
usermod -l wangerma zhangsan
-
设置密码
Linux
不允许没有密码的用户登录到系统,因此前面创建的用户目前都处于锁定状态,需要设置密码之后才能登录计算机。
常用语法:passwd 用户名
在设置密码的时候也是没有任何输入提示的,放心输入,确保两次输入的密码一致,按下回车即可。也可以使用弱密码,但是不建议,否则会看到以下的提示:
设置密码之后
shadow
文件中的体现:能够看出lisi用户没有密码的。
在设置用户密码之后可以登录帐号,例如此处需要登录wangerma:
-
删除用户
常用语法:userdel 选项 用户名
【Userdel
:user delete
(用户删除)】
常用选项:
-r
:表示删除用户的同时,删除其家目录;
案例:删除wangerma用户
注意:已经登录的wangerma
用户删除的时候提示删除失败,但是没有登录的lisi
用户可以正常删除。
解决办法:简单粗暴,kill
对应用户的全部进程
提示:所有跟用户操作的命令(除passwd
外)只有root
超级管理员有权限执行。
用户组管理
- 每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。
- 不同
Linux
系统对用户组的规定有所不同,如Linux
下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。 - 用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对
/etc/group
文件的更新。
文件结构:用户组名:密码:用户组ID:组内用户名
密码:X
表示占位符,虽然用户组可以设置密码,但是绝大部分的情况下不设置密码;
组内用户名:表示附加组是该组的用户名称;
- 添加用户组
常用语法:groupadd 选项 用户组名
常用选项:
-g
:类似用户添加里的“-u
”,-g
表示选择自己设置一个自定义的用户组ID数字,如果自己不指定,则默认从500之后递增;
案例:使用groupadd指令创建一个新的用户组,命名为Administrators
- 编辑用户组
常用语法:groupmod 选项 用户组名
常用选项:
-g
:类似用户修改里的“-u
”,-g
表示选择自己设置一个自定义的用户组ID数字
-n
:类似于用户修改“-l
”,表示设置新的用户组的名称
案例:修改Administrators用户组,将组ID从502改成520,将名称改为admins
- 删除用户组
常用语法:groupdel 用户组名
注意:当如果需要删除一个组,但是这个组是某个用户的主组时,则不允许删除;如果确实需要删除,则先从组内移出所有用户。
网络设置
首先知道网卡配置文件位置:/etc/sysconfig/network-scripts
在目录中网卡的配置文件命名格式:ifcfg-网卡名称
ONBOOT
:是否开机启动
BOOTPROTO
:ip
地址分配方式,DHCP
表示动态主机分配协议
HWADDR
:硬件地址,MAC
地址
如果后续需要重启网卡怎么去操作呢:service network restart
在有的分支版本中可能没有service
命令来快速操作服务,但是有一个共性的目录:/etc/init.d
,这个目录中放着很多服务的快捷方式。
此处重启网卡命令还可以使用:/etc/init.d/network restart
扩展一 —— 修改网卡配置文件
如果修改网卡的配置文件,但是配置文件的目录层次很深,此时可以在浅的目录中创建一个快捷方式(软连接),方便以后去查找
ln -s 原始文件的路径 快捷方式的路径
其中,文件类型位置的“l
”表示其类型为link
(连接类型),后面的“->
”指向的是原始文件路径。
扩展二 —— 重启网卡
如何去重启单个网卡?
停止某个网卡:ifdown 网卡名
开启某个网卡:ifup 网卡名
例如:需要停止-启动(重启)eth0
网卡,则可以输入
ifdown eth0
ifup eth0
提示:在实际工作的时候不要随意禁网卡。
SSH服务(重点)
ssh
(secure shell
,安全外壳协议),该协议有2个常用的作用:远程连接协议、远程文件传输协议。- 协议使用端口号:默认是
22
- 可以是被修改的,如果需要修改,则需要修改ssh服务的配置文件:
/etc/ssh/ssh_config
- 端口号可以修改,但是得注意2个事项:
a. 注意范围,端口范围是从0-65535
;
b. 不能使用别的服务已经占用的端口; - 服务启动/停止/重启【不建议频繁使用此命令】
service sshd start/stop/restart
/etc/init.d/sshd start/stop/restart
远程终端
终端工具主要帮助运维人员连接远程的服务器,常见终端工具有:Xshell
、secureCRT
、Putty
等。以putty为例:
① 获取服务器ip
地址,可以通过ifconfig
命令进行查看,然后顺手测试ip的连接相通性
② 打开putty
,输入相关的信息
③ 在弹出key
确认的时候点击“是”,以后不会再提示
④ 输入登录信息
SSH服务文件传输
以可视化的界面传输工具Filezilla
为例:
① 选择“文件”- “站点管理器【Ctrl + S
】”
②点击“文件”菜单下方的“▽
”选择需要连接的服务器,连接好之后的效果
③从本地windows
上传文件到linux
中方式:
支持直接拖拽文件,也可以右键本地需要上传的文件,然后点选“上传”即可
④ 下载linux
文件到本地:
支持服务器文件直接拖拽到本地,也可以在右侧窗口选择需要下载的文件,右键,点选“下载”。
通过命令行工具来传输文件/文件夹
-
工具:
PSCP.exe
(必须通过cmd
命令行打开),为了使用方便可以将其放到环境变量目录中;如果不清楚哪些路径是环境变量路径,只需要将其放到C:/Windows
目录下即可。
-
用法:
a.pscp 选项 用户名@linux主机地址:资源路径 windows本地的地址
【下载到win
】
b.pscp 选项 资源路径 用户名@linux主机地址:远程路径
【上传到linux
】
c.pscp 选项 -ls 用户名@linux主机地址
【列出远程路径下结构】①下载到本地
windows
:
要求将远程linux
服务器下的/etc
整个目录下载到本地E:\tmp
下
pscp 选项 用户名@linux主机地址:资源路径 windows本地的地址
pscp -r root@192.168.21.128:/etc E:\tmp
在CMD
中输入之后输入密码
② 上传文件到Linux
:
将“E:\coursedocs
”所有的内容传输到Linux
下root
用户的家目录
pscp 选项 资源路径 用户名@linux主机地址:远程路径
pscp -r “E:\coursedocs” root@192.168.21.128:/root