2.6W字系统总结,带你实现 Linux 自由!(下)

简介: 笔记

网络


ifconfig

查看 ip 网络相关信息,如果命令不存在的话, 执行命令 yum install net-tools 安装。

[root@lion ~]# ifconfig
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 172.31.24.78  netmask 255.255.240.0  broadcast 172.31.31.255
        ether 00:16:3e:04:9c:cd  txqueuelen 1000  (Ethernet)
        RX packets 1592318  bytes 183722250 (175.2 MiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 1539361  bytes 154044090 (146.9 MiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        loop  txqueuelen 1000  (Local Loopback)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

参数解析:

  • eth0 对应有线连接(对应你的有线网卡),就是用网线来连接的上网。ethEthernet 的缩写,表示“以太网”。有些电脑可能同时有好几条网线连着,例如服务器,那么除了 eht0 ,你还会看到 eth1eth2 等。
  • lo 表示本地回环( Local Loopback 的缩写,对应一个虚拟网卡)可以看到它的 ip 地址是 127.0.0.1 。每台电脑都应该有这个接口,因为它对应着“连向自己的链接”。这也是被称之为“本地回环”的原因。所有经由这个接口发送的东西都会回到你自己的电脑。看起来好像并没有什么用,但有时为了某些缘故,我们需要连接自己。例如用来测试一个网络程序,但又不想让局域网或外网的用户查看,只能在此台主机上运行和查看所有的网络接口。例如在我们启动一个前端工程时,在浏览器输入 127.0.0.1:3000 启动项目就能查看到自己的 web 网站,并且它只有你能看到。
  • wlan0 表示无线局域网(上面案例并未展示)。


host

ip 地址和主机名的互相转换。

软件安装

yum install bind-utils

基础用法

[root@lion ~]# host github.com
baidu.com has address 13.229.188.59
[root@lion ~]# host 13.229.188.59
59.188.229.13.in-addr.arpa domain name pointer ec2-13-229-188-59.ap-southeast-1.compute.amazonaws.com.


ssh 连接远程服务器

通过非对称加密以及对称加密的方式(同 HTTPS 安全连接原理相似)连接到远端服务器。

ssh 用户@ip:port
1、ssh root@172.20.10.1:22 # 端口号可以省略不写,默认是22端口
2、输入连接密码后就可以操作远端服务器了

配置 ssh

config 文件可以配置 ssh ,方便批量管理多个 ssh 连接。

配置文件分为以下几种:

  • 全局 ssh 服务端的配置:/etc/ssh/sshd_config
  • 全局 ssh 客户端的配置:/etc/ssh/ssh_config(很少修改);
  • 当前用户 ssh 客户端的配置:~/.ssh/config

【服务端 config 文件的常用配置参数】

服务端 config 参数 作用
Port sshd 服务端口号(默认是22)
PermitRootLogin 是否允许以 root 用户身份登录(默认是可以)
PasswordAuthentication 是否允许密码验证登录(默认是可以)
PubkeyAuthentication 是否允许公钥验证登录(默认是可以)
PermitEmptyPasswords 是否允许空密码登录(不安全,默认不可以)

[注意] 修改完服务端配置文件需要重启服务 systemctl restart sshd

【客户端 config 文件的常用配置参数】

客户端 config 参数 作用
Host 别名
HostName 远程主机名(或 IP 地址)
Port 连接到远程主机的端口
User 用户名

配置当前用户的 config

# 创建config
vim ~/.ssh/config
# 填写一下内容
Host lion # 别名
 HostName 172.x.x.x # ip 地址
  Port 22 # 端口
  User root # 用户

这样配置完成后,下次登录时,可以这样登录 ssh lion 会自动识别为 root 用户。

[注意] 这段配置不是在服务器上,而是你自己的机器上,它仅仅是设置了一个别名。

免密登录

ssh 登录分两种,一种是基于口令(账号密码),另外一种是基于密钥的方式。

基于口令,就是每次登录输入账号和密码,显然这样做是比较麻烦的,今天主要学习如何基于密钥实现免密登录。

基于密钥验证原理

客户机生成密钥对(公钥和私钥),把公钥上传到服务器,每次登录会与服务器的公钥进行比较,这种验证登录的方法更加安全,也被称为“公钥验证登录”。

具体实现步骤

1、在客户机中生成密钥对(公钥和私钥) ssh-keygen(默认使用 RSA 非对称加密算法)

运行完 ssh-keygen 会在 ~/.ssh/ 目录下,生成两个文件:

  • id_rsa.pub :公钥
  • id_rsa :私钥

2、把客户机的公钥传送到服务

执行 ssh-copy-id root@172.x.x.xssh-copy-id 它会把客户机的公钥追加到服务器 ~/.ssh/authorized_keys 的文件中)。

执行完成后,运行 ssh root@172.x.x.x 就可以实现免密登录服务器了。

配合上面设置好的别名,直接执行 ssh lion 就可以登录,是不是非常方便。

wget

可以使我们直接从终端控制台下载文件,只需要给出文件的HTTP或FTP地址。

wget [参数][URL地址]
wget http://www.minjieren.com/wordpress-3.1-zh_CN.zip

wget 非常稳定,如果是由于网络原因下载失败, wget 会不断尝试,直到整个文件下载完毕。

常用参数

  • -c 继续中断的下载。


备份


scp

它是 Secure Copy 的缩写,表示安全拷贝。scp 可以使我们通过网络,把文件从一台电脑拷贝到另一台电脑。

scp 是基于 ssh 的原理来运作的, ssh 会在两台通过网络连接的电脑之间创建一条安全通信的管道, scp 就利用这条管道安全地拷贝文件。

scp source_file destination_file # source_file 表示源文件,destination_file 表示目标文件

其中 source_filedestination_file 都可以这样表示:user@ip:file_nameuser 是登录名, ip 是域名或 ip 地址。file_name 是文件路径。

scp file.txt root@192.168.1.5:/root # 表示把我的电脑中当前文件夹下的 file.txt 文件拷贝到远程电脑
scp root@192.168.1.5:/root/file.txt file.txt # 表示把远程电脑上的 file.txt 文件拷贝到本机


rsync

rsync 命令主要用于远程同步文件。它可以同步两个目录,不管它们是否处于同一台电脑。它应该是最常用于“增量备份”的命令了。它就是智能版的 scp 命令。

软件安装

yum install rsync

基础用法

rsync -arv Images/ backups/ # 将Images 目录下的所有文件备份到 backups 目录下
rsync -arv Images/ root@192.x.x.x:backups/ # 同步到服务器的backups目录下

常用参数

  • -a 保留文件的所有信息,包括权限,修改日期等;
  • -r 递归调用,表示子目录的所有文件也都包括;
  • -v 冗余模式,输出详细操作信息。

默认地, rsync 在同步时并不会删除目标目录的文件,例如你在源目录中删除一个文件,但是用 rsync 同步时,它并不会删除同步目录中的相同文件。如果向删除也可以这么做:rsync \-arv \--delete Images/ backups/


系统


halt

关闭系统,需要 root 身份。

halt

reboot

重启系统,需要 root 身份。

reboot

poweroff

直接运行即可关机,不需要 root 身份。


Vim 编辑器


Vim 是什么?

Vim 是从 vi 发展出来的一个文本编辑器。其代码补完、编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用。和 Emacs 并列成为类 Unix 系统用户最喜欢的编辑器。


Vim 常用模式


  • 交互模式
  • 插入模式
  • 命令模式
  • 可视模式


交互模式

也成为正常模式,这是 Vim 的默认模式,每次运行 Vim 程序的时候,就会进入这个模式。

例如执行 vim name.txt 则会进入交互模式。

交互模式特征:

  • 在这个模式下,你不能输入文本;
  • 它可以让我们在文本间移动,删除一行文本,复制黏贴文本,跳转到指定行,撤销操作,等等。


插入模式

这个模式是我们熟悉的文本编辑器的模式,就是可以输入任何你想输入的内容。进入这个模式有几种方法,最常用的方法是按字母键 ii、I、a、A、o、O 都可以进入插入模式,只是所处的位置不同),退出这种模式,只需要按下 Esc 键。

  • i, I 进入输入模式 Insert modei 为“从目前光标所在处输入”, I 为“在目前所在行的第一个非空格符处开始输入”;
  • a, A 进入输入模式 Insert modea 为“从目前光标所在的下一个字符处开始输入”, A 为“从光标所在行的最后一个字符处开始输入”;
  • o, O 进入输入模式 Insert modeo 为“在目前光标所在的下一行处输入新的一行”;O 为在目前光标所在处的上一行输入新的一行。


命令模式

命令模式也称为底线命令模式,这个模式下可以运行一些命令例如“退出”,“保存”,等动作。

也可以用这个模式来激活一些 Vim 配置,例如语法高亮,显示行号,等。甚至还可以发送一些命令给终端命令行,例如 ls、cp

为了进入命令模式,首先要进入交互模式,再按下冒号键。

用一张图表示三种模式如何切换:


基本操作


打开 Vim

在终端命令行中输入 vim 回车后 Vim 就会被运行起来,也可以用 Vim 来打开一个文件,只需要在 vim 后面再加文件名。如 vim file.name ,如果文件不存在,那么会被创建。

插入

进入文件之后,此时处于交互模式,可以通过输入 i 进入插入模式。

移动

Vim 的交互模式下,我们可以在文本中移动光标。

  • h 向左移动一个字符
  • j 向下移动一个字符
  • k 向上移动一个字符
  • i 向右移动一个字符

当然也可以使用四个方向键进行移动,效果是一样的。

跳至行首和行末

  • 行首:在交互模式下,为了将光标定位到一行的开始位置,只需要按下数字键 0 即可,键盘上的 Home 键也有相同效果。
  • 行末:在交互模式下,为了将光标定位到一行的末尾,只需要按下美元符号键 $ 即可,键盘上的 End 键也有相同效果。

按单词移动

在交互模式下,按字母键 w 可以一个单词一个单词的移动。

退出文件

在交互模式下,按下冒号键 : 进入命令模式,再按下 q 键,就可以退出了。

如果在退出之前又修改了文件,就直接想用 :q 退出 Vim ,那么 Vim 会显示一个红字标明错误信息。此时我们有两个选择:

  1. 保存并退出 :wq:x
  2. 不保存且退出 :q!


标准操作


删除字符

在交互模式下,将光标定位到一个你想要删除的字符上,按下字母键 x 你会发现这个字符被删除了。

也可以一次性删除多个字符,只需要在按 x 键之前输入数字即可。


删除(剪切)单词,行

  • 删除一行:连按两次 d 来删除光标所在的那一行。
  • 删除多行:例如先输入数字 2 ,再按下 dd ,就会删除从光标所在行开始的两行。
  • 删除一个单词:将光标置于一个单词的首字母处,然后按下 dw
  • 删除多个单词:例如先按数字键 2 再按 dw 就可以删除两个单词了。
  • 从光标所在位置删除至行首:d0
  • 从光标所在位置删除至行末:d$


复制单词,行

  • 复制行:按两次 y 会把光标所在行复制到内存中,和 dd 类似, dd 用于“剪切”光标所在行。
  • 复制单词:yw 会复制一个单词。
  • 复制到行末:y$ 是复制从光标所在处到行末的所有字符。
  • 复制到行首:y0 是复制光标所在处到行首的所有字符。


粘贴

如果之前用 dd 或者 yy 剪切复制过来的,可以使用 p 来粘贴。同样也可以使用 数字+p 来表示复制多次。


替换一个字符

在交互模式下,将光标置于想要替换的字符上。按下 r 键,接着输入你要替换的字符即可。


撤销操作

如果要撤销最近的修改,只需要按下 u 键,如果想要撤销最近四次修改,可以按下4,再按下 u


重做

取消撤销,也就是重做之前的修改使用 ctrl + r


跳转到指定行

Vim 编辑的文件中,每一行都有一个行号,行号从1开始,逐一递增。

行号默认是不显示,如果需要它显示的话,可以进入命令模式,然后输入 set nu ,如果要隐藏行号的话,使用 set nonu

  • 跳转到指定行:数字+gg ,例如 7gg ,表示跳转到第7行。
  • 要跳转到最后一行,按下 G
  • 要跳转到第一行,按下 gg


高级操作


查找

处于交互模式下,按下 / 键,那么就进入查找模式,输入你要查找的字符串,然后按下回车。光标就会跳转到文件中下一个查找到的匹配处。如果字符串不存在,那么会显示 "pattern not found"

  • n 跳转到下一个匹配项;
  • N 跳转到上一个匹配项。

[注意] 用斜杠来进行的查找是从当前光标处开始向文件尾搜索,如果你要从当前光标处开始,向文件头搜索则使用 ? ,当然也可以先按下 gg 跳转到第一行在进行全文搜索。


查找并替换

替换光标所在行第一个匹配的字符串:

# 语法
:s/旧字符串/新字符串
# 实例
:s/one/two

替换光标所在行所有旧字符串为新字符串:

# 语法
:s/旧字符串/新字符串/g

替换第几行到第几行中所有字符串:

# 语法
:n,m s/旧字符串/新字符串/g
# 实例
:2,4 s/one/two/g

最常用的就是全文替换了:

# 语法
:%s/旧字符串/新字符串/g


合并文件

可以用冒号 +r ( :r ) 实现在光标处插入一个文件的内容。

:r filename # 可以用Tab键来自动补全另外一个文件的路径


分屏

Vim 有一个特别便捷的功能那就是分屏,可以同时打开好几个文件,分屏之后,屏幕每一块被称为一个 viewport ,表示“视口”。

  • 横向分屏 :sp 文件名
  • 垂直分屏 :vsp 文件名

分屏模式下的快捷键

  • Ctrl + w 再加 Ctrl + w ,表示从一个 viewport 移动光标到另外一个 viewport
  • Ctrl + w 再加 “方向键”,就可以移动到这个方向所处的下一个视口了;
  • Ctrl + w 再加 + 号,表示扩大当前视口;
  • Ctrl + w 再加 - 号,表示缩小当前视口;
  • Ctrl + w 再加 = 号,表示平均当前视口;
  • Ctrl + w 再加 r 键,会反向调换视口位置;
  • Ctrl + w 再加 q 键,会关闭当前视口;
  • Ctrl + w 再加 o 键,会关闭除当前视口以外的所有视口;


运行外部命令 :!

Vim 中可以运行一些终端命令,只要先输入 :! ,然后接命令名称。

例如:

:!ls # 在Vim中打开的文件所在的目录运行ls命令


可视模式

前面只讲了 Vim 的三种模式,其实还有一种模式叫做可视模式。

进入它的三种方式(都是从交互模式开始):

  • v 字符可视模式,进入后配合方向键选中字符后,然后再按 d 键可以删除选中。
  • V 行可视模式,进入后光标所在行默认被选中,然后再按 d 键可以删除所在行。
  • Ctrl + v 块可视模式,它是可视模式最有用的功能了,配合 dI 键可以实现删除选中的内容和插入内容。

同时选中多行,并在选中行头部插入内容的具体操作步骤:

1. ctrl + v 进入块可视模式
2. 使用方向键进行选中(上下左右)假设选中5行
3. 输入 I 键进行多行同时插入操作
4. 插入完成后连续按两下 esc 键,实现多行同时插入相同字符

进入可视模式之后的操作键:

  • d 键,表示删除选中;
  • I 键,表示在选中之前插入;
  • u 键,表示选中变为小写;
  • U 键,表示选中变为大写;


Vim 配置


选项参数

Vim 被启动后,可以运行一些指令来激活一些选项参数,但是这些选项参数的配置在退出 Vim 时会被忘记,例如前面讲解的激活行号。如果希望所在的配置是永久性的,那么需要在家目录( cd ~ )创建一个 Vim 的配置文件 .vimrc


.vimrc

set number " 显示行号
syntax on " 激活语法高亮
set showcmd " 实时看到输入的命令
set ignorecase " 搜索时不区分大小写
set mouse=a " 激活鼠标,用鼠标选中时相当于进入可视模式

Vim 配置非常丰富,我们可以通过个性化配置把 Vim 打造成属于自己的 IDE 等等。在 github 上也可以搜索到一些强大的 Vim 配置文件。


总结


相信通过本文的学习,你应该会对 Linux 有一个更加全面的认识。

都看到这里了,就点个👍 👍 👍 吧。

相关实践学习
CentOS 7迁移Anolis OS 7
龙蜥操作系统Anolis OS的体验。Anolis OS 7生态上和依赖管理上保持跟CentOS 7.x兼容,一键式迁移脚本centos2anolis.py。本文为您介绍如何通过AOMS迁移工具实现CentOS 7.x到Anolis OS 7的迁移。
相关文章
|
1天前
|
存储 缓存 监控
Linux缓存管理:如何安全地清理系统缓存
在Linux系统中,内存管理至关重要。本文详细介绍了如何安全地清理系统缓存,特别是通过使用`/proc/sys/vm/drop_caches`接口。内容包括清理缓存的原因、步骤、注意事项和最佳实践,帮助你在必要时优化系统性能。
102 78
|
5天前
|
Linux Shell 网络安全
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
本指南介绍如何利用 HTA 文件和 Metasploit 框架进行渗透测试。通过创建反向 shell、生成 HTA 文件、设置 HTTP 服务器和发送文件,最终实现对目标系统的控制。适用于教育目的,需合法授权。
33 9
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
|
1天前
|
存储 监控 Linux
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
31 13
|
2天前
|
Ubuntu Linux C++
Win10系统上直接使用linux子系统教程(仅需五步!超简单,快速上手)
本文介绍了如何在Windows 10上安装并使用Linux子系统。首先,通过应用商店安装Windows Terminal和Linux系统(如Ubuntu)。接着,在控制面板中启用“适用于Linux的Windows子系统”并重启电脑。最后,在Windows Terminal中选择安装的Linux系统即可开始使用。文中还提供了注意事项和进一步配置的链接。
12 0
|
25天前
|
Ubuntu Linux 网络安全
linux系统ubuntu中在命令行中打开图形界面的文件夹
在Ubuntu系统中,通过命令行打开图形界面的文件夹是一个高效且实用的操作。无论是使用Nautilus、Dolphin还是Thunar,都可以根据具体桌面环境选择合适的文件管理器。通过上述命令和方法,可以简化日常工作,提高效率。同时,解决权限问题和图形界面问题也能确保操作的顺利进行。掌握这些技巧,可以使Linux操作更加便捷和灵活。
17 3
|
29天前
|
Linux
在 Linux 系统中,`find` 命令
在 Linux 系统中,`find` 命令
31 1
|
13天前
|
存储 Oracle 安全
服务器数据恢复—LINUX系统删除/格式化的数据恢复流程
Linux操作系统是世界上流行的操作系统之一,被广泛用于服务器、个人电脑、移动设备和嵌入式系统。Linux系统下数据被误删除或者误格式化的问题非常普遍。下面北亚企安数据恢复工程师简单聊一下基于linux的文件系统(EXT2/EXT3/EXT4/Reiserfs/Xfs) 下删除或者格式化的数据恢复流程和可行性。
|
7月前
|
缓存 Linux 测试技术
安装【银河麒麟V10】linux系统--并挂载镜像
安装【银河麒麟V10】linux系统--并挂载镜像
2061 0
|
7月前
|
关系型数据库 MySQL Linux
卸载、下载、安装mysql(Linux系统centos7)
卸载、下载、安装mysql(Linux系统centos7)
248 0
|
2月前
|
Linux
手把手教会你安装Linux系统
手把手教会你安装Linux系统

热门文章

最新文章