Linux基础
虚拟机的网络类型的简单理解:
虚拟机是在我们的操作系统里使用软件模拟出来的,相当于虚拟机是寄宿在我们的真实的物理机的操作系统里的,虚拟机和物理机之间的关系是 寄宿与被寄宿的关系, 真实的物理机被称为宿主机。
1. bridged(桥接模式) : 我们的电脑在上网的时候都需要有一个网络地址(IP地址),通过这个地址可以确定我们的电脑在网络上的位置,桥接模式就是将我们虚拟机中的网卡的网络地址 放在我们真实的物理机的网卡上。 这样的话,我们的虚拟机就好像跟我们的宿主机所在的局域网中的一台机器一样。 桥接模式适合有路由器的情况,和真实的物理环境一样。(在同一个局域网(同一个路由器)里面, 虚拟机就是局域网其中一个机器, 可以互相访问)
2. NAT(网络地址转换模式) : 在宿主机上制作一个虚拟网卡,通过这个网卡,给虚拟机分配IP。宿主机在这里的角色相当于局域网中的路由器。NAT模式适合于没有路由器的情况,虚拟机通过宿主机去上网。(宿主机为路由器, 虚拟机间可以互相访问)
3.Host-Only(模式): 和NAT模式很像,唯一的区别是,没有地址转换服务,所以该模式下虚拟机只能访问到主机。无法访问外网。
Linux上一切皆文件
Linux version -
Ubuntu(有完整图形用户界面和管理系统)
CentOS(只有命令行, 操作简单而稳定, 适合做服务器)
Debian(比乌班图稳定,也适合做服务器,内核内存占用小)
Linux目录结构:
/ : 所有目录都在(即根目录)
/boot : boot 配置文件、内核和其它启动 时所需的文件
/etc : 存放系统配置有关的文件
/home : 存放普通用户目录
/mnt : 硬盘上手动挂载(把移动设备跟操作系统连接)的文件系统
/media : 自动挂载(加载)的硬盘分区以及类似CD、数码相机等可移动介质。
/cdrom : 挂载光盘?
/opt : 存放一些可选程序,如某个程序测试版本,安装到该目录的程序的所有数据,库文件都存在同个目录下
/root : 系统管理员的目录,对于系统来说,系统管理员好比上帝,他可以对系统做任何操作,比如删除你的文件,一般情况下不要使用root用户。
/bin : 存放常用的程序文件(命令文件)。
/sbin : 系统管理命令,这里存放的是系统管理员使用的管理程序
/tmp : 临时目录,存放临时文件,系统会定期清理该目录下的文件。
/usr : 在这个目录下,你可以找到那些不适合放在/bin或/etc目录下的额外的工具。比如游戏、打印工具等。/usr目录包含了许多子目录: /usr/bin目录用于存放程序;/usr/share用于存放一些共享的数据,比如音乐文件或者图标等等;/usr/lib目录用于存放那些不能直接 运行的,但却是许多程序运行所必需的一些函数库文件。/usr/local : 这个目录一般是用来存放用户自编译安装软件的存放目录;一般是通过源码包安装的软件,如果没有特别指定安装目录的话,一般是安装在这个目录中。
/var : 该目录存放那些经常被修改的文件,包括各种日志、数据文件;
/lib : 目录是根文件系统上的程序所需的共享库,存放了根文件系统程序运行所需的共享文件。这些文件包含了可被许多程序共享的代码,以避免每个程序都包含有相同的子程序的副本,故可以使得可执行文件变得更小,节省空间。
/lib64 : 同上
/lost+found : 该目录在大多数情况下都是空的。但当突然停电、或者非正常关机后,有些文件就临时存放在;
/dev : 存放设备文件
/run : 代替/var/run目录,
/proc : 虚拟文件系统,可以在该目录下获取系统信息,这些信息是在内存中由系统自己产生的,该目录的内容不在硬盘上而在内存里;
/sys : 和proc一样,虚拟文件系统,可以在该目录下获取系统信息,这些信息是在内存中由系统自己产生的,该目录的内容不在硬盘上而在内存里;
SWAP分区的作用:
(一个隐藏的分区, 当内存不够用是, 不常用的数据会被放入, 需要用时再从中恢复出来) - 内存足够大(超过16g)时不需要
当系统的物理内存不够用的时候,就需要将物理内存中的一部分空间释放出来,以供当前运行的程序使用。那些被释放的空间可能来自一些很长时间没有什么操作的程序,这些被释放的空间被临时保存到Swap空间中,等到那些程序要运行时,再从Swap中恢复保存的数据到内存中。这样,系统总是在物理内存不够时,才进行Swap交换。
sudo cat /proc/sys/vm/swappiness
该值默认值是60.
swappiness=0的时候表示最大限度使用物理内存,然后才是 swap空间,
swappiness=100的时候表示积极的使用swap分区,并且把内存上的数据及时的搬运到swap空间里面。
语言环境及安装软件
查看是否安装了中文支持
locale -a
如果有 zh_CN.utf8 则表示系统已经安装了中文locale,如果没有则需要安装相应的软件包。安装方式如下:
sudo apt-get install language-pack-zh-hans language-pack-zh-hans-base
sudo用于权限不够时
sudo apt-get install -y openssh-server (-y默认安装时全选是)
软件管理 apt ( Advanced Packaging Tool ) , 他可以自动下载、配置、安装软件包
apt-cache search package 搜索包
apt-cache show package 获取包的相关信息,如说明、大小、版本等
sudo apt-get install package 安装包
sudo apt-get install package –reinstall 重新安装包
sudo apt-get -f install 强制安装
sudo apt-get remove package 删除包
sudo apt-get remove package –purge 删除包,包括删除配置文件等
sudo apt-get autoremove 自动删除不需要的包
sudo apt-get update 更新源
sudo apt-get upgrade 更新已安装的包
sudo apt-get dist-upgrade 升级系统
sudo apt-get dselect-upgrade 使用 dselect 升级
apt-cache depends package 了解使用依赖
apt-cache rdepends package 了解某个具体的依赖
sudo apt-get build-dep package 安装相关的编译环境
apt-get source package 下载该包的源代码
sudo apt-get clean && sudo apt-get autoclean 清理下载文件的存档
sudo apt-get check 检查是否有损坏的依赖
date : 用来显示或设定系统的日期和与时间
date +"%Y-%m-%d %H:%M:%S"
cal : 显示一个日历 cal -y 显示当年的日历
设置时区 : tzselect
快捷键
gedit Linux上的文本编辑器 按ctr+c退出
ctrl-a : 把光标移动到命令行最开始的地方。
ctrl-e : 把光标移动到命令行末尾。
ctrl-u : 清除命令行中光标所处位置之前的所有字符。
ctrl-k : 清除从提示符所在位置到行末尾之间的字符
ctrl-w : 清除左边的字段
ctrl-y : 将会贴上被ctrl-u 或者 ctrl-k 或者 ctrl-w清除的部分。
ctrl-r : 将自动在命令历史缓存中增量搜索后面入的字符。
tab : 命令行自动补全-自动补全当前的命令行。如果启用自动补全脚本命令参数和选项也可以自动补齐。
ctrl-l : 清屏
ctrl-c : 终止任务
ctrl-d : 结束输入 关闭窗口
exit : 退出窗口
clear : 清空窗口
注销/重启/关机
logout # 注销
reboot # 重启系统: 需要管理员全新啊
shutdown # 关机: 需要管理员权限
shutdow -r # 重启 可以指定时间
shudown -h #关机 可以指定时间
部分常用命令:
pwd 查看当前所在目录 一开始应该为跟目录=> /root
cd / 进入根目录(cd - change directory)
cd xx/ 进入目录
cd .. 返回上层目录
. 表示当前目录
.. 表示上级目录
man xx(xx为名命令) 查看详细解释
xx -- help (xx为名命令) 查看简单解释
xx -h
info xx
help cd 可以查看一些Linux命令行的内置命令(cd为内置命令)
man man # 查看man命令的手册
man cd
man pwd
man 5 passwd
man -k passwd # 模糊查找
man -f passwd # 精确查找
ls 查看当前目录下的文件或目录
ls -l 列出当前目录详细文件信息(1st col - 文件or目录(第一个字符为d), 5th col - 大小 单位为byte)
ls -lh 人性化展示文件列表h stand for human
ls -a 显示隐藏文件
ls -lha 人性化展示隐藏文件列表
ls : 列出目标目录中所有的子目录和文件
-----------------------
格式:ls [选项] [目录名]
-a 用于显示所有文件和子目录(保罗点文件)
-l 除了文件名之外,还将文件的权限、所有者、文件大小等信息详细列出来。
-r 将目录的内容清单以英文字母顺序的逆序显示。
-t 按文件修改时间进行排序,而不是按文件名进行排序。
-A 同-a,但不列出“.”(表示当前目录)和“..”(表示当前目录的父目录)。
-F 在列出的文件名和目录名后添加标志。例如,在可执行文件后添加“*”,在目录名后添加“/”以区分不同的类型。
-R 如果目标目录及其子目录中有文件,就列出所有的文件。
. 和..
. 表示当前目录
.. 表示父目录
vi/vim : 编辑器
vim xxx 创建文件 xxx为文件名
进入后默认为命令行模式 若要编辑 需要按’i'进入insert模式才能编辑
如要保存 按Esc回到命令行模式 再按shift + :键, 再输入wq 再按enter 及保存且退出 若按q仅退出不保存 !为强制执行操作如w!q!wq! w xx1保存且指定文件名为xx1
vim .test 创建一个隐藏文件 因为.

光标的移动和翻页操作
h向左移动光标
l向右移动光标
k向上移动光标
j向下移动光标
翻页Ctrl + f向前翻整页
Ctrl + b向后翻整页
Ctrl + u向前翻半页
Ctrl + d向后翻半页
行内快速跳转
^将光标快速跳转到本行的行首字符
$将光标快速跳转到本行的行尾字符
w将光标快速跳转到当前光标所在位置的后一个单词的首字母
b将光标快速跳转到当前光标所在位置的前一个单词的首字母
e将光标快速跳转到当前光标所在位置的后一个单词的尾字母
文件内行间快速跳转
命令功能
:set nu 在编辑器中显示行号
:set nonu 取消编辑器中的行号显示
1G跳转到文件的首行
G跳转到文件的末尾行
#G跳转到文件中的第#行
进入输入模式
i在当前光标处进入插入状态
a在当前光标后进入插入状态
A将光标移动到当前行的行末,并进入插入状态
o在当前行的下面插入新行,光标移动到新行的行首,进入插入状态
O在当前行的上面插入新行,光标移动到新行的行首,进入插入状态
cw删除当前光标到所在单词尾部的字符,并进入插入状态
c$删除当前光标到行尾的字符,并进入插入状态
c^命令删除当前光标之前(不包括光标上的字符)到行首的字符,并进入插入状态
输入模式的编辑键操作
方向键进行上下左右方向的光标移动
Home快速定位光标到行首
End快速定位光标到行尾
PageUp进行文本的向上翻页
PageDown进行文本的向下翻页
Backspace删除光标左侧的字符
Del删除光标位置的字符
删除操作
x删除光标处的单个字符
dd删除光标所在行
dw删除当前字符到单词尾(包括空格)的所有字符
de删除当前字符到单词尾(不包括单词尾部的空格)的所有字符
d$删除当前字符到行尾的所有字符
d^删除当前字符到行首的所有字符
J删除光标所在行行尾的换行符,相当于合并当前行和下一行的内容
替换操作
:s/old/new 将当前行中查找到的第一个字符“old” 串替换为“new”
:s/old/new/g 将当前行中查找到的所有字符串“old” 替换为“new”
:#,#s/old/new/g 在行号“#,#”范围内替换所有的字符串“old”为“new”
:%s/old/new/g 在整个文件范围内替换所有的字符串“old”为“new”
:s/old/new/c 在替换命令末尾加入c命令,将对每个替换动作提示用户进行确认
撤消操作
u取消最近一次的操作,并恢复操作结果
可以多次使用u命令恢复已进行的多步操作
U取消对当前行进行的所有操作
Ctrl + r对使用u命令撤销的操作进行恢复
复制与粘贴操作
yy复制当前行整行的内容到vi缓冲区
yw复制当前光标到单词尾字符的内容到vi缓冲区
y$复制当前光标到行尾的内容到vi缓冲区
y^复制当前光标到行首的内容到vi缓冲区
p读取vi缓冲区中的内容,并粘贴到光标当前的位置(不覆盖文件已有的内容)
字符串查找操作
/word从上而下在文件中查找字符串“word”
?word 从下而上在文件中查找字符串“word”
n定位下一个匹配的被查找字符串
N定位上一个匹配的被查找字符串
vim xxx 或者
cat xxx 查看文件内容
more xxx 可以慢慢查看内容
less : 查看文件内容
head : 输出文件的开始的部分, 可以指定行数 , 默认显示10行
tail : 查看文件尾部的内容。默认显示最后10行 (可实时监控log文件)
which # 查找其他命令的位置
touch 创建文件 但主要用来修改文件时间
touch /xx/xx/xx/.log 创建文件
mkdir xxx1 创建目录
mv xxx xxx1/ 移动前面文件/目录到后面的目录
mkdir -p XXX/XX/X 递归的创建目录
tree XX 显示XX目录的树结构图
cp 复制和 黏贴 - cp xx.log /root/
cp -i SOURCE DEST # 如果遇到需要覆盖的情况,则提示
cp -r dir1 dir2 # 若给出的源文件是一目录文件,此时cp将递归复制该目录下所有的子目录和文件。此时目标文件必须为一个目录名
cp -p file1 file2 # 此时cp除复制源文件的内容外,还将把其修改时间和访问权限也复制到新文件中。
cp -rp dir1 dir2
locate xx 查找文件
locate /etc/sh # 搜索所有etc目录下以sh开头的文件。
locate ~/a # 搜索用户主目录下,所有以a开头的文件。
locate -i ~/a # 搜索用户主目录下,所有以a开头的文件,-i并且忽略大小写。
find
按名字查找
find / -name “xx.log” 查看文件位置所在
find /home. -iname “*e.py” -i不区分大小写
find / -name *xx* 按文件名模糊查询
按目录深度查找
find . -maxdepth 3 -type f # 最大深度为3
find . -mindepth 2 -type f # 最小深度为2
按大小查找
find / -size +90M 按大小查询
find / -size +90M |xargs ls -lh 按大小查询并列出详细信息
xxx |xargs xxxx 把前面xxx命令的所有结果 当做后面xxxx的输入
按时间查找
-atime(+|-)n # 此选项代表查找出n天以前被读取过的文件。
-mtime(+|-)n # 此选项代表查找出n天以前文件内容发生改变的文件。
-ctime(+|-)n # 此选项代表查找出n天以前的文件的属性发生改变的文件。
-newer file # 此选项代表查找出所有比file新的文件。
-newer file1 ! –newer file2 # 此选项代表查找比file1文件时间新但是没有file2时间新的文件。
按用户/权限查找
-user 用户名:根据文件的属主名查找文件。
-group 组名:根据文件的属组名查找文件。
-uid n:根据文件属主的UID进行查找文件。
-gid n:根据文件属组的GID进行查找文件。
-nouser:查询文件属主在/etc/passwd文件中不存在的文件。
-nogroup:查询文件属组在/etc/group文件中不存在的文件
-perm 777: 查询权限为777的文件
查找时指定多个条件
-o:逻辑或,两个条件只要满足一个即可。
-a:逻辑与,两个条件必须同时满足。
find /etc -size +2M -a -size -10M
对查找结果进行处理
-exec shell命令 {} \;
-ok shell命令 {} \;
其中-exec就是代表要执行shell命令,后面加的是shell指令,再后面的“{}”表示的是要对前面查询到的结果进行查询,最后的“\;”表示命令结束。需要注意的是“{}”和“\”之间是要有空格的。而-ok选项与-exec的唯一区别就是它在执行shell命令的时候会事先进行询问,-print选项是将结果显示在标准输入上
find /home -name “*.txt” -ok ls -l {} \;
find /home -name “*.txt” -ok rm {} \;
rm xx.log 删除文件 Linux里面没有回收站 删除就没了
代替方法:创建一个目录当做回收站使用
或者 >xx.log 清空文件
三剑客之一 grep
grep xxx 查看文件并快速修改 xxx为文件里的内容
-c --count #计算符合样式的列数
-l --file-with-matches #列出文件内容符合指定的样式的文件名称。
-v --revert-match #显示不包含匹配文本的所有行。
-i --ignore-case #忽略字符大小写的差别。
-o # 只显示匹配到的关键字
-n # 现实行号 -on可连用n也可和其他连用
-E 使用正则表达式(用来匹配字符串)
部分正则表达式:
^ : 匹配开头 ^xxx
$ : 匹配结尾 xxx$
[] : 范围匹配
[a-z] : 匹配有小写字母
[A-Z] : 匹配所有大写字母
[0-9] : 匹配所有数字
[^0=9] 非0至9 ^表示取反
. : 匹配单个字符
* : 表示*前面的内容出现0次或多次 [a-z]* 0个或多个小写字母
+ : 表示+前面的内容出现1次或多次 [a-z]+ 至少出现一次小写字母
? : 表示?前面的内容出现0次或1次 [a-z]? 出现0次或一个小写字母
grep -E “^S” z.txt
cat a.txt |grep hat$ # 匹配以hat结尾的行
cat a.txt |grep ^hat # 匹配以hat开头的行
cat a.txt | grep -E "[0-9]*" # 匹配有0到多个数字的行
cat a.txt | grep -E "[0-9]+" # 匹配有至少有1个数字的行
cat a.txt | grep -E "[0-9]?" # 匹配有0到1个数字的行
简单邮箱匹配 grep -E “[0-9a-zA-Z]+@[0-9a-zA-Z]+\.[a-zA-Z]+”z.txt
三剑客之一 sed
用于编辑, 流编辑器,一次处理一行内容
sed [-nefr] [动作] [文件]
cat -n xx.txt | sed “3d” 删除第三行
cat -n xx.txt | sed -n “3p”
cat -n xx.txt | sed “3”a’xxxx’
cat -n xx.txt | sed “3”c’xxxx’
cat -n xx.txt | sed “s/x/x1/” x替换成x1
选项与参数:
-n :使用安静(silent)模式。在一般 sed 的用法中,所有来自 STDIN 的数据一般都会被列出到终端上。但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来 (前面加行数)
-e :直接在命令列模式上进行 sed 的动作编辑
-f :直接将 sed 的动作写在一个文件内, -f filename 则可以运行 filename 内的 sed 动作
-r :sed 的动作支持的是延伸型正规表示法的语法。(默认是基础正规表示法语法)
-i :直接修改读取的文件内容,而不是输出到终端。
动作说明: [n1[,n2]] 动作:
n1, n2 :不一定存在,一般代表选择进行动作的行数,比如,如果我的动作是需要在 10 到 20 行之间进行的,则10,20[动作行为]
动作:
#a :新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)
#c :取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行!
#d :删除,因为是删除啊,所以 d 后面通常不接任何咚咚;
sed "3d" file # 删除第三行
sed "1,3d" # 删除前三行
sed "1d;3d;5d" # 删除1、3、5行
sed "/^$/d" #删除空行
sed "/abc/d" #删除所有含有abc的行
sed "/abc/,/def/d" #删除abc 和 def 之间的行,包括其自身
sed "1,/def/d" #删除第一行到 def 之间的行,包括其自身
sed "/abc/,+3d " # 删除含有abc的行之后,在删除3行
sed "/abc/,~3d" #从含有abc的行开始,共删除3行
sed "1~2d" # 从第1行开始,每2行删除一行, 删除奇数行
sed "2~2d" # 从第2行开始,每2行删除一行, 删除奇数行
sed “\$d" # 删除最后一行
sed "/dd\|cc/d" 删除有dd或者cc的行 (\作用转义)
#i :插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行);
#p :列印,亦即将某个选择的数据印出。通常 p 会与参数 sed -n 一起运行
sed -n "3p" file # 显示第三行
sed -n "1,3p" # 显示前三行
sed -n "2,+3p" # 显示第二行,及后面的三行
sed -n “\$p" # 显示最后一行
sed -n "1p;3p;5p" # 只显示文件1、3、5行
sed -n "$=" # 显示文件行数
#s :替换,可以直接进行取代的工作。通常这个 s 的动作可以搭配正规表示法,例如 1,20s/old/new/g (最常用)
's/old/new/g'
sed "s/\(all\)/bb/"
sed -r "s/(all)/bb/"
三剑客之一 awk
一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大。简单来说awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行各种分析处理.
# 命令行调用方式
awk [-F field-separator] 'commands' input-file(s)
awk ‘{print $1}’ xx.txt 显示每行第一列
awk ‘{print NR}’ xx.txt
# commands 是真正awk命令,[-F域分隔符]是可选的。 input-file(s) 是待处理的文件。 在awk中,文件的每一行中,由域分隔符分开的每一项称为一个域。通常,在不指名-F域分隔符的情况下,默认的域分隔符是空格。
# awk工作流程:
# 读入有'\n'换行符分割的一条记录,然后将记录按指定的域分隔符划分域,填充域,$0则表示所有域,$1表示第一个域,$n表示第n个域。默认域分隔符是"空白键" 或 "[tab]键",所以$1表示登录用户,$3表示登录用户ip,以此类推。
cat /etc/passwd |awk -F ':' '{print $1}'
cat /etc/passwd |awk -F ':' '{print $1"\t"$7}'
awk 常用内置变量
ARGC 命令行参数个数
ARGV 命令行参数排列, ARGV[0] ARGV[1]
ENVIRON 支持队列中系统环境变量的使用
FILENAME awk浏览的文件名
FNR 浏览文件的记录数(行数)
FS 设置输入域分隔符,等价于命令行 -F选项
NF 浏览记录的域的个数
NR 已读的记录数(总行数)
OFS 输出域分隔符
ORS 输出记录分隔符
RS 控制记录分隔符
# 统计/etc/passwd:文件名,每行的行号,每行的列数,对应的完整行内容:
#awk -F ':' '{print "filename:" FILENAME ",linenumber:" NR ",columns:" NF ",linecontent:"$0}' /etc/passwd
# 使用printf替代print,可以让代码更加简洁,易读
awk -F ':' '{printf("filename:%10s,linenumber:%s,columns:%s,linecontent:%s\n",FILENAME,NR,NF,$0)}' /etc/passwd
tar zcvf demo.tar.gz ./* 打包文件 zcvf为参数 demo为自定的文件名 .tar.gz为格式 ./*表示所有文件 建立压缩文件
tar zxf demo.tar.gz 解压文件 zxf为参数 demo名字
-c :建立一个压缩文件的参数指令(create 的意思);
-x :解开一个压缩文件的参数指令!
-t :查看 tarfile 里面的文件!
特别注意 c/x/t 同时仅能存在一个,因为不可能同时压缩与解压缩。
-z :是否同时具有 gzip 的属性?亦即是否需要用 gzip 压缩?
-j :是否同时具有 bzip2 的属性?亦即是否需要用 bzip2 压缩?
-v :压缩的过程中显示文件!这个常用,但不建议用在背景执行过程!
-f :使用档名,请留意,在 f 之后要立即接文件名
-p :使用原文件的原来属性(属性不会依据使用者而变)
-P :可以使用绝对路径来压缩!
-N :比后面接的日期(yyyy/mm/dd)还要新的才会被打包进新建的文件中!
# 将当前目录下所有.txt文件打包并压缩归档到文件this.tar.gz
tar czvf this.tar.gz ./*.txt
# 将当前目录下的this.tar.gz中的文件解压到当前目录
tar xzvf this.tar.gz ./
# 将整个 /etc 目录下的文件全部打包成为 /tmp/etc.tar
tar -cvf /tmp/etc.tar /etc # 仅打包,不压缩!
tar -zcvf /tmp/etc.tar.gz /etc # 打包后,以 gzip 压缩
tar -jcvf /tmp/etc.tar.bz2 /etc # 打包后,以 bzip2 压缩
# 解压文件
tar -xf a.tar.gz #
tar -xf a.tar.gz -C /tmp # 指定解包路径
sz xx.tar.gz 下载文件
df -h 查看当前系统磁盘的各种容量 h表人性化
df -Th 查看分区如何挂载
/dev/sda1 ext4 62G 4.3G 55G 8% /
du -sh 查看当前文件/目录的容量
du -sh ./* ./*代表当前目录下所有文件
-s : 如果后面是目录,只显示一层
-h : 以能显示的最大单位显示
free -m 查看当前服务器的内存
top 查看系统性能, q退出
kill 2731 杀掉进程 2731为进程号
在top里面可查看:
cpu:
user:用户进程所占的cpu
system:操作系统本身所占cpu
iowait:CPU等待io的时间比
idle:cpu空闲率
mem:
total
usage(使用, 但是不是准的)
free(空闲) 实际free = free + cache - buffer
cache(缓存)
buffer(准备使用)
ip a 查看ip地址
ifconfig 查看ip地址
mount / umount 挂载和卸载设备
mount # 查询挂在设备及属性
# 挂载光盘
mount -t iso9660 /dev/cerom /mnt
mount /dev/sr0 /mnt
# 重新挂载设备
mount -o remount,rw /mnt # 重新挂载设备并设置rw属性
# 挂载iso文件
mount a.iso -o loop /mnt
umount /mnt # 卸载设备
umount -l /mnt # 强制卸载
用户和用户组
linux使用文件保存用户信息 :
文件
less /etc/passwd 用户账户信息。
less /etc/shadow 安全用户账户信息。
less /etc/group 组账户信息。
less /etc/gshadow 安全组账户信息。
less /etc/default/useradd 账户创建的默认值。
less /etc/skel/ 包含默认文件的目录。
less /etc/login.defs Shadow 密码套件配置。
charon:x:1000:1000:Charon,,,:/home/charon:/bin/bashuseradd:
第一个1000为user ID 第二个1000为group ID charon,,,为comment
/home/charon 为家目录
/bin/bashuseradd 为shell 壳 通过它可以跟系统交互
用到的终端默认使用的shell 是bash 其他的shell 有dash 、csh 、tcsh、zsh等等
Shell本身是一个用C语言编写的程序,它是用户使用Unix/Linux的桥梁,用户的大部分工作都是通过Shell完成的。Shell既是一种命令语言,又是一种程序设计语言。作为命令语言,它交互式地解释和执行用户输入的命令;作为程序设计语言,它定义了各种变量和参数,并提供了许多在高级语言中才具有的控制结构,包括循环和分支。
自定义账户的个性化环境的三个重要文件
.bash_history .bash_logout .bashrc
刚登录Linux时,首先启动 /etc/profile 文件 , ~/.bash_profile、 ~/.bash_login、 ~/.profile。 如果 ~/.bash_profile文件存在的话,一般还会执行 ~/.bashrc文件。
添加用户
sudo useradd -m -s /bin/bash xx 在创建xx用户的时候建立用户主文件夹 并将/etc/skel/当中的文件复制到用户的根目录下 同时设置用户登录所使用的shell
sudo passwd xx
# -c 备注 加上备注。并会将此备注文字加在/etc/passwd中的第5项字段中
# -d 用户主文件夹。指定用户登录所进入的目录,并赋予用户对该目录的的完全控制权
# -e 有效期限。指定帐号的有效期限。格式为YYYY-MM-DD,将存储在/etc/shadow
# -f 缓冲天数。限定密码过期后多少天,将该用户帐号停用
# -g 主要组。设置用户所属的主要组
# -G 次要组。设置用户所属的次要组,可设置多组
# -M 强制不创建用户主文件夹
# -m 强制建立用户主文件夹,并将/etc/skel/当中的文件复制到用户的根目录下
# -p 密码。输入该帐号的密码
# -s shell。用户登录所使用的shell
# -u uid。指定帐号的标志符user id,简称uid
userdel : 删除用户 sudo userdel -r xx
usermod: 修改用户信息
# -c<备注> 修改用户帐号的备注文字。
# -d登入目录> 修改用户登入时的目录。
# -e<有效期限> 修改帐号的有效期限。
# -f<缓冲天数> 修改在密码过期后多少天即关闭该帐号。
# -g<群组> 修改用户所属的群组。
# -G<群组> 修改用户所属的附加群组。
# -l<帐号名称> 修改用户帐号名称。
# -L 锁定用户密码,使密码无效。
# -s<shell> 修改用户登入后所使用的shell。
# -u<uid> 修改用户ID。
# -U 解除密码锁定。
usermod -G staff user2 # 将 newuser2 添加到组 staff 中
usermod -l newuser1 newuser # 修改 newuser 的用户名为 newuser1
usermod -L newuser1 # 锁定账号 newuser1
usermod -U newuser1 # 解除对 newuser1 的锁定
groupadd : 添加组
groupadd group1
groupadd -g 1000 group1 # 指定gid
groupdel : 删除组
groupdel group1 # 删除组
su与 sudo
su : 切换用户,没有参数时,默认切换为root用户;
su - # 切换为root 并加载user1的环境配置
su - user1 # 切换为user1 并加载user1的环境配置
sudo : 一般情况下 让当前用户暂时以管理员的身份来执行命令
二般情况下 让当前用户暂时以指定的身份来执行命令
编辑sudo的配置文件
- vi /etc/sudoers (vi/vim为文本编辑器)
- visudo
alias : 给命令起别名
alias ll='ls -alF’
alias la='ls -A’
alias l='ls -CF’
如果需要别名永久生效,需要保存到 .bashrc 文件
chown xx1.xx2 xx xx1为用户(属主) xx2为用户组(属组) xx为文件 修改用户
文件权限
rwxr-xr-x
这样看的: rwx r-x r-x
用户的权限 用户组的权限 其他
7 5 5
7+4+1 4+1 4+1
r read 4
w write 2
x excute 1
- 0
777
rwxrwxrwx 非常不安全
root root other
修改权限:
chmod 777 xx/ 修改文件夹权限 xx/为文件夹
chmod 755 xx/
chmod o+w file1
chmod g-w file1
chmod go-w file1
chmod u=rwx file1
chmod 755 file1 # -rwxr-xr-x (755) 只有所有者才有读,写,执行的权限,组群和其他人只有读和执行的权限
chmod 644 # -rw-r--r-- (644) 只有所有者才有读和写的权限,组群和其他人只有读的权限
# 其中:
# u 代表所有者(user)
# g 代表所有者所在的组群(group)
# o 代表其他人,但不是u和g (other)
# a 代表全部的人,也就是包括u,g和o
stat xxx 查看文件状态
wc :统计指定文件中的字节数、字数、行数,并将统计结果显示输出
-c 统计字节数。
-l 统计行数。
-m 统计字符数。这个标志不能与 -c 标志一起使用。
-w 统计字数。一个字被定义为由空白、跳格或换行字符分隔的字符串
sort: 排序
选项与参数:
-f :忽略大小写的差异,例如 A 与 a 视为编码相同;
-b :忽略最前面的空格符部分;
-n :使用『纯数字』进行排序(默认是以文字型态来排序的);
-r :反向排序;
-u :就是 uniq ,相同的数据中,仅出现一行代表;
-t :分隔符,默认是用 [tab] 键来分隔;
-k :以那个区间 (field) 来进行排序的意思
uniq: 忽略或报告重行
-i :忽略大小写字符的不同;
-c :进行计数
-u :只显示唯一的行
cut命令可以从一个文本文件或者文本流中提取文本列。
-d :后面接分隔字符。与 -f 一起使用;
-f :依据 -d 的分隔字符将一段信息分割成为数段,用 -f 取出第几段的意思;
-c :以字符 (characters) 的单位取出固定字符区间;
tee : 读取标准输入的数据,并将其内容输出成文件。
cat sec.log | tee file1 # 读取sec.log ,并生成file1文件
cat sec.log | tee - a file1 # 读取sec.log ,并追加,
cat sec.log |tee file1 file2
history : 查看执行过的命令。
修改PATH环境变量
sudo vim ~/.profile
~/.profile —> PATH=“要增加的路径:$PATH” (当前用户)
/etc/profile —> PATH=“要增加的路径:$PATH” (所有用户)
env : 查看当前环境变量
export : 设置或显示环境变量。
source xx 在当前bash环境下读取并执行FileName中的命令。该filename文件可以无"执行权限"
echo
echo “xxx”
echo -n “xxx” (-n 不要再最后自动换行)
echo会将输入的字符串送往标准输出。输出的字符串间以空白字符隔开并在最后加上换行号。
管道符
管道符 就是 | :他的作用是 将前一个命令的结果 交给后一个命令使用
重定向
> 重定向,如果的文件存在,则覆盖文件内容,文件不存在时创建文件
>> 重定向,如果的文件存在,则向文件追加内容,文件不存在时创建文件
1> 标准正确输出,同上
1>> 标准正确输出,同上
2> 标准错误输出,同上
2>> 标准错误输出,同上
&> 标准正确输出和标准错误输出,同上
crontab 计划任务
- - - - - -
第六个- 预执行的命令
第五个- 表示星期0~7(其中星期天可以用0或7表示)
第四个- 表示月份1~12
第三个- 表示日期1~31
第二个- 表示小时1~23(0表示0点)
第一个- 表示分钟1~59 每分钟用*或者 */1表示
-u user:用来设定某个用户的crontab服务;
-e:编辑某个用户的crontab文件内容。如果不指定用户,则表示编辑当前用户的crontab文件。
-l:显示某个用户的crontab文件内容,如果不指定用户,则表示显示当前用户的crontab文件内容。
-r:从/var/spool/cron目录中删除某个用户的crontab文件,如果不指定用户,则默认删除当前用户的crontab文件。
-i:在删除用户的crontab文件时给确认提示
*/1 * * * * date >> /tmp/date/txt 表示每一分钟执行一次

浙公网安备 33010602011771号