Linux的简单介绍和基础命令
一、Linux简要介绍
- Linux命令基础
- Linux命令帮助
- 目录与文件基本操作
Linux家族
- Redhat 红帽 三个认证 (开源但是不免费)---》社区(系统开发者)---》Centos(服务器端)
- Ubuntu 最好的客户端系统,开源纯免费(软件开发人群)
- Debian ---》kali Linux(专用工具资源占用很少) 树莓派
- suse Linux---》ISP(电信,移动,联通) 定制版
shell--Linux系统的一种特殊程序--"翻译官"
用户登录Linux系统时就自动加载一个shell程序,Bash是Linux系统中默认使用的shell程序
Linux的内核是由C语言开发出来的(面向过程的语言),应用程序是用c++开发
编译器-- gcc gcc-c++ jdk(Java的编译器)Python的编译器就是Python2/3
源码文件---》(编译器)--》执行文件
Linux命令的分类
- 内部命令
- 外部命令
通用的命令行使用格式:
命令字 [选项] [参数] (对应于操作、功能、操作对象)
- -单个字符的组合
- -- 单词
对root@localhost ~]# 的介绍
- root --当前用户
- @ --分隔符
- localhost --主机名字
- ~ --当前目录位置
- #--管理员
- $ --普通用户
路径简介
绝对路径:例如--/etc/sysconfig/network-scripts/
相对路径(以当前所在位置的路径):例如--sysconfig/
家目录:管理员(/root) 普通用户(/home)
根目录: /
二、Linux命令集(结合实例)
cd:切换工作目录
pwd:查看当前所在的绝对目录路径
[root@lokott ~]# cd /etc/sysconfig/network-scripts/ //进入绝对路径下的文件夹[root@lokott network-scripts]# pwd //显示当前所在的目录的绝对路径/etc/sysconfig/network-scripts[root@lokott network-scripts]# cd - //返回上次进入的目录命令,即cd /etc/sysconfig/network-scripts//root[root@lokott ~]# cd -/etc/sysconfig/network-scripts[root@lokott network-scripts]# cd .. //返回上层目录 [root@lokott sysconfig]# cd ../../ //返回上两层目录 [root@lokott /]#
ls:显示当前目录的内容
- -l 显示文件详细信息
- -a 查看隐藏文件
- -A 查看除了. .. 的隐藏文件
- -d 显示本目录的信息
- -h 友好形式显示带有单位的信息
- -R 递归显示
- -- color 以颜色区分文件类型
- 黑色(数据文件)
- 蓝色(目录)
- 红色(压缩包)
- 绿色(执行文件/命令文件/脚本)
- 天蓝色(链接文件)
- 黄的(设备文件/磁盘文件)
[root@lokott ~]# lsanaconda-ks.cfg initial-setup-ks.cfg note shell 公共 模板 视频 图片 文档 下载 音乐 桌面[root@lokott ~]# cd shell/[root@lokott shell]# ls 1.sh 2.sh 3.sh 4.sh 5.sh 6.sh hello[root@lokott shell]# ls -a. .. 1.sh 2.sh 3.sh 4.sh 5.sh 6.sh hello[root@lokott shell]# ls -A1.sh 2.sh 3.sh 4.sh 5.sh 6.sh hello[root@lokott shell]# ls -l总用量 24-rwxr-xr-x. 1 root root 111 10月 25 19:10 1.sh-rwxr-xr-x. 1 root root 124 10月 25 19:12 2.sh-rwxr-xr-x. 1 root root 192 10月 25 19:25 3.sh-rwxr-xr-x. 1 root root 104 10月 25 19:33 4.sh-rwxr-xr-x. 1 root root 147 10月 25 19:36 5.sh-rwxr-xr-x. 1 root root 26 10月 25 19:37 6.shdrwxr-xr-x. 2 root root 18 10月 30 13:53 hello[root@lokott shell]# ls -R.:1.sh 2.sh 3.sh 4.sh 5.sh 6.sh hello./hello:0.sh[root@lokott shell]# ls -d.[root@lokott shell]# ls -ah. .. 1.sh 2.sh 3.sh 4.sh 5.sh 6.sh hello[root@lokott shell]# ls -lR.:总用量 24-rwxr-xr-x. 1 root root 111 10月 25 19:10 1.sh-rwxr-xr-x. 1 root root 124 10月 25 19:12 2.sh-rwxr-xr-x. 1 root root 192 10月 25 19:25 3.sh-rwxr-xr-x. 1 root root 104 10月 25 19:33 4.sh-rwxr-xr-x. 1 root root 147 10月 25 19:36 5.sh-rwxr-xr-x. 1 root root 26 10月 25 19:37 6.shdrwxr-xr-x. 2 root root 18 10月 30 13:53 hello./hello:总用量 0-rwxrwxrwx. 1 root root 0 10月 30 13:53 0.sh[root@lokott shell]#
alias:给命令取一个别名
du:统计目录及文件空间占用情况
- -a
- -h 友好显示
- -s
which: 查找命令存放目录
- 搜索范围由环境变量PATH决定
mkdir:创建目录
- -p递归嵌套创建
touch:创建文件
[root@lokott shell]# alias c='clear' //clear是表示清屏相当于Ctrl+l的操作[root@lokott shell]# which c alias c='clear' /usr/bin/clear[root@lokott shell]# which clear/usr/bin/clear[root@lokott shell]# mkdir linux[root@lokott shell]# ls1.sh 2.sh 3.sh 4.sh 5.sh 6.sh hello linux[root@lokott shell]# touch 0.sh[root@lokott shell]# ls0.sh 1.sh 2.sh 3.sh 4.sh 5.sh 6.sh hello linux[root@lokott shell]# du -ah4.0K ./1.sh4.0K ./2.sh4.0K ./3.sh4.0K ./4.sh4.0K ./5.sh4.0K ./6.sh0 ./hello/0.sh0 ./hello0 ./linux0 ./0.sh24K .[root@lokott shell]# du -sh24K .[root@lokott shell]# du -as //不可以设置选项为-as(h)du: 不能既显示总用量,同时又显示每个项目Try 'du --help' for more information.[root@lokott shell]# [root@lokott shell]# mkdir -p /2019/2018/2017 //连续创建文件夹[root@lokott shell]# cd /2019/2018/2017/[root@lokott 2017]# touch {1..10}.txt //..表示创建连续10个名为1-10的txt文件[root@lokott 2017]# ls10.txt 1.txt 2.txt 3.txt 4.txt 5.txt 6.txt 7.txt 8.txt 9.txt
下面的操作过程中会出现文件节点(inode值):文件在磁盘中存储的标识序列
ln:创建链接文件(类似于Windows系统的快捷方式)
- 软链接:相当于快捷方式 -s
- 硬链接:给文件取别名(无法创建硬链接文件夹)
[root@lokott shell]# ln -s 1.sh 8.sh[root@lokott shell]# ln 1.sh 10.sh[root@lokott shell]# ls -l总用量 28-rwxrwxrwx. 1 root root 0 10月 30 13:59 0.sh-rwxr-xr-x. 2 root root 111 10月 25 19:10 10.sh //硬链接-rwxr-xr-x. 2 root root 111 10月 25 19:10 1.sh-rwxr-xr-x. 1 root root 124 10月 25 19:12 2.sh-rwxr-xr-x. 1 root root 192 10月 25 19:25 3.sh-rwxr-xr-x. 1 root root 104 10月 25 19:33 4.sh-rwxr-xr-x. 1 root root 147 10月 25 19:36 5.sh-rwxr-xr-x. 1 root root 26 10月 25 19:37 6.shlrwxrwxrwx. 1 root root 4 10月 30 14:07 8.sh -> 1.sh //软链接drwxr-xr-x. 2 root root 18 10月 30 13:53 hellodrwxr-xr-x. 2 root root 6 10月 30 13:59 linux[root@lokott shell]# ls -ih //显示文件节点值的大小19397655 0.sh 20564913 10.sh 20564913 1.sh 20564915 2.sh 20564917 3.sh 20564916 4.sh 20564918 5.sh 20564919 6.sh 19134334 8.sh 20565286 hello 35183604 linux//上面文件左边的就是该文件的文件节点(inode值)软链接与源文件的文件节点是非一致的,而硬链接的文件节点与源文件是一致的
cp :复制文件或目录 源|目标
- -f 不询问
- -i 询问是否覆盖原有
- -p 保持源文件的用户权限不变,权限高用户使用
- -r 递归复制
rm:删除
- -i:默认提醒
- -rf :强制递归删除
mv:移动文件或目录
[root@lokott shell]# cd hello/[root@lokott hello]# ls0.sh[root@lokott hello]# cp ../5.sh .[root@lokott hello]# ls0.sh 5.sh[root@lokott hello]# cp -i ../5.sh .cp:是否覆盖"./5.sh"? yes[root@lokott hello]# cp -f ../5.sh . //猜测被alias了cp:是否覆盖"./5.sh"? y[root@lokott hello]# [root@lokott hello]# which cp //查看cp命令果然是被alias更改了alias cp='cp -i' /usr/bin/cp[root@lokott hello]# cp -r ../linux/ . //递归复制上层路径linux文件夹的所有内容到当前路径(目前无内容)[root@lokott hello]# ls0.sh 5.sh linux[root@lokott hello]# cd linux/[root@lokott linux]# ls[root@lokott linux]# mkdir 2020 //创建文件夹[root@lokott linux]# ls2020[root@lokott linux]# cd 2020/[root@lokott 2020]# touch 2.txt //创建文件[root@lokott 2020]# cd ../../[root@lokott hello]# ls0.sh 5.sh linux[root@lokott hello]# mv linux/ ../ //移动文件夹mv:是否覆盖"../linux"? y[root@lokott hello]# cd ..[root@lokott shell]# ls0.sh 10.sh 1.sh 2.sh 3.sh 4.sh 5.sh 6.sh 8.sh hello linux[root@lokott shell]# ls -l linux/总用量 0drwxr-xr-x. 2 root root 19 10月 30 14:15 2020[root@lokott shell]# cp -r linux/ hello/ //递归复制linux文件夹的所有内容到hello文件夹中[root@lokott shell]# cd hello/[root@lokott hello]# ls0.sh 5.sh linux[root@lokott hello]# ls -l linux/总用量 0drwxr-xr-x. 2 root root 19 10月 30 14:16 2020[root@lokott hello]# ls -lR linux/ //递归查看拷贝过来的文件夹的信息linux/:总用量 0drwxr-xr-x. 2 root root 19 10月 30 14:16 2020linux/2020:总用量 0-rw-r--r--. 1 root root 0 10月 30 14:16 2.txt
通配符
- ?表示一个
- *表示多个
find:查找文件或目录
find 【查找范围】【选项】[表达式]
- -name:根据目标名字查找
- -type:根据文件类型查找
- -size:根据大小查找
- -user:根据文件的用户所有者查找
[root@lokott hello]# find . -name "*.sh" //*号表示通配符./0.sh./5.sh[root@lokott hello]# find . -type f./0.sh./5.sh./linux/2020/2.txt[root@lokott hello]# find . -size -10k../0.sh./5.sh./linux./linux/2020./linux/2020/2.txt./ifcfg-ens33[root@lokott hello]# find . -size -10k | du -ah0 ./0.sh4.0K ./5.sh0 ./linux/2020/2.txt0 ./linux/20200 ./linux4.0K ./ifcfg-ens338.0K .
centos7系统启动的命令清单
1. init 0 关机2. init 1 单用户模式(系统维护,破解密码)3. init 2 多用户模式无网络4. init 3 多用户模式有网络 *5. init 4 保留6. init 5多用户模式图形化界面有网络7. init 6 重启 (reboot)
三、Linux的目录结构
树形目录结构
/etc 管理员的家目录/home 普通用户家目录/bin 所有用户的命令文件目录/sbin 管理员命令文件目录/boot 启动分区(grub启动菜单,压缩内核等)/usr 应用程序目录/etc 配置文件目录/var 可变长文件目录(日志)/dev 设备文件目录(磁盘,光驱)/tmp 临时文件/proc 硬件信息(CPU 内存)/lib 服务管理文件(systemctl)
查看文件内容命令
cat [] 文件名 ... :查看文件内容
more [] 文件名 .. :全屏方式分页显示文件内容
less [] 文件名 ... :more命令的扩展 END 可以查找 (man less进行查看,这边不是非常方便演示效果)
head 看文件开头一部分内容(默认为10行)
tail:看文件尾部的内容(默认10行)
[root@lokott hello]# cat ifcfg-ens33 TYPE="Ethernet"PROXY_METHOD="none"BROWSER_ONLY="no"BOOTPROTO="dhcp"DEFROUTE="yes"IPV4_FAILURE_FATAL="no"IPV6INIT="yes"IPV6_AUTOCONF="yes"IPV6_DEFROUTE="yes"IPV6_FAILURE_FATAL="no"IPV6_ADDR_GEN_MODE="stable-privacy"NAME="ens33"UUID="0d6ffef5-693f-4d48-88b5-d2e1a66cf9c4"DEVICE="ens33"ONBOOT="yes"[root@lokott hello]# more ifcfg-ens33 TYPE="Ethernet"PROXY_METHOD="none"BROWSER_ONLY="no"BOOTPROTO="dhcp"DEFROUTE="yes"IPV4_FAILURE_FATAL="no"IPV6INIT="yes"IPV6_AUTOCONF="yes"IPV6_DEFROUTE="yes"IPV6_FAILURE_FATAL="no"IPV6_ADDR_GEN_MODE="stable-privacy"NAME="ens33"UUID="0d6ffef5-693f-4d48-88b5-d2e1a66cf9c4"DEVICE="ens33"ONBOOT="yes"root@lokott hello]# head ifcfg-ens33 TYPE="Ethernet"PROXY_METHOD="none"BROWSER_ONLY="no"BOOTPROTO="dhcp"DEFROUTE="yes"IPV4_FAILURE_FATAL="no"IPV6INIT="yes"IPV6_AUTOCONF="yes"IPV6_DEFROUTE="yes"IPV6_FAILURE_FATAL="no"[root@lokott hello]# tail ifcfg-ens33 IPV4_FAILURE_FATAL="no"IPV6INIT="yes"IPV6_AUTOCONF="yes"IPV6_DEFROUTE="yes"IPV6_FAILURE_FATAL="no"IPV6_ADDR_GEN_MODE="stable-privacy"NAME="ens33"UUID="0d6ffef5-693f-4d48-88b5-d2e1a66cf9c4"DEVICE="ens33"ONBOOT="yes"
统计文件内容
wc(默认全部统计)
- -l :统计行数
- -w:统计单词统计数
- -c:统计字节数
[root@lokott hello]# cat 5.sh #!/bin/bashread -p "please input a ip address!" ipping -c1 $ip &>/dev/nullif [ $? -eq 0 ]then echo "$ip is up."else echo "$ip is down"fi[root@lokott hello]# wc -l 5.sh 9 5.sh[root@lokott hello]# wc -w 5.sh 30 5.sh[root@lokott hello]# wc -c 5.sh 147 5.sh[root@lokott hello]#
检索和过滤文件内容
grep命令:在文件中查找不显示包含指定字符串的行
- grep [options] PATTERN [FILE...]
- grep [options] [-e PATTERN | -f FILE] [FILE...]
- -i :忽略大小写
- -v:反转查找,输出与查找条件不相符的行
[root@lokott hello]# grep -i up 5.sh echo "$ip is up."[root@lokott hello]# grep -v 'bash$' /etc/passwd bin:x:1:1:bin:/bin:/sbin/nologindaemon:x:2:2:daemon:/sbin:/sbin/nologinadm:x:3:4:adm:/var/adm:/sbin/nologinlp:x:4:7:lp:/var/spool/lpd:/sbin/nologinsync:x:5:0:sync:/sbin:/bin/syncshutdown:x:6:0:shutdown:/sbin:/sbin/shutdownhalt:x:7:0:halt:/sbin:/sbin/haltmail:x:8:12:mail:/var/spool/mail:/sbin/nologinoperator:x:11:0:operator:/root:/sbin/nologingames:x:12:100:games:/usr/games:/sbin/nologinftp:x:14:50:FTP User:/var/ftp:/sbin/nologinnobody:x:99:99:Nobody:/:/sbin/nologinsystemd-network:x:192:192:systemd Network Management:/:/sbin/nologindbus:x:81:81:System message bus:/:/sbin/nologinpolkitd:x:999:998:User for polkitd:/:/sbin/nologinabrt:x:173:173::/etc/abrt:/sbin/nologinlibstoragemgmt:x:998:996:daemon account for libstoragemgmt:/var/run/lsm:/sbin/nologinrpc:x:32:32:Rpcbind Daemon:/var/lib/rpcbind:/sbin/nologincolord:x:997:995:User for colord:/var/lib/colord:/sbin/nologinsaslauth:x:996:76:Saslauthd user:/run/saslauthd:/sbin/nologinrtkit:x:172:172:RealtimeKit:/proc:/sbin/nologinpulse:x:171:171:PulseAudio System Daemon:/var/run/pulse:/sbin/nologinchrony:x:995:991::/var/lib/chrony:/sbin/nologinrpcuser:x:29:29:RPC Service User:/var/lib/nfs:/sbin/nologinnfsnobody:x:65534:65534:Anonymous NFS User:/var/lib/nfs:/sbin/nologinntp:x:38:38::/etc/ntp:/sbin/nologintss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologinusbmuxd:x:113:113:usbmuxd user:/:/sbin/nologingeoclue:x:994:989:User for geoclue:/var/lib/geoclue:/sbin/nologinqemu:x:107:107:qemu user:/:/sbin/nologinradvd:x:75:75:radvd user:/:/sbin/nologinsetroubleshoot:x:993:988::/var/lib/setroubleshoot:/sbin/nologinsssd:x:992:987:User for sssd:/:/sbin/nologingdm:x:42:42::/var/lib/gdm:/sbin/nologingnome-initial-setup:x:991:986::/run/gnome-initial-setup/:/sbin/nologinsshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologinavahi:x:70:70:Avahi mDNS/DNS-SD Stack:/var/run/avahi-daemon:/sbin/nologinpostfix:x:89:89::/var/spool/postfix:/sbin/nologintcpdump:x:72:72::/:/sbin/nologinapache:x:48:48:Apache:/usr/share/httpd:/sbin/nologinroot@lokott hello]# grep -v 'bash$' /etc/passwd | wc -l //将结果写入管道后用wc命令显示结果数量40[root@lokott hello]#
Ctrl + r 可以进行命令的搜索
[root@lokott hello]# vim ifcfg-ens33 用快捷键!进入下面的模式输入之前敲击过的命令会自动查找
(reverse-i-search)`v': vim ifcfg-ens33
压缩命令
gzip命令和bzip2命令:制作压缩文件、解压缩文件
- -9表示的是高压缩比
- -d进行解压缩
[root@lokott hello]# ls0.sh 5.sh ifcfg-ens33 linux[root@lokott hello]# gzip -9 0.sh 5.sh [root@lokott hello]# ls0.sh.gz 5.sh.gz ifcfg-ens33 linux[root@lokott hello]# gzip -d 0.sh.gz [root@lokott hello]# gzip -d 5.sh.gz [root@lokott hello]# ls0.sh 5.sh ifcfg-ens33 linux[root@lokott hello]# bzip2 -9 0.sh 5.sh [root@lokott hello]# bzip2 -d 0.sh.bz2 [root@lokott hello]# bzip2 -d 5.sh.bz2 [root@lokott hello]# ls0.sh 5.sh ifcfg-ens33 linux[root@lokott hello]#
tar命令:制作归档文件、释放归档文件
- -c:创建文件包
- -x:解压文件包
- -v:显示详细过程
- -f: 执行
- -p:保留原有权限
- -t:查看压缩包的内容
- -C:解压到某个地方去
- -z:gz格式
- -j:bz2格式
[root@lokott hello]# ls0.sh 5.sh ifcfg-ens33 linux[root@lokott hello]# tar czvf if.tar.gz ifcfg-ens33 ifcfg-ens33[root@lokott hello]# ls0.sh 5.sh ifcfg-ens33 if.tar.gz linux[root@lokott hello]# tar xzvf if.tar.gz -C ../ifcfg-ens33[root@lokott hello]# cd ..[root@lokott shell]# ls0.sh 10.sh 1.sh 2.sh 3.sh 4.sh 5.sh 6.sh 8.sh hello ifcfg-ens33 linux[root@lokott shell]# //如果是bz2格式就将文件格式的后缀名更换后用j替换z的命令
四、文本编辑器vi/vim(对vim编辑器的熟练操作可以提高工作效率)
作用
- 创建或修改文本文件
- 维护Linux系统中的各种配置文件
命令模式、输入模式、末行模式(底线命令模式)转换关系和操作
vim编辑器的相关操作命令
行号设置操作
- :set nu
- :set nu!和:set nonu 取消行号 注意!!!记住切换为末行模式(底线命令模式)
定位行(命令模式下)
- gg:定位到开头
- G:定位到结尾
- 3G:3表示行号,定位到第三行
复制粘贴删除
- x:删除光标处的单个字符
- dd :删除当前光标所在行
- dw:删除光标所在位置的一个单词
- #dd :删除从光标所在行开始的#行内容
- ddp:上下行调换位置
- yy:复制改行到剪切板
- nyy:复制n行到剪切板
- p:粘贴
vim编辑器中的其他操作
shift+r 替换 在光标处进行替换
PG UP 向上翻页
PG DN 向下翻页
:e ~/install.log 打开新的文件进行编辑(末行模式下)
:r file--在编辑的数据中,读入另一个档案的数据。亦即将 『filename』 这个档案内容加到游标所在行后面(末行模式下)
:w /opt/test.txt 将该文件写入到opt下并且重新命名为test.txt文件但是不保持与源文件相同权限
:n1,n2s/word1/word2/g 在n1到n2行之间将所有的word1换为word2
:%s/word1/word2/g 将所有的word1换为word2