Linux菜鸟笔记

Linux菜鸟笔记

一、系统目录结构

Linux的根文件目录为“/”,以下所有目录都是挂载在这个目录下的。

  • /bin
    bin 是 Binaries (二进制文件) 的缩写, 这个目录存放着最经常使用的命令

  • /boot:
    这里存放的是启动 Linux 时使用的一些核心文件,包括一些连接文件以及镜像文件。

  • /dev :
    dev 是 Device(设备) 的缩写, 该目录下存放的是 Linux 的外部设备,在 Linux 中访问设备的方式和访问文件的方式是相同的。

  • /etc:
    etc 是 Etcetera(等等) 的缩写,这个目录用来存放所有的系统管理所需要的配置文件和子目录

  • /home
    用户的主目录,在 Linux 中,每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的。

  • /lib
    lib 是 Library(库) 的缩写这个目录里存放着系统最基本的动态连接共享库,其作用类似于 Windows 里的 DLL 文件。几乎所有的应用程序都需要用到这些共享库。

  • /lost+found
    这个目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件。

  • /media
    linux 系统会自动识别一些设备,例如U盘、光驱等等,当识别后,Linux 会把识别的设备挂载到这个目录下。

  • /mnt
    系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将光驱挂载在 /mnt/ 上,然后进入该目录就可以查看光驱里的内容了。

  • /opt
    opt 是 optional(可选) 的缩写,这是给主机额外安装软件所摆放的目录。比如你安装一个ORACLE数据库则就可以放到这个目录下。默认是空的。

  • /proc
    proc 是 Processes(进程) 的缩写,/proc 是一种伪文件系统(也即虚拟文件系统),存储的是当前内核运行状态的一系列特殊文件,这个目录是一个虚拟的目录,它是系统内存的映射,我们可以通过直接访问这个目录来获取系统信息。
    这个目录的内容不在硬盘上而是在内存里,我们也可以直接修改里面的某些文件,比如可以通过下面的命令来屏蔽主机的ping命令,使别人无法ping你的机器:

    /proc/sys/net/ipv4/icmp_echo_ignore_all
    
  • /root
    该目录为系统管理员,也称作超级权限者的用户主目录

  • /sbin
    s 就是 Super User 的意思,是 Superuser Binaries (超级用户的二进制文件) 的缩写,这里存放的是系统管理员使用的系统管理程序

  • /srv
    该目录存放一些服务启动之后需要提取的数据

  • /sys:这是linux2.6内核的一个很大的变化。该目录下安装了2.6内核中新出现的一个文件系统 sysfs 。

  • /tmp
    tmp 是 temporary(临时) 的缩写这个目录是用来存放一些临时文件的。

  • /usr
    usr 是 unix shared resources(共享资源) 的缩写,这是一个非常重要的目录,用户的很多应用程序和文件都放在这个目录下,类似于 windows 下的 program files 目录。

    • /usr/bin:
      系统用户使用的应用程序
    • /usr/sbin:
      超级用户使用的比较高级的管理程序和系统守护程序
    • /usr/src:
      内核源代码默认的放置目录。
  • /var
    var 是 variable(变量) 的缩写,这个目录中存放着在不断扩充着的东西,我们习惯将那些经常被修改的目录放在这个目录下。包括各种日志文件

  • /run
    是一个临时文件系统,存储系统启动以来的信息。当系统重启时,这个目录下的文件应该被删掉或清除。

二、开关机操作

开机

开机会启动许多程序。它们在Windows叫做"服务"(service),在Linux就叫做"守护进程"(daemon)。

一般来说,用户的登录方式有三种:

  • 命令行登录
  • ssh登录
  • 图形界面登录

最高权限账户为 root,可以操作一切!

关机 shutdown

正确的关机流程为:sync > shutdown > reboot > halt

不管是重启系统还是关闭系统,首先要运行 sync 命令,把内存中的数据写到磁盘中。

sync 将数据由内存同步到硬盘中。

shutdown 关机指令,可以man shutdown 来看一下帮助文档。

shutdown –h 10    计算机将在10分钟后关机,并且会显示在登陆用户的当前屏幕中。

shutdown –h now   立马关机

shutdown –h 20:25 系统会在今天20:25关机

shutdown –h +10   十分钟后关机

shutdown –r now   系统立马重启

shutdown –r +10   系统十分钟后重启

reboot 就是重启,等同于 shutdown –r now

halt 关闭系统,等同于shutdown –h now 和 poweroff

man shutdown得到如下结果:

三、用户和用户组管理

一、Linux系统用户账号的管理

添加新的用户账号使用useradd命令,其语法如下:

useradd 选项 用户名
  • 选项:

    • -c comment 指定一段注释性描述。
    • -d 目录 指定用户主目录,如果此目录不存在,则同时使用-m选项,可以创建主目录。
    • -g 用户组 指定用户所属的用户组。
    • -G 用户组,用户组 指定用户所属的附加组。
    • -s Shell文件 指定用户的登录Shell。
    • -u 用户号 指定用户的用户号,如果同时有-o选项,则可以重复使用其他用户的标识号。
  • 用户名:

    指定新账号的登录名。

删除用户

删除用户账号就是要将/etc/passwd、/etc/shadow、 /etc/group等系统文件中的该用户记录删除,必要时还删除用户的主目录。删除一个已有的用户账号使用userdel命令,

userdel 选项 用户名

常用的选项是 -r,它的作用是把用户的主目录一起删除。

修改用户

修改用户账号就是根据实际情况更改用户的有关属性,如用户号、主目录、用户组、登录Shell等。修改已有用户的信息使用usermod命令,其格式如下:

usermod 选项 用户名

常用的选项包括-c, -d, -m, -g, -G, -s, -u以及-o等,这些选项的意义与useradd命令中的选项一样,可以为用户指定新的资源值。

切换用户

1.切换用户的命令为:su usernameusername是你的用户名】

2.从普通用户切换到root用户,还可以使用命令:sudo su

3.在终端输入exitlogout或使用快捷方式ctrl+d,可以退回到原来用户,其实ctrl+d也是执行的exit命令

4.在切换用户时,如果想在切换用户之后使用新用户的工作环境,可以在su和username之间加-,例如:【su - root】

$表示普通用户

#表示超级用户,也就是root用户

用户口令的管理

用户管理的一项重要内容是用户口令的管理。用户账号刚创建时没有口令,但是被系统锁定,无法使用,必须为其指定口令后才可以使用,即使是指定空口令。

指定和修改用户口令的命令是passwd。超级用户可以为自己和其他用户指定口令,普通用户只能用它修改自己的口令。命令的格式为:

passwd 选项 用户名

可使用的选项:

  • -l 锁定口令,即禁用账号。
  • -u 口令解锁。
  • -d 使账号无口令。
  • -f 强迫用户下次登录时修改口令。

普通用户修改自己的口令时,passwd命令会先询问原口令,验证后再要求用户输入两遍新口令,如果两次输入的口令一致,则将这个口令指定给用户;而超级用户为用户指定口令时,就不需要知道原口令

二、系统用户组的管理

用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对/etc/group文件的更新。

添加一个用户组

groupadd 选项 用户组

可以使用的选项有:

  • -g GID 指定新用户组的组标识号(GID)。
  • -o 一般与-g选项同时使用,表示新用户组的GID可以与系统已有用户组的GID相同。

删除一个用户组

groupdel 用户组

修改一个用户组

groupmod 选项 用户组

常用的选项有:

  • -g GID 为用户组指定新的组标识号。
  • -o 与-g选项同时使用,用户组的新GID可以与系统已有用户组的GID相同。
  • -n新用户组 将用户组的名字改为新名字
# 将组group2的标识号改为10000,组名修改为group3。
groupmod –g 10000 -n group3 group2

切换组

如果一个用户同时属于多个用户组,那么用户可以在用户组之间切换,以便具有其他用户组的权限。用户可以在登录后,使用命令newgrp切换到其他用户组,这个命令的参数就是目的用户组。

$ newgrp root

三、与用户账号有关的系统文件

/etc/passwd文件是用户管理工作涉及的最重要的一个文件。

/etc/passwd文件中有一个对应的记录行,它记录了这个用户的一些基本属性。/etc/passwd中一行记录对应着一个用户,每行记录又被冒号(:)分隔为7个字段,其格式和具体含义如下:用户名:口令:用户标识号:组标识号:注释性描述:主目录:登录Shell

/etc/shadow文件:Linux系统都把加密后的口令字分离出来,单独存放在一个文件中,有超级用户才拥有该文件读权限.

登录名:加密口令:最后一次修改时间:最小时间间隔:最大时间间隔:警告时间:不活动时间:失效时间:标志

/etc/group文件,用户组所有的信息都存在在这里。

组名:口令:组标识号:组内用户列表

四、文件基本属性

Linux 系统是一种典型的多用户系统,不同的用户处于不同的地位,拥有不同的权限。为了保护系统的安全性,Linux 系统对不同的用户访问同一文件(包括目录文件)的权限做了不同的规定。

首先通过一张图来了解文件的基本属性:

img

第一个字符表述file type,也就是文件类型。规则如下:

  • 当为 d 则是目录
  • 当为 - 则是文件;
  • 若是 l 则表示为链接文档(link file);
  • 若是 b 则表示为装置文件里面的可供储存的接口设备(可随机存取装置);
  • 若是 c 则表示为装置文件里面的串行端口设备,例如键盘、鼠标(一次性读取装置)。

接下来的字符中,以三个为一组,且均为 rwx 的三个参数的组合。其中, r 代表可读(read)、 w 代表可写(write)、 x 代表可执行(execute)。这三个权限的位置固定,如果没有权限,就会出现 - 。具体表示如下:

363003_1227493859FdXT

  • 属主权限:该文件所有者拥有该文件的权限。
  • 属组权限:所有者的同组用户拥有该文件的权限
  • 其他用户权限:其他用户拥有该文件的权限。

chgrp:更改文件属组

chgrp [-R] 属组名 文件名
  • -R:递归更改文件属组,就是在更改某个目录文件的属组时,如果加上-R的参数,那么该目录下的所有文件的属组都会更改。

chown:更改文件属主,也可以同时更改文件属组

chown [–R] 属主名 文件名
chown [-R] 属主名:属组名 文件名

chmod:更改文件9个属性

Linux文件属性有两种设置方法,一种是数字,一种是符号。

1、数字方式

文件的权限字符为: -rwxrwxrwx , 这九个权限是三个三个一组的!其中,我们可以使用数字来代表各个权限,其中:

  • r:4
  • w:2
  • x:1

每种身份(owner/group/others)各自的三个权限(r/w/x)分数是需要累加的,通过累加的和就能判断这三个权限情况。

chmod [-R] xyz 文件或目录

选项与参数:

  • xyz : 就是刚刚提到的数字类型的权限属性,为 rwx 属性数值的相加。
  • -R : 进行递归(recursive)的持续变更,亦即连同次目录下的所有文件都会变更

2、符号方式

针对这种方式,结合所属用户的划分,我们就可以使用 u, g, o 来代表三种身份的权限。此外a 则代表 all,即全部的身份。

  • user:用户
  • group:组
  • others:其他

如果我们需要将文件权限设置为 -rwxr-xr-- ,可以使用 chmod u=rwx,g=rx,o=r 文件名 来设定:

#  touch test1    // 创建 test1 文件
# ls -al test1    // 查看 test1 默认权限
-rw-r--r-- 1 root root 0 Nov 15 10:32 test1
# chmod u=rwx,g=rx,o=r  test1    // 修改 test1 权限
# ls -al test1
-rwxr-xr-- 1 root root 0 Nov 15 10:32 test1

而如果是要将权限去掉而不改变其他已存在的权限呢?例如要拿掉全部人的可执行权限,则:

#  chmod  a-x test1
# ls -al test1
-rw-r--r-- 1 root root 0 Nov 15 10:32 test1

五、文件与目录管理

  1. 区分绝对路径相对路径

    Linux的目录结构为树状结构,最顶级的目录为根目录 /。其他目录通过挂载可以将它们添加到树中,通过解除挂载可以移除它们。

    绝对路径:

    ​ 路径的写法,由根目录 / 写起,例如:/usr/share/doc 这个目录。

    相对路径:

    ​ 路径的写法,不是由 / 写起,例如由 /usr/share/doc 要到 /usr/share/man 底下时,可以写成:cd ../man 这就是相对路径的写法!

1、处理目录常用命令

  • ls(英文全拼:list files): 列出目录及文件名
  • cd(英文全拼:change directory):切换目录
  • pwd(英文全拼:print work directory):显示目前的工作目录
  • mkdir(英文全拼:make directory):创建一个新的目录
  • rmdir(英文全拼:remove directory):删除一个空的目录
  • rm(英文全拼:remove): 删除文件或目录
  • cp(英文全拼:copy file): 复制文件或目录
  • mv(英文全拼:move file): 移动文件与目录,或修改文件与目录的名称

ls(英文全拼:list files): 列出目录及文件名

  • -a :全部的文件,连同隐藏文件( 开头为 . 的文件) 一起列出来(常用)
  • -d :仅列出目录本身,而不是列出目录内的文件数据(常用)
  • -l :长数据串列出,包含文件的属性与权限等等数据;(常用)

将目录下的所有文件列出来(含属性与隐藏档): [root@www ~]# ls -al ~

cd (Change Directory)的缩写切换目录

语法:

cd [相对路径或绝对路径]
#使用 mkdir 命令创建 runoob 目录
[root@www ~]# mkdir runoob

#使用绝对路径切换到 runoob 目录
[root@www ~]# cd /root/runoob/

#使用相对路径切换到 runoob 目录
[root@www ~]# cd ./runoob/

 # 表示回到自己的家目录,亦即是 /root 这个目录
[root@www runoob]# cd ~ 

# 表示去到目前的上一级目录,亦即是 /root 的上一级目录的意思;
[root@www ~]# cd ..

pwd 是 Print Working Directory 的缩写,也就是显示目前所在目录的命令。

选项与参数:

  • -P :显示出确实的路径,而非使用连结 (link) 路径。

mkdir (make directory)创建新目录

选项与参数:

  • -m :配置文件的权限!直接配置,不需要看默认权限 (umask) 的脸色~
  • -p :帮助你直接将所需要的目录(包含上一级目录)递归创建起来!
[root@www ~]# cd /tmp
[root@www tmp]# mkdir test    <==创建一名为 test 的新目录
[root@www tmp]# mkdir test1/test2/test3/test4
mkdir: cannot create directory `test1/test2/test3/test4': 
No such file or directory       <== 没办法直接创建此目录啊!
[root@www tmp]# mkdir -p test1/test2/test3/test4

rmdir (删除空的目录)

  • -p :连同上一级『空的』目录也一起删除 :rmdir -p test1/test2/test3
[root@iZwz99yuz3z7cggxlq02myZ home]# ls
test1  threepure
[root@iZwz99yuz3z7cggxlq02myZ home]# rmdir threepure
rmdir: failed to remove 'threepure': Directory not empty
[root@iZwz99yuz3z7cggxlq02myZ home]# rmdir -p threepure
rmdir: failed to remove 'threepure': Directory not empty
[root@iZwz99yuz3z7cggxlq02myZ home]# rmdir -p test1/test2/test3
[root@iZwz99yuz3z7cggxlq02myZ home]# ls
threepure

不过要注意的是, rmdir 仅能删除空的目录,可以使用 rm 命令来删除非空目录

rm (移除文件或目录)

选项与参数:

  • -f :就是 force 的意思,忽略不存在的文件,不会出现警告信息;
  • -i :互动模式,在删除前会询问使用者是否动作
  • -r :递归删除!最常用在目录的删除!这是非常危险的选项
[root@iZwz99yuz3z7cggxlq02myZ home]# rm -r threepure
rm: descend into directory 'threepure'? y
rm: remove directory 'threepure/sanchun'? y
rm: remove regular file 'threepure/install.sh'? y
rm: remove directory 'threepure'? y
[root@iZwz99yuz3z7cggxlq02myZ home]# ls
[root@iZwz99yuz3z7cggxlq02myZ home]# 

cp (复制文件或目录)

选项与参数:

  • -a:相当于 -pdr 的意思,至于 pdr 请参考下列说明;(常用)
  • -d:若来源档为连结档的属性(link file),则复制连结档属性而非文件本身;
  • -f:为强制(force)的意思,若目标文件已经存在且无法开启,则移除后再尝试一次;
  • -i:若目标档(destination)已经存在时,在覆盖时会先询问动作的进行(常用)
  • -l:进行硬式连结(hard link)的连结档创建,而非复制文件本身;
  • -p:连同文件的属性一起复制过去,而非使用默认属性(备份常用);
  • -r:递归持续复制,用于目录的复制行为;(常用)
  • -s:复制成为符号连结档 (symbolic link),亦即『捷径』文件;
  • -u:若 destination 比 source 旧才升级 destination !
[root@iZwz99yuz3z7cggxlq02myZ /]# cd root
[root@iZwz99yuz3z7cggxlq02myZ ~]# ls
install.sh
[root@iZwz99yuz3z7cggxlq02myZ ~]# cp install.sh /home/threepure
[root@iZwz99yuz3z7cggxlq02myZ ~]# cd /home/threepure
[root@iZwz99yuz3z7cggxlq02myZ threepure]# ls
install.sh  sanchun

mv 移动文件与目录,或修改名称

选项与参数:

  • -f :force 强制的意思,如果目标文件已经存在,不会询问而直接覆盖;
  • -i :若目标文件 (destination) 已经存在时,就会询问是否覆盖!
  • -u :若目标文件已经存在,且 source 比较新,才会升级 (update)
[root@iZwz99yuz3z7cggxlq02myZ home]# ls
install.sh  sanchun  threepure
[root@iZwz99yuz3z7cggxlq02myZ home]# mv install.sh threepure
[root@iZwz99yuz3z7cggxlq02myZ home]# mv sanchun threepure
[root@iZwz99yuz3z7cggxlq02myZ home]# ls
threepure
[root@iZwz99yuz3z7cggxlq02myZ home]# cd threepure
[root@iZwz99yuz3z7cggxlq02myZ threepure]# ls
install.sh  sanchun

[root@iZwz99yuz3z7cggxlq02myZ threepure]# cd ..
[root@iZwz99yuz3z7cggxlq02myZ home]# mv threepure threepure1
[root@iZwz99yuz3z7cggxlq02myZ home]# ls
threepure1
[root@iZwz99yuz3z7cggxlq02myZ home]# cd threepure1
[root@iZwz99yuz3z7cggxlq02myZ threepure1]# ls
install.sh  sanchun

sh shell命令语言解释器,执行命令从标准输入读取或从一个文件中读取[执行.sh脚本]

-c 命令从-c后的字符串读取
-i 实现脚本交互
-n 进行shell脚本的语法检查
-x 实现shell脚本逐条语句的跟踪

2、文件内容查看

  • cat 由第一行开始显示文件内容

  • tac 从最后一行开始显示,可以看出 tac 是 cat 的倒着写!

  • nl 显示的时候,顺道输出行号!

  • more 一页一页的显示文件内容

  • less 与 more 类似,但是比 more 更好的是,他可以往前翻页!

  • head 只看头几行

  • tail 只看尾巴几行

    可以使用 man [命令]来查看各个命令的使用文档

cat: 由第一行开始显示文件内容

cat [-AbEnTv]

选项与参数:

  • -A :相当于 -vET 的整合选项,可列出一些特殊字符而不是空白而已;
  • -b :列出行号,仅针对非空白行做行号显示,空白行不标行号!
  • -E :将结尾的断行字节 $ 显示出来;
  • -n :列印出行号,连同空白行也会有行号,与 -b 的选项不同;
  • -T :将 [tab] 按键以 ^I 显示出来;
  • -v :列出一些看不出来的特殊字符
# 查看网络配置: 文件地址 /etc/sysconfig/network-scripts/
[root@root ~]# cat /etc/sysconfig/network-scripts/ifcfg-eth0
DEVICE=eth0
BOOTPROTO=dhcp
ONBOOT=yes

tac : tac与cat命令刚好相反,文件内容从最后一行开始显示,可以看出 tac 是 cat 的倒着写

[root@root ~]# tac /etc/sysconfig/network-scripts/ifcfg-eth0
ONBOOT=yes
BOOTPROTO=dhcp
DEVICE=eth0

nl : 显示行号

nl [-bnw] 文件

选项与参数:

  • -b :指定行号指定的方式,主要有两种:
    -b a :表示不论是否为空行,也同样列出行号(类似 cat -n);
    -b t :如果有空行,空的那一行不要列出行号(默认值);
  • -n :列出行号表示的方法,主要有三种:
    -n ln :行号在荧幕的最左方显示;
    -n rn :行号在自己栏位的最右方显示,且不加 0 ;
    -n rz :行号在自己栏位的最右方显示,且加 0 ;
  • -w :行号栏位的占用的位数。

more: 一页一页翻动

在 more 这个程序的运行过程中,你有几个按键可以按的:

  • 空白键 (space):代表向下翻一页;
  • Enter :代表向下翻『一行』;
  • /字串 :代表在这个显示的内容当中,向下搜寻『字串』这个关键字;
  • :f :立刻显示出档名以及目前显示的行数;
  • q :代表立刻离开 more ,不再显示该文件内容。
  • b 或 [ctrl]-b :代表往回翻页,不过这动作只对文件有用,对管线无用。

less 一页一页翻动

  • 空白键 :向下翻动一页;
  • [pagedown]:向下翻动一页;
  • [pageup] :向上翻动一页;
  • /字串 :向下搜寻『字串』的功能;
  • ?字串 :向上搜寻『字串』的功能;
  • n :重复前一个搜寻 (与 / 或 ? 有关!)
  • N :反向的重复前一个搜寻 (与 / 或 ? 有关!)
  • q :离开 less 这个程序;

head 取出文件前面几行

head [-n number] 文件
  • -n :后面接数字,代表显示几行的意思, 默认的情况中,显示前面 10 行

tail 取出文件后面几行

tail [-n number] 文件
  • -n :后面接数字,代表显示几行的意思. 默认的情况中,显示前面 10 行

3、Linux 链接概念

Linux 链接分两种,一种被称为硬链接(Hard Link),另一种被称为符号链接(Symbolic Link,软链接)。默认情况下,ln 命令产生硬链接。

硬连接

硬连接指通过索引节点来进行连接。在 Linux 的文件系统中,保存在磁盘分区中的文件不管是什么类型都给它分配一个编号,称为索引节点号(Inode Index)。在 Linux 中,多个文件名指向同一索引节点是存在的。比如:A 是 B 的硬链接(A 和 B 都是文件名),则 A 的目录项中的 inode 节点号与 B 的目录项中的 inode 节点号相同,即一个 inode 节点对应两个不同的文件名,两个文件名指向同一个文件,A 和 B 对文件系统来说是完全平等的。删除其中任何一个都不会影响另外一个的访问。

硬连接的作用是允许一个文件拥有多个有效路径名,这样用户就可以建立硬连接到重要文件,以防止“误删”的功能。其原因如上所述,因为对应该目录的索引节点有一个以上的连接。只删除一个连接并不影响索引节点本身和其它的连接,只有当最后一个连接被删除后,文件的数据块及目录的连接才会被释放。也就是说,文件真正删除的条件是与之相关的所有硬连接文件均被删除。

软连接

另外一种连接称之为符号连接(Symbolic Link),也叫软连接。软链接文件有类似于 Windows 的快捷方式。它实际上是一个特殊的文件。在符号连接中,文件实际上是一个文本文件,其中包含的有另一文件的位置信息。比如:A 是 B 的软链接(A 和 B 都是文件名),A 的目录项中的 inode 节点号与 B 的目录项中的 inode 节点号不相同,A 和 B 指向的是两个不同的 inode,继而指向两块不同的数据块。但是 A 的数据块中存放的只是 B 的路径名(可以根据这个找到 B 的目录项)。A 和 B 之间是“主从”关系,如果 B 被删除了,A 仍然存在(因为两个是不同的文件),但指向的是一个无效的链接。

[root@iZwz99yuz3z7cggxlq02myZ threepure]# touch f1                #创建一个f1文件
[root@iZwz99yuz3z7cggxlq02myZ threepure]# ll
total 0
-rw-r--r-- 1 root root 0 Jul 30 14:13 f1
[root@iZwz99yuz3z7cggxlq02myZ threepure]# ln f1 f2                #硬链接一个f2文件
[root@iZwz99yuz3z7cggxlq02myZ threepure]# ln -s f1 f3             #软链接一个f3文件
[root@iZwz99yuz3z7cggxlq02myZ threepure]# ls -li
total 0
1349605 -rw-r--r-- 2 root root 0 Jul 30 14:13 f1
1349605 -rw-r--r-- 2 root root 0 Jul 30 14:13 f2
1349623 lrwxrwxrwx 1 root root 2 Jul 30 14:14 f3 -> f1            #f3文件指向f1文件
[root@iZwz99yuz3z7cggxlq02myZ threepure]# echo "I am f1 file">>f1     #写入文件
[root@iZwz99yuz3z7cggxlq02myZ threepure]# cat f1                  #读取f1文件   
I am f1 file
[root@iZwz99yuz3z7cggxlq02myZ threepure]# cat f2
I am f1 file
[root@iZwz99yuz3z7cggxlq02myZ threepure]# cat f3
I am f1 file
[root@iZwz99yuz3z7cggxlq02myZ threepure]# rm -rf f1               #删除f1文件
[root@iZwz99yuz3z7cggxlq02myZ threepure]# ll
total 4
-rw-r--r-- 1 root root 13 Jul 30 14:15 f2              
lrwxrwxrwx 1 root root  2 Jul 30 14:14 f3 -> f1
[root@iZwz99yuz3z7cggxlq02myZ threepure]# cat f2                  #f2文件可读
I am f1 file
[root@iZwz99yuz3z7cggxlq02myZ threepure]# cat f3                  #f3文件失效
cat: f3: No such file or directory

六、Vim编辑器

Vim是从 vi 发展出来的一个文本编辑器。代码补完、编译及错误跳转等方便编程的功能特别丰富。

Vim键盘图:

1、vi/vim 的使用

基本上 vi/vim 共分为三种模式,分别是命令模式(Command mode)输入模式(Insert mode)底线命令模式(Last line mode)

命令模式(Command mode)

用户刚刚启动 vi/vim,便进入了命令模式。此状态下敲击键盘动作会被Vim识别为命令,而非输入字符。以下是常用的几个命令:

  • i 切换到输入模式,以输入字符。
  • x 删除当前光标所在处的字符。
  • : 切换到底线命令模式,以在最底一行输入命令。

若想要编辑文本:启动Vim,进入了命令模式,按下i,切换到输入模式。命令模式只有一些最基本的命令,因此仍要依靠底线命令模式输入更多命令。

输入模式(Insert mode)

在输入模式中,可以使用以下按键:

  • 字符按键以及Shift组合,输入字符
  • ENTER,回车键,换行
  • BACK SPACE,退格键,删除光标前一个字符
  • DEL,删除键,删除光标后一个字符
  • 方向键,在文本中移动光标
  • HOME/END,移动光标到行首/行尾
  • Page Up/Page Down,上/下翻页
  • Insert,切换光标为输入/替换模式,光标将变成竖线/下划线
  • ESC,退出输入模式,切换到命令模式

底线命令模式(Last line mode)

底线命令模式可以输入单个或多个字符的命令,可用的命令非常多。

  • q 退出程序
  • w 保存文件
  • ESC 可随时退出底线命令模式。

2、Vim案例

  1. 使用vim建立一个名为 threepure.txt 的文件:

    vim threepure.txt

    如果这个文件存在就会打开进行修改,如果不存在就会新建一个文件。

  1. 按下 i 字符就可以进入输入模式了,在一般模式之中(i,o,a)均可

第一部分:一般模式可用的光标移动、复制粘贴、搜索替换等

移动光标的方法
h 或 向左箭头键(←) 光标向左移动一个字符
j 或 向下箭头键(↓) 光标向下移动一个字符
k 或 向上箭头键(↑) 光标向上移动一个字符
l 或 向右箭头键(→) 光标向右移动一个字符
[Ctrl] + [f] 屏幕『向下』移动一页,相当于 [Page Down]按键 (常用)
[Ctrl] + [b] 屏幕『向上』移动一页,相当于 [Page Up] 按键 (常用)
[Ctrl] + [d] 屏幕『向下』移动半页
[Ctrl] + [u] 屏幕『向上』移动半页
+ 光标移动到非空格符的下一行
- 光标移动到非空格符的上一行
n< space> 那个 n 表示『数字』,例如 20 。按下数字后再按空格键,光标会向右移动这一行的 n 个字符。
0 或功能键[Home] 这是数字『 0 』:移动到这一行的最前面字符处 (常用)
$ 或功能键[End] 移动到这一行的最后面字符处(常用)
H 光标移动到这个屏幕的最上方那一行的第一个字符
M 光标移动到这个屏幕的中央那一行的第一个字符
L 光标移动到这个屏幕的最下方那一行的第一个字符
G 移动到这个档案的最后一行(常用)
nG n 为数字。移动到这个档案的第 n 行。例如 20G 则会移动到这个档案的第 20 行(可配合 :set nu)
gg 移动到这个档案的第一行,相当于 1G 啊!(常用)
n< Enter> n 为数字。光标向下移动 n 行(常用)
搜索替换
/word 向光标之下寻找一个名称为 word 的字符串。例如要在档案内搜寻 vbird 这个字符串,就输入 /vbird 即可!(常用)
?word 向光标之上寻找一个字符串名称为 word 的字符串。
n 这个 n 是英文按键。代表重复前一个搜寻的动作。举例来说, 如果刚刚我们执行 /vbird 去向下搜寻 vbird 这个字符串,则按下 n 后,会向下继续搜寻下一个名称为 vbird 的字符串。如果是执行 ?vbird 的话,那么按下 n 则会向上继续搜寻名称为 vbird 的字符串!
N 这个 N 是英文按键。与 n 刚好相反,为『反向』进行前一个搜寻动作。例如 /vbird 后,按下 N 则表示『向上』搜寻 vbird 。
删除、复制与粘贴
x, X 在一行字当中,x 为向后删除一个字符 (相当于 [del] 按键), X 为向前删除一个字符(相当于 [backspace] 亦即是退格键) (常用)
nx n 为数字,连续向后删除 n 个字符。举例来说,我要连续删除 10 个字符, 『10x』。
dd 删除游标所在的那一整行(常用)
ndd n 为数字。删除光标所在的向下 n 行,例如 20dd 则是删除 20 行 (常用)
d1G 删除光标所在到第一行的所有数据
dG 删除光标所在到最后一行的所有数据
d$ 删除游标所在处,到该行的最后一个字符
d0 那个是数字的 0 ,删除游标所在处,到该行的最前面一个字符
yy 复制游标所在的那一行(常用)
nyy n 为数字。复制光标所在的向下 n 行,例如 20yy 则是复制 20 行(常用)
y1G 复制游标所在行到第一行的所有数据
yG 复制游标所在行到最后一行的所有数据
y0 复制光标所在的那个字符到该行行首的所有数据
y$ 复制光标所在的那个字符到该行行尾的所有数据
p, P p 为将已复制的数据在光标下一行贴上,P 则为贴在游标上一行!举例来说,我目前光标在第 20 行,且已经复制了 10 行数据。则按下 p 后, 那 10 行数据会贴在原本的 20 行之后,亦即由 21 行开始贴。但如果是按下 P 呢?那么原本的第 20 行会被推到变成 30 行。(常用)
J 将光标所在行与下一行的数据结合成同一行
c 重复删除多个数据,例如向下删除 10 行,[ 10cj ]
u 复原前一个动作。(常用)
[Ctrl]+r 重做上一个动作。(常用)

第二部分:一般模式切换到编辑模式的可用的按钮说明

进入输入或取代的编辑模式
i, I 进入输入模式(Insert mode):i 为『从目前光标所在处输入』, I 为『在目前所在行的第一个非空格符处开始输入』。(常用)
a, A 进入输入模式(Insert mode):a 为『从目前光标所在的下一个字符处开始输入』, A 为『从光标所在行的最后一个字符处开始输入』。(常用)
o, O 进入输入模式(Insert mode):这是英文字母 o 的大小写。o 为『在目前光标所在的下一行处输入新的一行』;O 为在目前光标所在处的上一行输入新的一行!(常用)
r, R 进入取代模式(Replace mode):r 只会取代光标所在的那一个字符一次;R会一直取代光标所在的文字,直到按下 ESC 为止;(常用)
[Esc] 退出编辑模式,回到一般模式中(常用)

第三部分:一般模式切换到指令行模式的可用的按钮说明

指令行的储存、离开等指令
:w 将编辑的数据写入硬盘档案中(常用)
:w! 若文件属性为『只读』时,强制写入该档案。不过,到底能不能写入, 还是跟你对该档案的档案权限有关啊!
:q 离开 vi (常用)
:q! 若曾修改过档案,又不想储存,使用 ! 为强制离开不储存档案。
注意一下啊,那个惊叹号 (!) 在 vi 当中,常常具有『强制』的意思~
:wq 储存后离开,若为 :wq! 则为强制储存后离开 (常用)
ZZ 这是大写的 Z 喔!若档案没有更动,则不储存离开,若档案已经被更动过,则储存后离开!
:w [filename] 将编辑的数据储存成另一个档案(类似另存新档)
:r [filename] 在编辑的数据中,读入另一个档案的数据。亦即将 『filename』 这个档案内容加到游标所在行后面
:n1,n2 w [filename] 将 n1 到 n2 的内容储存成 filename 这个档案。
:! command 暂时离开 vi 到指令行模式下执行 command 的显示结果!例如 『:! ls /home』即可在 vi 当中看 /home 底下以 ls 输出的档案信息!
:set nu 显示行号,设定之后,会在每一行的前缀显示该行的行号
:set nonu 与 set nu 相反,为取消行号!

七、磁盘管理

一、df:列出文件系统的整体磁盘使用量

df [-ahikHTm] [目录或文件名]

选项与参数:

  • -a :列出所有的文件系统,包括系统特有的 /proc 等文件系统;
  • -k :以 KBytes 的容量显示各文件系统;
  • -m :以 MBytes 的容量显示各文件系统;
  • -h :以人们较易阅读的 GBytes, MBytes, KBytes 等格式自行显示;
  • -H :以 M=1000K 取代 M=1024K 的进位方式;
  • -T :显示文件系统类型, 连同该 partition 的 filesystem 名称 (例如 ext3) 也列出;
  • -i :不用硬盘容量,而以 inode 的数量来显示

二、du:检查磁盘空间使用量

du [-ahskm] 文件或目录名称

选项与参数:

  • -a :列出所有的文件与目录容量,因为默认仅统计目录底下的文件量而已。
  • -h :以人们较易读的容量格式 (G/M) 显示;
  • -s :列出总量而已,而不列出每个各别的目录占用容量;
  • -S :不包括子目录下的总计,与 -s 有点差别。
  • -k :以 KBytes 列出容量显示;
  • -m :以 MBytes 列出容量显示;

三、磁盘挂载与卸除

mount [-t 文件系统] [-L Label名] [-o 额外选项] [-n] 装置文件名 挂载点
umount [-fn] 装置文件名或挂载点

选项与参数:

  • -f :强制卸除!可用在类似网络文件系统 (NFS) 无法读取到的情况下;
  • -n :不升级 /etc/mtab 情况下卸除。

八、软件安装

  • rpm安装
  • 解压缩安装
  • yum安装

rpm安装(JDK)

RPM是Red-Hat Package Manager(红帽软件包管理器)的缩写。一种用于互联网下载包的打包及安装工具,它包含在某些Linux分发版中。它生成具有.RPM扩展名的文件。用于安装、卸载、升级和管理软件。

同过在Oracle官网下载后缀为.rpm的文件,通过Xftp传至服务器,通过以下步骤完成安装。

安装:rpm -ivh jdk-8u301-linux-x64.rpm

卸载:rpm -e --nodeps jdk1.8-1.8.0_301-fcs.x86_64

配置环境变量

export JAVA_HOME=/usr/java/jdk1.8.0_301-amd64
export JRE_HOME=$JAVA_HOME/jre
export CLASS_PATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/
export PATH=$PATH:$JAVA_HOME/bin:$JRE_HOME/bin
export JAVA_HOME JRE_HOME CLASS_PATH PATH

让新增的环境变量生效:通过source /etc/profile命令加载整个“profile”配置文件。

测试:java -version,返回如下信息。

java version "1.8.0_301"
Java(TM) SE Runtime Environment (build 1.8.0_301-b09)
Java HotSpot(TM) 64-Bit Server VM (build 25.301-b09, mixed mode)

关于rpm的使用。

  • -e 卸载rpm包
  • -q 查询已安装的软件信息
  • -i 安装rpm包
  • -u 升级rpm包
  • --replacepkgs 重新安装rpm包
  • --justdb 升级数据库,不修改文件系统
  • --percent 在软件包安装时输出百分比
  • --help 帮助
  • --version 显示版本信息
  • -c 显示所有配置文件
  • -d 显示所有文档文件
  • -h 显示安装进度
  • -l 列出软件包中的文件
  • -a 显示出文件状态
  • -p 查询/校验一个软件包文件
  • -v 显示详细的处理信息
  • --dump 显示基本文件信息
  • --nomd5 不验证文件的md5支持
  • --nofiles 不验证软件包中的文件
  • --nodeps 不验证软件包的依赖关系
  • --whatrequires 查询/验证需要一个依赖性的软件包
  • --whatprovides 查询/验证提供一个依赖性的软件包

解压缩安装(Tomcat)

  1. tomcat官网下载tomcat10的压缩包。在linux中,压缩文件的格式为:tar.gz

  1. 将下载的tomcat压缩包通过Xftp传到服务器的/usr目录下,通过解压目录解压这个压缩文件

    tar -zxvf apache-tomcat-9.0.22.tar.gz
    
  2. 运行Tomcat,只需要进入bin目录,执行startup.sh文件即可。

    ./startup.sh
    
  3. 关闭tomcat,

    ./shutdown.sh
    

    关于Linux的防火墙,需要确保Linux的防火墙端口是开启的,如果是阿里云,需要保证阿里云的安全组策略是开放的!我的安装过程并没有出现防火墙问题。

    # 查看firewall服务状态
    systemctl status firewalld
    
    # 开启、重启、关闭、firewalld.service服务
    # 开启
    service firewalld start
    # 重启
    service firewalld restart
    # 关闭
    service firewalld stop
    
    # 查看防火墙规则
    firewall-cmd --list-all    # 查看全部信息
    firewall-cmd --list-ports  # 只看端口信息
    
    # 开启端口
    开端口命令:firewall-cmd --zone=public --add-port=80/tcp --permanent
    重启防火墙:systemctl restart firewalld.service
    
    命令含义:
    --zone #作用域
    --add-port=80/tcp  #添加端口,格式为:端口/通讯协议
    --permanent   #永久生效,没有此参数重启后失效
    

yum 在线安装(Docker),基于CentOS7

参考Docker官网的参考手册。

  1. yum安装gcc相关

    yum -y install gcc
    yum -y install gcc-c++
    
  2. 卸载旧版本

    yum -y remove docker docker-common docker-selinux docker-engine
    # 官网版本
    yum remove docker \
              docker-client \
              docker-client-latest \
              docker-common \
              docker-latest \
              docker-latest-logrotate \
              docker-logrotate \
              docker-engine
    
  3. 安装需要的软件包

    yum install -y yum-utils device-mapper-persistent-data lvm2
    
  4. 设置stable镜像仓库

    1. # 错误
      yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
      ## 报错
      [Errno 14] curl#35 - TCP connection reset by peer
      [Errno 12] curl#35 - Timeout
      
    2. # 正确推荐使用国内的
      yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
      
  5. 更新yum软件包索引

    yum makecache fast
    
  6. 安装Docker CE

    yum -y install docker-ce docker-ce-cli containerd.io
    
  7. 启动docker

    systemctl start docker
    
  8. 测试

    docker version
    
    docker run hello-world
    
    docker images
    

关于yum的使用可以参见菜鸟教程。关于CentOS8跟CentOS7是有区别的,我只是在虚拟机上的CentOS7上安装了Docker,而服务器上是CentOS8,没有安装Docker。关于CentOS8上使用yum可以互联网上查找。

其他

ifconfig 查看网络配置,相当于Windows里面的ipconfig

ping 查看与某个网站的连接,等价于Windows中的ping

exit 退出终端

Ctrl+C 退出当前任务

touch 创建文件

echo 写入文件

ll 查看当前目录下目录和文件信息

hostname 查看主机名

hostname [主机名] 修改主机名,需要在root账户下修改,修改完需要重新连接

cat /etc/redhat-release 查看当前系统版本

date 显示或设置系统时间与日期

wget 从指定的URL下载文件.如:wget https://github.com/alibaba/nacos/releases/download/2.1.0/nacos-server-2.1.0.tar.gz 从GitHub下载Nocos到本地;

posted @ 2022-07-20 15:48  三淳  阅读(149)  评论(0编辑  收藏  举报