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:
内核源代码默认的放置目录。
- /usr/bin:
-
/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 username
【username
是你的用户名】
2.从普通用户切换到root用户,还可以使用命令:sudo su
3.在终端输入exit
或logout
或使用快捷方式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 系统对不同的用户访问同一文件(包括目录文件)的权限做了不同的规定。
首先通过一张图来了解文件的基本属性:
第一个字符表述file type,也就是文件类型。规则如下:
- 当为 d 则是目录
- 当为 - 则是文件;
- 若是 l 则表示为链接文档(link file);
- 若是 b 则表示为装置文件里面的可供储存的接口设备(可随机存取装置);
- 若是 c 则表示为装置文件里面的串行端口设备,例如键盘、鼠标(一次性读取装置)。
接下来的字符中,以三个为一组,且均为 rwx 的三个参数的组合。其中, r
代表可读(read)、 w
代表可写(write)、 x
代表可执行(execute)。这三个权限的位置固定,如果没有权限,就会出现 - 。具体表示如下:
- 属主权限:该文件所有者拥有该文件的权限。
- 属组权限:所有者的同组用户拥有该文件的权限
- 其他用户权限:其他用户拥有该文件的权限。
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
五、文件与目录管理
-
区分绝对路径和相对路径
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案例
-
使用vim建立一个名为 threepure.txt 的文件:
vim threepure.txt
如果这个文件存在就会打开进行修改,如果不存在就会新建一个文件。
- 按下 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)
- 在tomcat官网下载tomcat10的压缩包。在linux中,压缩文件的格式为:
tar.gz
-
将下载的tomcat压缩包通过Xftp传到服务器的
/usr
目录下,通过解压目录解压这个压缩文件tar -zxvf apache-tomcat-9.0.22.tar.gz
-
运行Tomcat,只需要进入bin目录,执行
startup.sh
文件即可。./startup.sh
-
关闭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官网的参考手册。
-
yum安装gcc相关
yum -y install gcc yum -y install gcc-c++
-
卸载旧版本
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
-
安装需要的软件包
yum install -y yum-utils device-mapper-persistent-data lvm2
-
设置stable镜像仓库
-
# 错误 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
-
# 正确推荐使用国内的 yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
-
-
更新yum软件包索引
yum makecache fast
-
安装Docker CE
yum -y install docker-ce docker-ce-cli containerd.io
-
启动docker
systemctl start docker
-
测试
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到本地;