Linux
Linux的简单了解
Linux的常用命令
Linux的用户和组
Linux的权限命令
Linux的简单了解
- 概述:
- linux是基于Unix开发的,是一种自由和开放源码的操作系统,.可安装在各种计算机硬件设备中,比如,手机、平板电脑、路由器、台式计算机等.
- 诞生于1991年10月5日. 由Linus Torvalds和后来加入的众多爱好者共同开发完成.
- 版本分为内核版本和发行版本. 区别在于,内核版本是Linus领导下的内核小组开发维护的,而发行版本是一些组织和公司根据自己的需要而自定的.
- 发明者照片(一个有梦想的富二代)
- 安装软件
- 下载虚拟机和linux镜像(自行百度)
- 安装(B站看视频)
- Linux的目录结构
- bin (binaries)存放二进制可执行文件
- sbin (super user binaries)存放二进制可执行文件,只有root才能访问
- etc (etcetera)存放系统配置文件
- usr (unix shared resources)用于存放共享的系统资源
- home 存放用户文件的根目录
- root 超级用户目录
- dev (devices) 用于存放设备文件
- lib (library)存放跟文件系统中的程序运行所需要的共享库及内核模块
- mnt (mount)系统管理员安装临时文件系统的安装点
- boot 存放用于系统引导时使用的各种文件
- tmp (temporary)用于存放各种临时文件
- var (variable)用于存放运行时需要改变数据的文件
Linux的常用命令
- 切换目录命令 cd :
cd app
切换到app目录cd ..
切换到上一层目录cd /
切换到系统根目录cd -
切换到上一个所在目录
- 列出文件列表 ls ll dir
- ls
- ls -a 显示所有文件或目录(包含隐藏的文件)
- ls -l 缩写成ll
- 创建目录和移除目录 : mkdir rmdir
- mkdir(make directory)命令可用来创建子目录
mkdir app 在当前目录下创建app目录
mkdir -p app2/test 级联创建app2以及test目录(app2里边包含test) - rmdir(remove directory)命令可用来删除空的子目录
rmdir app 删除app目录
- mkdir(make directory)命令可用来创建子目录
- 浏览文件 : cat more less
cat 显示文件的内容 cat yum.conf
more 一般用于要显示的内容会超过一个页面长度的情况,按空格键显示下一个页面,回车显示下一行内容,按q键退出查看
less 用法和more类似,不同的是less可以通过PgUp、PgDn键来控制上下翻页.
tail 是在实际使用过程中使用非常多的一个命令,它的功能是: 用于显示文件后几行的内容.
tail -10 /etc/passwd 查看后10行数据
tail -f catalina.log 动态查看日志 - 文件操作
- rm 删除文件
rm a.txt 删除需要用户确认
rm -f a.txt 不询问,直接删除 - rm 删除目录
rm -r a 递归删除 - cp(copy)命令可以将文件从一处复制到另一处,一般在使用cp命令时将一个文件复制成另一个文件或复制到某目录时,需要指定源文件名与目标文件名或目录.
cp a.txt b.txt 将a,txt复制为b.txt文件
cp a.txt …/ 将a.txt文件复制到上一层目录中 - mv移动或者重命名
mv a.txt …/ 将a.txt文件移动到上一层目录中
mv a.txt b.txt 将a.txt文件重命名为b.txt. - tar 打包或解压
tar命令位于/bin目录下,它能够将用户所指定的文件或目录打包成一个文件,但不做压缩. 一般Linux上常用的压缩方式是选用tar将许多文件打包成一个文件,再以gzip压缩为xxxx.tar.gz(或称为xxx.tgz文件).
常用参数:
-c : 创建一个新tar文件
-v : 显示运行过程的信息
-f : 指定文件名
-z : 调用gzip压缩命令进行压缩
-t : 查看压缩文件的内容
-x : 解开tar文件
打包 :tar -cvf xxx.tar ./*
打包并且压缩 :tar -zcvf xxx.tar.gz ./*
- grep : 查找复合条件的字符串
grep lang anacoda-ks.cfg 在文件中查找lang
grep lang anaconda -ks.cfg -color 高亮显示
- rm 删除文件
- 其它常用命令
- pwd : 显示当前所在目录
- touch : 创建一个空文件
touch a.txt - ll -h : 友好显示文件大小
- wget : 下载资料 wget http://nginx.org/download/nginx-1.9.12.tar.gz
- Vi和Vim
- 在Linux下一班使用vi编辑器来编辑文件,vi既可以查看文件也可以编辑文件
三种模式 : 命令号,插入,底行模式
* 切换到命令行模式 : 按Esc键
* 切换到插入模式 : 按 i、o、a键
i:在当前位置首前插入
I:在当前行首插入
a:在当前位置后插入
A:在当前行尾插入
o:在当前行之后插入一行
O:在当前行之前插入一行
* 切换到底行模式:按:(冒号) - 打开文件 : vim file
- 退出 : esc -> :q
- 修改文件 : 输入i进入插入模式
- 保存并退出 : esc->:wq
- 不保存退出 : esc->q
- 3种进入插入模式:
- i:在当前的光标所在处插入
- o:在当前光标所在的下一行插入
- a:在光标所在的下一个字符插入
- 快捷键
dd - 快速删除一行
r - 替换
- 在Linux下一班使用vi编辑器来编辑文件,vi既可以查看文件也可以编辑文件
- 重定向输出>和>>
> 重定向输出,覆盖原有内容
>> 重定向输出,又追加功能
- 示例:
cat /etc/passwd > a.txt 将输出定向到a.txt中
cat /etc/passwd >> a.txt 输出并且追加
ifconfig > ifconfig.txt
- 管道
- 管道是Linux命令中重要的一个概念,其作用是将一个命令的输出用作另一个命令的输入.
- 示例
ls --help | more : 分页查询帮助信息
ps -ef | grep java 查询名称中包含java的进程
ifconfig | more
cat index.html | more
ps -ef | grep aio
- && 命令执行控制
- 命令之间使用&&连接,实现逻辑与的功能
只有在&&左边的命令返回真(命令返回值KaTeX parse error: Expected 'EOF', got '&' at position 7: ?==0),&̲&右边的命令才会被执行 只…?==1),后面的命令就不会被执行.
mkdir test &&cd test
- 命令之间使用&&连接,实现逻辑与的功能
- 网络通讯命令
- ifconfig 显示或设置网路设备
ifconfig 显示网路设备
ifconfig eth0 up 启用eth0网卡
ifconfig eth0 down 停用eth0网卡 - ping 探测网路是否通畅
ping 192.168.0.1 - netstat 查看网络端口
netstat -an | grep 3306 查询3306端口占用情况
- ifconfig 显示或设置网路设备
- 系统管理命令
- date 显示或设置系统时间
date 显示当前系统时间
date -s “2020-01-01 10:10:10“ 设置系统时间 - df 显示磁盘信息
df -h 友好显示大小 - free 显示内存状态
free -m 以mb单位显示内存 - top 显示,管理执行中的程序
- clear 清屏幕
- ps 正在运行的某个进程的状态
ps -ef 查看所有进程
ps -ef | grep ssh 查找某一进程 - kill 杀掉某一进程
kill 2868 杀掉2868编号的进程
kill -f 2868 强制杀死进程 - du 显示目录或文件的大小
du -h 显示当前目录的大小 - who 显示目前登入系统的用户信息
- hostname 查看当前主机名
修改 : vi 、etc/sysconfig/network - uname 显示系统信息
uname -a 显示本机详细信息。
依次为 : 内核名称(类别),主机名,内核版本号,内核编译日期,硬件名,处理器类型,硬件平台类型,操作系统名称.
- date 显示或设置系统时间
Linux的用户和组
- 用户管理
-
useradd 添加一个用户
useradd test 添加test用户
useradd test -d /home/t1指定用户home目录 -
passwd 设置、修改密码
passwd test 为test用户设置密码 -
切换登录
ssh -l test -p 22 192.168.19.128 -
su -用户名
-
userdel 删除一个用户
userdel test 删除test用户(不会删除home目录)
userdel -r test 删除用户以及home目录
-
- 组管理
- 当在创建一个新用户user时,若没有指定他所属于的组,就建立一个和该用户同名的私有组
- 创建用户时也可以指定所在组
- groupadd 创建组
groupadd public 创建一个名为public的组
useradd u1 -g public 创建用户指定组 - groupdel 删除组,如果该组有用户成员,必须先删除用户才能删除组
groupdel public
- id ,su 命令
- id命令
功能 : 查看一个用户的uid和gid - su 命令
功能:切换用户
示例:
su u1 切换到u1用户
su - u1 切换到u1用户,并且将环境也切换到u1用户的环境 - 账号文件
/etc/passwd 用户文件
/etc/shadow 密码文件
/etc/group 组信息文件 - 用户文件
root❌0:0:root:/root:/bin/bash
账号名称: 在系统中是唯一的
用户密码: 此字段存放加密口令
用户标识码(User ID): 系统内部用它来标示用户
组标识码(Group ID): 系统内部用它来标识用户属性
用户相关信息: 例如用户全名等
用户目录: 用户登录系统后所进入的目录
用户环境: 用户工作的环境 - 密码文件
shadow文件中每条记录用冒号间隔的9个字段组成.
用户名:用户登录到系统时使用的名字,而且是惟一的
口令: 存放加密的口令
最后一次修改时间: 标识从某一时刻起到用户最后一次修改时间
最大时间间隔: 口令保持有效的最大天数,即多少天后必须修改口令
最小时间间隔: 再次修改口令之间的最小天数
警告时间:从系统开始警告到口令正式失效的天数
不活动时间: 口令过期少天后,该账号被禁用
失效时间:指示口令失效的绝对天数(从1970年1月1日开始计算)
标志:未使用 - 组文件
root❌0:
组名:用户所属组
组口令:一般不用
GID:组ID
用户列表:属于该组的所有用户
- id命令
Linux的权限命令
- Linux三种文件类型
- 普通文件 : 包含文本文件,数据文件,可执行的二进制程序文件等
- 目录文件 : Linux系统把目录看成是一种特殊的文件,利用它构成文件系统的树型结构
- 设备文件 : Linux系统把每一个设备看成是一个文件
- 文件类型标识
普通文件(-)
目录(d)
符号链接(l)
进入etc可以查看,相当于快捷方式
字符设备文件(c)
块设备文件(s)
套接字(s)
命名管道(p) - 文件权限管理
- chmod 变更文件或目录的权限。
chmod 755 a.txt
chmod u=rwx,g=rx,o=rx a.txt
chmod 000 a.txt / chmod 777 a.txt chown 变更文件或目录改文件所属用户和组
chown u1:public a.txt :变更当前的目录或文件的所属用户和组
chown -R u1:public dir :变更目录中的所有的子目录及文件的所属用户和组
- chmod 变更文件或目录的权限。