Linux学习笔记
文章目录
1、云服务器
直接用服务器学习Linux命令,不用虚拟机。
阿里云高效学生计划:https://developer.aliyun.com/adc/student
云服务管理控制台:https://ecs.console.aliyun.com/
可以在阿里云高效学生计划这个网站白嫖2个月云服务器,在云服务管理控制台管理云服务器
登录成功后,需要在实例->实例列表->更多中选择密码->重置实例密码
要想让外界访问,最重要的是添加安全组
2、基本认识
用FinalShell建立远程连接
Linux对zip格式解压:unzip xxxx.zip
ls:显示当前文件夹下的所有文件
cd:转到什么位置
ls -ll:一个文件独占一行的显示
若执行 ./startup.sh提示权限不够,则执行 chmod u+x *.sh
即可。
系统目录结构
/bin:bin是Binary的缩写, 这个目录存放着最经常使用的命令。
/boot: 这里存放的是启动Linux时使用的一些核心文件,包括一些连接文件以及镜像文件。
/dev : dev是Device(设备)的缩写, 存放的是Linux的外部设备,在Linux中访问设备的方式和访问文件的方式是相同的。
/etc: 这个目录用来存放所有的系统管理所需要的配置文件和子目录。
/home:用户的主目录,在Linux中,每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的。
/lib:这个目录里存放着系统最基本的动态连接共享库,其作用类似于Windows里的DLL文件。
/lost+found:这个目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件。
/media:linux系统会自动识别一些设备,例如U盘、光驱等等,当识别后,linux会把识别的设备挂载到这个目录下。
/mnt:系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将光驱挂载在/mnt/上,然后进入该目录就可以查看光驱里的内容了。
/opt:这是给主机额外安装软件所摆放的目录。比如你安装一个ORACLE数据库则就可以放到这个目录下。默认是空的。
/proc:这个目录是一个虚拟的目录,它是系统内存的映射,我们可以通过直接访问这个目录来获取系统信息。
/root:该目录为系统管理员,也称作超级权限者的用户主目录。
/sbin:s就是Super User的意思,这里存放的是系统管理员使用的系统管理程序。
/srv:该目录存放一些服务启动之后需要提取的数据。
/sys:这是linux2.6内核的一个很大的变化。该目录下安装了2.6内核中新出现的一个文件系统 sysfs 。
/tmp:这个目录是用来存放一些临时文件的。
/usr:这是一个非常重要的目录,用户的很多应用程序和文件都放在这个目录下,类似于windows下的program files目录。
/usr/bin: 系统用户使用的应用程序。
/usr/sbin: 超级用户使用的比较高级的管理程序和系统守护程序。
/usr/src: 内核源代码默认的放置目录。
/var:这个目录中存放着在不断扩充着的东西,我们习惯将那些经常被修改的目录放在这个目录下。包括各种日志文件。
/run:是一个临时文件系统,存储系统启动以来的信息。当系统重启时,这个目录下的文件应该被删掉或清除。
3、常用命令
- ls: 列出目录
- cd:切换目录
- pwd:显示目前的目录
- mkdir:创建一个新的目录
- rmdir:删除一个空的目录
- cp: 复制文件或目录
- rm: 移除文件或目录
- mv: 移动文件与目录,或修改文件与目录的名称
ls
ls -a:列出所有目录,包括隐藏域里的文件
ls -l:列出所有目录,不包括隐藏域里的文件
cd(切换目录)
cd+空格+绝对路径
cd+空格+相对路径,会根据当前路径跳转到目录或文件
cd+空格+…:返回上一级
mkdir
mkdir xxx:创建一级目录
mkdir -p xxx/xxx/xxx:创建多级目录
cp ( 复制文件或目录 )
cp 原来的文件或目录 目标目录
选项与参数:
-a:相当于-pdr 的意思,至于 pdr 请参考下列说明;(常用)
-p:连同文件的属性一起复制过去,而非使用默认属性(备份常用);
-d:若来源档为连结档的属性(link file),则复制连结档属性而非文件本身;
-r:递归持续复制,用于目录的复制行为;(常用)
-f:为强制(force)的意思,若目标文件已经存在且无法开启,则移除后再尝试一次;
-i:若目标档(destination)已经存在时,在覆盖时会先询问动作的进行(常用)
-l:进行硬式连结(hard link)的连结档创建,而非复制文件本身。
-s:复制成为符号连结档 (symbolic link),亦即『捷径』文件;
-u:若 destination 比 source 旧才升级 destination !
rm ( 移除文件或目录 )
rm [-fir] 文件或目录
选项与参数:
- -f :就是 force 的意思,忽略不存在的文件,不会出现警告信息;
- -i :互动模式,在删除前会询问使用者是否动作
- -r :递归删除啊!最常用在目录的删除了!这是非常危险的选项!!!
mv ( 移动文件与目录,或修改名称 )
选项与参数:
- -f :force 强制的意思,如果目标文件已经存在,不会询问而直接覆盖;
- -i :若目标文件 (destination) 已经存在时,就会询问是否覆盖!
- -u :若目标文件已经存在,且 source 比较新,才会升级 (update)
若mv 已存在的目录 不存在的目录,会把目录名重命名为后面不存在目录的名字。
4、基本属性
4.1、文件属性
在Linux中第一个字符代表这个文件是目录、文件或链接文件等等:
-
当为[ d ]则是目录
-
当为[ - ]则是文件;
-
若是[ l ]则表示为链接文档 ( link file );
-
若是[ b ]则表示为装置文件里面的可供储存的接口设备 ( 可随机存取装置 );
-
若是[ c ]则表示为装置文件里面的串行端口设备,例如键盘、鼠标 ( 一次性读取装置 )。
接下来的字符中,以三个为一组,且均为『rwx』 的三个参数的组合。
其中,[ r ]代表可读(read)、[ w ]代表可写(write)、[ x ]代表可执行(execute)。
要注意的是,这三个权限的位置不会改变,如果没有权限,就会出现减号[ - ]而已。
从左至右用0-9这些数字来表示。
第0位确定文件类型
,第1-3位确定属主
(该文件的所有者)拥有该文件的权限。第4-6位确定属组
(所有者的同组用户)拥有该文件的权限,第7-9位确定其他用户
拥有该文件的权限。
4.2、修改文件属性
chgrp:更改文件属组
chgrp [-R] 属组名 文件名
-R:递归更改文件属组,就是在更改某个目录文件的属组时,如果加上-R的参数,那么该目录下的所有文件的属组都会更改。
chown:更改文件属主,也可以同时更改文件属组
chown [–R] 属主名 文件名
chown [-R] 属主名:属组名 文件名
chmod:更改文件9个属性(重要)
chmod [-R] xyz 文件或目录
Linux文件属性有两种设置方法,一种是数字,一种是符号。
Linux文件的基本权限就有九个,分别是owner/group/others三种身份各有自己的read/write/execute权限。
文件的权限字符为:『-rwxrwxrwx』, 这九个权限是三个三个一组的!其中,我们可以使用数字来代表各个权限,各权限的分数对照表如下:
r:4 w:2 x:1
每种身份(owner/group/others)各自的三个权限(r/w/x)分数是需要累加的,例如当权限为:[-rwxrwx—] 分数则是:
owner = rwx = 4+2+1 = 7
group = rwx = 4+2+1 = 7
others= --- = 0+0+0 = 0
可以使用下面命令行实现:
chmod 770 filename
4.3、文件内容查看
Linux系统中使用以下命令来查看文件的内容:
-
cat 由第一行开始显示文件内容
-
tac 从最后一行开始显示,可以看出 tac 是 cat 的倒着写!
-
nl 显示的时候,顺道输出行号!
-
more 一页一页的显示文件内容
-
less 与 more 类似,但是比 more 更好的是,他可以往前翻页!
-
head 只看头几行
-
tail 只看尾巴几行
cat [-AbEnTv]
选项与参数:
-
-A :相当于 -vET 的整合选项,可列出一些特殊字符而不是空白而已;
-
-b :列出行号,仅针对非空白行做行号显示,空白行不标行号!
-
-E :将结尾的断行字节 $ 显示出来;
-
-n :列印出行号,连同空白行也会有行号,与 -b 的选项不同;
-
-T :将 [tab] 按键以 ^I 显示出来;
-
-v :列出一些看不出来的特殊字符
nl [-bnw] 文件
选项与参数:
-
-b :指定行号指定的方式,主要有两种:-b a :表示不论是否为空行,也同样列出行号(类似 cat -n):如果有空行,空的那一行不要列出行号(默认值);
-
-n :列出行号表示的方法,主要有三种:-n ln :行号在荧幕的最左方显示;-n rn :行号在自己栏位的最右方显示,且不加 0 ;-n rz :行号在自己栏位的最右方显示,且加 0 ;
-
-w :行号栏位的占用的位数。
more
在 more 这个程序的运行过程中,你有几个按键可以按的:
-
空白键 (space):代表向下翻一页;
-
Enter :代表向下翻『一行』;
-
/字串 :代表在这个显示的内容当中,向下搜寻『字串』这个关键字;
-
:f :立刻显示出档名以及目前显示的行数;
-
q :代表立刻离开 more ,不再显示该文件内容。
-
b 或 [ctrl]-b :代表往回翻页,不过这动作只对文件有用,对管线无用。
less 一页一页翻动
less运行时可以输入的命令有:
-
空白键 :向下翻动一页;
-
[pagedown]:向下翻动一页;
-
[pageup] :向上翻动一页;
-
/字串 :向下搜寻『字串』的功能;
-
?字串 :向上搜寻『字串』的功能;
-
n :重复前一个搜寻 (与 / 或 ? 有关!)
-
N :反向的重复前一个搜寻 (与 / 或 ? 有关!)
-
q :离开 less 这个程序;
head 取出文件前面几行
语法: head [-n number] 文件
选项与参数:
- -n 后面接数字,代表显示几行的意思!
默认的情况中,显示前面 10 行!
若要显示20行,可以:head -n 20 xxx
tail 取出文件后面几行
语法: tail [-n number] 文件
选项与参数:
- -n :后面接数字,代表显示几行的意思
默认的情况中,显示最后 10 行!
若要显示20行,可以:tail -n 20 xxx
5、链接
5.1、硬链接
A 是 B 的硬链接(A 和 B 都是文件名),则 A 的目录项中的 inode 节点号与 B 的目录项中的 inode 节点号相同,即一个 inode 节点对应两个不同的文件名,两个文件名指向同一个文件,A 和 B 对文件系统来说是完全平等的。删除其中任何一个都不会影响另外一个的访问。
硬连接的作用是允许一个文件拥有多个有效路径名,这样用户就可以建立硬连接到重要文件,以防止“误删”的功能。
5.2、软链接
软链接也成为符号链接。 软链接文件类似于 Windows 的快捷方式。
5.3、测试
[root@iZ8vb5nl4hbc7syh6jmdz8Z test]# touch f1
[root@iZ8vb5nl4hbc7syh6jmdz8Z test]# ls
f1 test1
[root@iZ8vb5nl4hbc7syh6jmdz8Z test]# ln f1 f2
[root@iZ8vb5nl4hbc7syh6jmdz8Z test]# ls
f1 f2 test1
[root@iZ8vb5nl4hbc7syh6jmdz8Z test]# ln -s f1 f3
[root@iZ8vb5nl4hbc7syh6jmdz8Z test]# ls
f1 f2 f3 test1
[root@iZ8vb5nl4hbc7syh6jmdz8Z test]# ls -ll
总用量 0
-rw-r--r-- 2 root root 0 4月 15 15:41 f1
-rw-r--r-- 2 root root 0 4月 15 15:41 f2
lrwxrwxrwx 1 root root 2 4月 15 15:42 f3 -> f1
drwxr-xr-x 3 root root 19 4月 15 13:28 test1
[root@iZ8vb5nl4hbc7syh6jmdz8Z test]# echo "hello world" >> f1
[root@iZ8vb5nl4hbc7syh6jmdz8Z test]# cat f1
hello world
[root@iZ8vb5nl4hbc7syh6jmdz8Z test]# cat f2
hello world
[root@iZ8vb5nl4hbc7syh6jmdz8Z test]# cat f3
hello world
[root@iZ8vb5nl4hbc7syh6jmdz8Z test]# rm -rf f1
[root@iZ8vb5nl4hbc7syh6jmdz8Z test]# ls
f2 f3 test1
[root@iZ8vb5nl4hbc7syh6jmdz8Z test]# cat f2
hello world
[root@iZ8vb5nl4hbc7syh6jmdz8Z test]# cat f3
cat: f3: 没有那个文件或目录
touch f1 # 创建一个测试文件f1
ln f1 f2 # 创建f1的一个硬连接文件f2
ln -s f1 f3 # 创建f1的一个符号连接文件f3
echo “hello world” >> f1 是把hello world写入f1中
6、Vim编辑器
6.1、简述
vim xxx.xxx:没有就新建文件,如果文件存在则修改
默认进入命令模式,输入i进入编辑模式,编辑完毕。按下ESC键回到命令模式,再按下:到底线命令模式,输入wq,保存并退出。
输入模式按键
在输入模式中,可以使用以下按键:
- 字符按键以及Shift组合,输入字符
- ENTER,回车键,换行
- BACK SPACE,退格键,删除光标前一个字符
- DEL,删除键,删除光标后一个字符
- 方向键,在文本中移动光标
- HOME/END,移动光标到行首/行尾
- Page Up/Page Down,上/下翻页
- Insert,切换光标为输入/替换模式,光标将变成竖线/下划线
- ESC,退出输入模式,切换到命令模式
6.2、一般模式可用的光标移动、复制粘贴、搜索替换等
移动光标
移动光标的方法 | |
---|---|
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 | 重做上一个动作。(常用) |
6.3、一般模式切换到编辑模式的可用的按钮说明
进入输入或取代的编辑模式 | |
---|---|
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] | 退出编辑模式,回到一般模式中(常用) |
6.4、一般模式切换到指令行模式的可用的按钮说明
指令行的储存、离开等指令 | |
---|---|
: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 相反,为取消行号! |
7、账户管理
/etc/passwd文件是用户管理工作涉及的最重要的一个文件
7.1、用户账号管理
useradd 添加用户
语法:useradd 选项 用户名
参数说明:
-
选项 :
-
- -c comment 指定一段注释性描述。
- -d 目录 指定用户主目录,如果此目录不存在,则同时使用-m选项,可以创建主目录。
- -g 用户组 指定用户所属的用户组。
- -G 用户组,用户组 指定用户所属的附加组。
- -m 使用者目录如不存在则自动建立。
- -s Shell文件 指定用户的登录Shell。
- -u 用户号 指定用户的用户号,如果同时有-o选项,则可以重复使用其他用户的标识号。
-
用户名 :
-
- 指定新账号的登录名。
当然,可以更改主机名
[root@iZ8vb5nl4hbc7syh6jmdz8Z home]# hostname
iZ8vb5nl4hbc7syh6jmdz8Z
输入hostname查看主机名
输入hostname 新主机名 修改主机名。
userdel 删除用户
语法:userdel 选项 用户名
常用的选项是 -r,它的作用是把用户的主目录一起删除。
usermod 修改用户的 用户号、主目录、用户组、登录Shell等。
语法:usermod 选项 用户名
参数说明:
-
选项 :
-
- -c comment 指定一段注释性描述。
- -d 目录 指定用户主目录,如果此目录不存在,则同时使用-m选项,可以创建主目录。
- -g 用户组 指定用户所属的用户组。
- -G 用户组,用户组 指定用户所属的附加组。
- -m 使用者目录如不存在则自动建立。
- -s Shell文件 指定用户的登录Shell。
- -u 用户号 指定用户的用户号,如果同时有-o选项,则可以重复使用其他用户的标识号。
7.2、用户口令管理
指定和修改用户口令的Shell命令是passwd。超级用户可以为自己和其他用户指定口令,普通用户只能用它修改自己的口令。
命令的格式为:
passwd 选项 用户名
可使用的选项:
- -l 锁定口令,即禁用账号。
- -u 口令解锁。
- -d 使账号无口令。
- -f 强迫用户下次登录时修改口令。
[root@iZ8vb5nl4hbc7syh6jmdz8Z home]# passwd hhh
更改用户 hhh 的密码 。
新的 密码:
重新输入新的 密码:
passwd:所有的身份验证令牌已经成功更新。
linux修改密码时不可见,盲打即可。
#代表超级用户,$代表普通用户
新建连接把公网IP写入新建连接,输入用户名和这个新密码测试即可。
普通用户直接passwd,可以修改自己的密码
[hhh@iZ8vb5nl4hbc7syh6jmdz8Z ~]$ passwd
更改用户 hhh 的密码 。
Current password:
8、用户组管理
组的增加、删除和修改实际上就是对**/etc/group**文件的更新。
groupadd 添加用户组
语法:groupadd 选项 用户组
可以使用的选项有:
- -g GID 指定新用户组的组标识号(GID)。
- -o 一般与-g选项同时使用,表示新用户组的GID可以与系统已有用户组的GID相同。
groupdel 删除一个用户组
语法:groupdel 用户组
groupmod 修改用户组
语法:groupmod 选项 用户组
常用的选项有:
- -g GID 为用户组指定新的组标识号。
- -o 与-g选项同时使用,用户组的新GID可以与系统已有用户组的GID相同。
- -n新用户组 将用户组的名字改为新名字
# 将组group2的标识号改为666,组名修改为group3。
groupmod –g 666 -n group3 group2
切换组
如果一个用户同时属于多个用户组,那么用户可以在用户组之间切换,以便具有其他用户组的权限。
$ newgrp root
这条命令将当前用户切换到root用户组,前提条件是root用户组确实是该用户的主组或附加组。
9、磁盘管理
Linux磁盘管理常用命令为 df、du。
- df :列出文件系统的整体磁盘使用量
- du:检查磁盘空间使用量
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 列出容量显示;
磁盘挂载与卸除
Linux 的磁盘挂载使用mount命令,卸载使用umount命令。
磁盘挂载语法:
mount [-t 文件系统] [-L Label名] [-o 额外选项] [-n] 装置文件名 挂载点
磁盘卸载命令 umount 语法:
umount [-fn] 装置文件名或挂载点
选项与参数:
- -f :强制卸除!可用在类似网络文件系统 (NFS) 无法读取到的情况下;
- -n :不升级 /etc/mtab 情况下卸除。
10、进程管理
ps 查看当前系统中正在运行的各种进程的信息
语法:ps -aux
可选项:
- -a :显示当前终端运行的所有的进程信息
- -u: 以用户的信息显示进程
- -x : 显示后台运行进程的参数;
# ps -aux 查看所有的进程
ps -aux|grep mysql
# | 管道符 A|B
# grep 查找文件中符合条件的字符串
ps -xx|grep 进程名字 :过滤进程信息
ps -ef : 可以查看到父进程的信息
ps -ef|grep mysql
查看父进程我们一般可以通过目录树机构来查看
进程树:
pstree -pu
- -p : 显示父id;
- -u :显示用户组;
kill -9 进程id(结束进程)
java代码死循环可以选择结束进程(杀进程)其他一般用不到
11、安装配置
11.1、jdk安装
官网下载地址:https://www.oracle.com/java/technologies/javase/javase-jdk8-downloads.html
使用rpm安装不需要配置环境变量
若提示oracle登录,使用免注册网站:http://bugmenot.com/view/oracle.com
把账户和密码复制,登录即可。
rpm包,我放入了/home/ljh/xxx.rpm
执行以下一行代码即可。
rpm -ivh jdk-8u281-linux-x64.rpm
执行java -version查看安装是否成功。
[root@iZ8vb5nl4hbc7syh6jmdz8Z ljh]# java -version
java version "1.8.0_281"
Java(TM) SE Runtime Environment (build 1.8.0_281-b09)
Java HotSpot(TM) 64-Bit Server VM (build 25.281-b09, mixed mode)
若想其他方式,可以参考:https://blog.csdn.net/king_kgh/article/details/76893339
11.2、Tomcat安装
把本机的tomcat压缩成.zip格式
拖入/home/ljh/xxx.zip
执行解压缩命令unzip xxxx.zip
若执行 ./startup.sh提示权限不够,则执行 chmod u+x *.sh
即可。
此时,若云服务器安全组配置了8080端口,则可以直接访问。内网ip:8080
不过,springboot内置了Tomcat,所以若是springboot项目,则云服务器不必安装tomcat
11.3、Linux防火墙
# 查看firewall服务状态
systemctl status firewalld
# 开启、重启、关闭、firewalld.service服务
# 开启
service firewalld start
# 重启
service firewalld restart
# 关闭
service firewalld stop
# 查看防火墙规则
firewall-cmd --list-all # 查看全部信息
firewall-cmd --list-ports # 只看端口信息
# 开启端口,只需要把下面的80换成想要开启的端口即可!
开端口命令:firewall-cmd --zone=public --add-port=80/tcp --permanent
重启防火墙:systemctl restart firewalld.service
命令含义:
--zone #作用域
--add-port=80/tcp #添加端口,格式为:端口/通讯协议
--permanent #永久生效,没有此参数重启后失效
开启之后,添加新项目时要把端口添加一下,然后再重启防火墙!
11.4、yum安装
机的tomcat压缩成.zip格式
拖入/home/ljh/xxx.zip
执行解压缩命令unzip xxxx.zip
若执行 ./startup.sh提示权限不够,则执行 chmod u+x *.sh
即可。
此时,若云服务器安全组配置了8080端口,则可以直接访问。内网ip:8080
不过,springboot内置了Tomcat,所以若是springboot项目,则云服务器不必安装tomcat
11.3、Linux防火墙
# 查看firewall服务状态
systemctl status firewalld
# 开启、重启、关闭、firewalld.service服务
# 开启
service firewalld start
# 重启
service firewalld restart
# 关闭
service firewalld stop
# 查看防火墙规则
firewall-cmd --list-all # 查看全部信息
firewall-cmd --list-ports # 只看端口信息
# 开启端口,只需要把下面的80换成想要开启的端口即可!
开端口命令:firewall-cmd --zone=public --add-port=80/tcp --permanent
重启防火墙:systemctl restart firewalld.service
命令含义:
--zone #作用域
--add-port=80/tcp #添加端口,格式为:端口/通讯协议
--permanent #永久生效,没有此参数重启后失效
开启之后,添加新项目时要把端口添加一下,然后再重启防火墙!
11.4、yum安装
yum -y install 包名