文章目录
python从linux基础命令到放弃
声明
没整理。当时想学python地。在b站看的视频。一共600集。前100集讲linux命令。然后就只看了前100集。
2020/2/10
操作系统
没有安装操作系统的计算机,通常被称为裸机。
操作系统的作用
- 直接控制各个硬件(CPU,内存,硬盘,声卡)进行工作
- 把操作硬件的方法封装成一个个系统调用,供其他成员通过系统调用间接对硬件进行操作
例子:
播放音乐
- 将歌曲文件从硬盘加载到内存
- 使用声卡对音频数据进行解码
- 将解码后的数据发送给音箱
通过系统调用
桌面操作系统
-
windows
-
软件多,方便
-
安全性稳定性不太好
-
用一段时间卡。==》重启一下
-
用户群体大
-
-
macOS
-
适合于开发人员(据说用mac开发非常好的开发体验)
-
安全性稳定性远远高于Windows?(弹幕很反对的样子
-
基于unix
-
-
linux
- 应用软件少
服务器操作系统(对服务器进行维护和管理)
- linux
- 安全,稳定,免费,
- 在服务器提供的相关配套软件比Windows serve 齐全很多
- 市场占有率高
- windows serve
- 付费
- 占有率低
机房一般温度低,噪音大。
远程登陆服务器,对服务器进行管理
嵌入式操作系统(智能硬件智能机器人智能家居的开发)
- linux
- 内核小
- 开源
移动设备操作系统
- IOS
- Android(基于Linux)
虚拟机
通过软件模拟的具有完整硬件系统功能的运行在一个完全隔离环境中的完整计算机系统
操作系统的发展史
linus经常用他的终端仿真器去访问大学主机上的新闻和邮件,为了方便你读写和下载文件,他自己编写了磁盘驱动程序和文件系统,这些在后来成为了linux第一个内核的雏形。
linus利用GNU的bash当作开发环境,gcc当作编译工具,编写了linux内核,一开始linux并不能兼容unix
即unix上跑的程序不能在linux上跑,即应用程序与内核之间的接口不一致
一开始linux只适用于386,后来经过全世界的网友的帮助,能够兼容多种硬件
linux内核及发行版本
内核版本
- 内核是系统的心脏,是运行程序和管理像磁盘和打印机等硬件设备的核心程序,它提供了一个在裸设备与应用程序间的抽象层
- linux内核版本又分为稳定版和开发版
发行版本
-
linux发行版(也被叫做GNU/Linux发行版)通常包含了包括桌面环境,办公套件,媒体播放器,数据库等应用软件
-
常见的发行版本
- Ubuntu
- Redhat
- fedora
- openSUSE
- Linux Mint
- Debian
- Manjaro
- Magela
- CentOS
- Arch
linux主要目录
- /:根目录,一般根目录只存放目录
- /bin、/usr/bin: 可执行二进制文件的目录,如常用的命令ls 、tar、mv、cat等
- /etc:系统配置文件存放的目录,不建议在此目录下存放可执行文件
2020/2/11
常用linux命令的基本使用
01.学习linux终端命令的原因
- linux刚面世时并没有图形界面,所有的操作全靠命令完成,如磁盘操作、文件存取、目录操作、进程管理、文件权限 设定等。
- 在职场中,大量的服务器维护工作都是在远程通过SSH客户端来完成的,并没有图形界面,所有的维护工作都要通过命令来完成
- linux发行版本的命令大概有200多个,常用的只有10多个而已
不常用的要用到时,临时查就行了
02.常用linux命令的基本使用
序号 | 命令 | 对应英文 | 作用 |
---|---|---|---|
01 | ls | list | 查看当前文件夹的内容 |
02 | pwd | print work directory | 查看当前所在文件夹 |
03 | cd[目录名] | change directory | 切换文件夹 |
04 | touch[文件名] | touch | 如果文件不存在,新建文件 |
05 | mkdir[目录名] | make directory | 创建目录 |
06 | rm[文件名] | remove | 删除指定的文件名 |
07 | clear | clear | 清屏 |
小技巧:
ctrl+shift+= :放大终端字体(shift+=是+)
ctrl±:缩小字体
linux终端命令格式
command [-options] [parameter]
说明:
- command:命令名,相应功能的英文单词或单词的缩写
- [-options] : 选项,可用来对命令进行控制,也可以省略
- [parameter] :传给命令的参数,可以是0个、1个或者多个
[]代表可选,即可有可无
查阅命令帮助信息
-
command --help
如:ls --help
显示命令的帮助信息
-
man command
查阅命令的使用手册
man是manual的缩写,是linux提供的一个手册,包括了绝大部分的命令、函数的详细使用说明
使用man的操作键
操作键 功能 空格键 显示手册页的下一屏 Enter键 一次滚动手册页的一行 b—back 回滚一屏 f 前滚一屏 q 退出 /word 搜索word字符串
1.1终端使用技巧
1.自动补全
- 在敲出
文件
/目录
/命令
的前几个字母之后,按下tab
键- 如果输入的没有歧义,系统会自动补全
- 如果还存在其他
文件
/目录
/命令
,再按一下tab
键
2.曾经使用过的命令
- 按
上
/下
光标键可以在曾经使用过过的命令之前来回切换 - 如果想要退出选择,并且不想执行当前选中的命令,可以按
ctrl +c
1.2 ls命令说明
ls
是英文单词list的简写,其功能为列出目录的内容,是用户最常用的命令之一,类似于DOS下的dir
命令
linux下文件和目录的特点
- linux 文件 或者 目录 名称最长可以有
256
个字符 - 以
.
开头的文件为隐藏文件,需要用 -a 参数才能显示 - .表示当前目录
- …表示上一级目录
1.3 ls常用选项
可以 ls -alh
没有顺序要求
参数 | 含义 |
---|---|
-a | 显示指定目录下所有子目录与文件,包括隐藏文件 |
-l | 以列表方式显示文件的详细信息 |
-h | 配合 -l 以人性化的方式显示文件大小 |
-h
单独使用没有用途,必须配合-l
使用
文件夹默认以蓝色显示,文件默认以白色显示
-l
纵向显示目录,第一列为字母d的是文件夹,第一列为-的是文件
.com/
隐藏文件,文件夹用来配置我们安装的应用软件。保存我们安装的软件的配置内容?日常使用不需要改动隐藏文件
1.4 ls通配符的使用
通配符 | 含义 |
---|---|
* | 代表任意个数个字符,也可以是没有字符 |
? | 代表任意一个字符, |
[abc] | 匹配a、b、c中的任意一个 |
[a-f] | 匹配a到f范围内的任意一个字符 |
2.1 cd
- cd 是英文单词 change directory 的简写, 其功能为更改当前的工作目录
注意:Linux所有的 目录 和文件名都是大小写敏感的
命令 | 含义 |
---|---|
cd | 切换到当前用户的主目录(/home/用户目录) |
cd ~ | 切换到当前用户的主目录(/home/用户目录) |
cd . | 保持在当前目录不变 |
cd … | 切换到上级目录 |
cd - | 可以在最近两次工作目录之间来回切换 |
2.2 相对路径和绝对路径
- 相对路径 在输入路径时,最前面不是 / 或者 ~,表示相对 当前目录 所在的目录位置
- 绝对路径 在输入路径时,最前面是**/或者~**,表示从根目录/家目录 开始的具体目录位置
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Q1U0euLz-1586912906857)(C:\Users\lenovo\Desktop\截图\批注 2020-02-11 164901.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-wkHghpnt-1586912906861)(C:\Users\lenovo\Desktop\截图\批注 2020-02-11 170146.png)]
3.1 touch
- 创建文件或修改文件时间
- 如果文件 不存在,可以创建一个空白文件
- 如果文件 已经存在, 可以修改文件的末次修改日期
3.2 mkdir
- 创建一个新的目录
选项 | 含义 |
---|---|
-p | 可以递创建目录 |
新建目录的名称 不能和当前目录中 已有的目录或文件 同名
3.3 rm
- 删除文件或目录
使用 rm
命令要小心,因为文件删除后不能恢复
参数 | 含义 |
---|---|
-f | 强制删除,忽略不存在的文件,无需提示 |
-r |
2020/2/12
联网
发现没有tree,然后又发现没联网。反正把wifi设置为共享的,然后虚拟机的网络适配设置为自定义vment 08?就可以了。蛮顺利的。
是的。我又重新照着做了一次。又可以了。
不是所有型号的无线网卡都能通过"系统设置——软件和更新——附加驱动"来安装驱动,所以一直做了很多无用功
04. 拷贝和移动文件
序号 | 命令 | 对应英文 | 作用 |
---|---|---|---|
01 | tree [目录名] | tree | 以树状图列出文件目录结构 |
02 | cp 源文件 目标文件 | copy | 复制文件或者目录 |
03 | mv 源文件 目标文件 | move | 移动文件或者目录/文件或者目录重命名 |
4.1 tree
- 选项 -p:只显示目录
4.2 cp
cp
命令的功能是将给出的 文件 或者 目录 复制到另一个 文件 或 目录 中,相当于 DOS 下的copy
命令
选项 | 含义 |
---|---|
-i | 覆盖文件的提示 |
-r | 若给出的源文件是目录文件,则 cp 例如:cp -r a test 将递归复制该目录下的所有子目录和文件,目标文件必须为一个目录名 |
如果复制到了桌面的文件改了之后是被打开的状态,那么在复制一遍,再点开窗口,会提示是否覆盖,如果文件不是打开的,则会直接覆盖
4.3 mv
重命名: mv test.txt ./123.txt
mv
命令可以用来 移动 文件 或 目录 ,也可以给文件或目录重命名
选项 | 含义 |
---|---|
-i | 覆盖文件前提示 |
05.查看文件内容
序号 | 命令 | 对应英文 | 作用 |
---|---|---|---|
01 | cat 文件名 | concatenate | 查看文件内容、创建文件、文件合并、追加文件内容等功能 |
02 | more 文件名 | more | 分屏显示文件内容 |
03 | grep 搜索文本文件名 | grep | 搜索文本文件内容 |
5.1cat
cat
命令可以用来 查看文件内容 、创建文件 、 文件合并 、追加文件内容 等功能cat
会一次显示所有的内容,适合 查看内容较少 的文本文件
选项 | 含义 |
---|---|
-b --nonblank | 对非空输出行编号 |
-n --number | 对输出的所有行编号 |
Linux中还要一个 nl
命令和 cat -b
的效果等价
5.2 more
more
命令可以用于分屏显示文件内容, 每次只显示一页内容- 适合于 查看内容较多 的文本文件
使用more
的操作键:
操作键 | 功能 |
---|---|
空格键 | 显示手册页的下一屏 |
Enter键 | 一次滚动手册页的一行 |
b | 回滚一屏 |
f | 前滚一屏 |
q | 退出 |
5.3 grep
- Linux系统中
grep
命令是一种强大的文本搜索工具 grep
允许对文本文件进行 模式 查找,所谓模式查找,又被称为正则表达式
选项 | 含义 |
---|---|
-n | 显示匹配行及行号 |
-v | 显示不包含匹配文本的所有行(相当于求反) |
-i | 忽略大小写 |
如果搜索 hello python : grep -in "hello python" test.txt
- 常用的两种模式查找
参数 | 含义 |
---|---|
^a | 行首,搜索以a开头的行 |
ke$ | 行尾,搜索以ke结束的行 |
06. 其他
6.1 echo 文字内容
echo
会在终端中显示参数指定的文字,通常会和 重定向 联合使用
6.2 重定向 > 和 >>
- Linux允许将命令执行结果 重定向 到一个 文件
- 将本应显示在终端上的内容 输出/追加 到 指定文件中
其中
>
表示输出, 会覆盖文件原有的内容>>
表示追加,会将内容追加到已有文件的末尾
6.3 管道 |
例如 :ls -alh ~ | grep o
- Linux允许将 一个命令的输出 可以 通过管道 作为 另一个命令的输入
- 可以理解现实生活中的管子,管子的一头塞东西进去,另一头取出来,这里
|
的左右分为两端,左端塞东西(写),右端取东西(读)
常用的管道命令有:
more
:分屏显示内容grep
: 在命令执行结果的基础上查询指定的文本
远程管理常用命令
01. 关机/重启
序号 | 命令 | 对应英文 | 作用 |
---|---|---|---|
01 | shutdown 选项(没有选项的话默认为关机) 时间 | shutdown | 关机/重启 |
1.1 shutdown
shutdown
命令可以 安全 关闭 或者 重新启动系统
选项 | 含义 |
---|---|
-r (reboot?) | 重新启动 |
- 不指定选项 和 参数, 默认表示 1分钟 之后 关闭电脑
- 远程维护服务器时,最好不要关闭系统,而应该重新启动系统
通过ssh登录对服务器进行日常的管理。如果把电脑关机了,再开启,就非常麻烦
——————————————————————————————————————————
- 常用命令示例
#重新启动操作系统,其中 now 表示现在
shutdown -r now
#立即关机,其中 now 表示现在
shutdown now
#系统在今天的 20:25 会关机
shutdown 20:25
#系统再过十分钟后自动关机
shutdown +10
#取消之前指定的关机计划 c=cancel?
shutdown -c
2020/2/14
02.查看或配置网卡信息
序号 | 命令 | 对应英文 | 作用 |
---|---|---|---|
01 | ifconfig | configure a network interface | 查看/配置计算机当前的网卡配置信息 |
02 | ping ip 地址 | ping(乒网,向计算机发送信号等待恢复测试是否连通互联网) | 检测到目标 IP 地址的连接是否正常 |
2.1网卡和IP地址
网卡
- 网卡是一个专门负责网络通讯的硬件设备(==连接网线的硬件设备 ||无线网卡 —WIFI)
- IP地址 是设置在网卡上的地址信息
我们可以把 电脑 比作 电话 ,网卡 相当于 SIM 卡 ,IP地址 相当于 电话号码
评论:
- 屁,明明是mac地址
- 公网地址私网地址的概念没讲
IP地址
- 每台联网的电脑上都也有IP地址,是保证电脑之间正常通讯的重要设置
注意:每台电脑的IP地址不能相同,否则会出现IP地址冲突,并且没有办法正常通讯
提示:有关 IP 地址的详细内容,在就业班会详细讲解
2.2 ifconfig
ifconfig
可以查看/配置计算机 当前的 网卡配置 信息
# 查看网卡配置
ifconfig
# 查看网卡对应的IP地址
ifconfig | grep inet
提示:一台计算机中有可能会有一个 物理网卡 和 多个虚拟网卡,在 Linux 中物理网卡的名字通常以 ensXX
表示
127.0.0.1
被称为 本地回环/环回地址 ,一般用来测试本机网卡是否正常
2.3 ping
#检测到目标主机是否连接正常
ping IP地址
#检测本地网卡工作是否正常
ping 127.0.0.1
-
ping
一般用于检测当前计算机到目标计算机之间的网络 是否通畅,数值越大,速度越慢ping
的工作原理与潜水艇的声纳相似,ping
这个命令就是取自 声纳的声音- 网络管理员之间也常将
ping
用作动词 —— ping 一下计算机X,看他是否开着
原理:网络上的机器都有 唯一确定的IP地址, 我们给 目标IP地址 发送一个数据包,对方就要返回一个数据包,根据返回的数据包以及时间,我们可以确定目标主机的存在
*提示:在 Linux 中,想要终止一个终端程序的执行,绝大多数都可以使用
ctrl + c
03. 远程登录和复制文件
序号 | 命令 | 对应英文 | 作用 |
---|---|---|---|
01 | ssh 用户名@ip | secure shell | 关机/重新启动 |
02 | scp 用户名@ip:文件名或路径 用户名@ip:文件名或路径 | secure copy | 远程复制文件 |
3.1 ssh 基础 (重点)
在 Linux 中 SSH 是 非常常用 的工具,通过 SSH 客户端 我们可以连接到运行了 SSH 服务器 的远程机器上
SSH 的服务器 和 SSH 的客户端 都是默认安装的,只有在windows 系统下才需要单独安装 SSH 客户端
————————————————————————————
数据传输是加密的,可以防止信息泄露
数据传输是压缩的,可以提高传输速度
SSH 客户端 =============== =================================================================================> SSH 服务器
————————————————————————————
- SSH 客户端 是一种使用
Secure Shell (SSH)
协议连接到远程计算机的软件程序 SSH
是目前较可靠,专为远程登录会话和其他网络服务 提供安全性的协议- 利用
SSH 协议
可以有效防止远程管理过程中的信息泄露 - 通过
SSH 协议
可以对所有传输的数据进行加密,也能够防止 DNS 欺骗和 IP 欺骗
- 利用
SSH
的另一项优点是传输的数据可以是经过压缩的,所以可以加快传输的速度
1)域名 和 端口号
域名
- 由一串 用点分隔 的名字组成,例如:
www.itcast.cn
- 是 IP 地址 的别名,方便用户记忆
端口号
- IP 地址:通过 IP 地址 找到网络上的 计算机
- 端口号 : 通过 端口号 可以找到 计算机上运行的应用程序
- SSH 服务器 的 默认端口号是
22
,如果是默认端口号,在连接的时候,可以省略
- SSH 服务器 的 默认端口号是
- 常见服务端口号列表
序号 | 服务 | 端口号 |
---|---|---|
01 | SSH 服务器 | 22 |
02 | Web 服务器 | 80 |
03 | HTTPS | 443 |
04 | FTP服务器 | 21 |
评论:
- 域名和端口号是指DNS解析出来的,端口指系统上的端口使用
- 还有域名解析系统 把IP地址映射为http域名
用户通过IP找到服务器,再通过端口号找到服务器上安装的程序如:web服务器,由服务器上的软件提供给用户相应的服务
2020/2/15
2)SSH 客户端的简单使用
ssh [-p port] user@remote
user
是在远程机器上的用户名,如果不指定的话默认为当前用户remote
是远程机器的地址,可以是 IP/域名 ,或者是 后面会提到的别名port
是 SSH Server 监听的端口 ,如果不指定,就为默认值22
如果默认是22,就不需要-p
提示:
- 使用
exit
退出当前用户的登录
注意
ssh
这个终端命令只能在Linux
或者UNIX
系统下使用- 如果再
Windows
系统中,可以安装PuTTY
或者XShell
客户端软件即可
提示:
- 在工作中,SSH 服务器的端口号很有可能 不是22 ,如果遇到这种情况就需要使用
-p
选项,指定正确的端口号,否则无法正常连接到服务器
3) Windows 下 SSH客户端的安装
Putty
XShell
评论:
- 用win10自带的powershell(win+x呼出)
IP是否被墙
http://vultr.idcspy.com/235.html
3.2 scp(掌握)
- scp 就是
secure copy
,是一个在Linux下用来进行 远程拷贝文件 的命令 - 它的 地址格式与 ssh 基本相同 ,需要注意的是,在指定端口时用的是大写的
-P
而不是小写的
#把本地当前目录下的 01.py 文件复制到远程家目录下的 Desktop/01.py
#注意:‘:’ 后面的路径如果不是绝对路径,则以用户的家目录作为参照路径
scp -P port 01.py user@remote:Desktop/0.1py
#把远程家目录下的 Desktop/01.py 文件复制到本地当前目录下的 01.py
scp -P port user@remote:Desktop/01.py 01.py
#加上 -r 选项可以传送文件夹
#把当前目录下的 demo 文件夹复制到远程家目录下的 Desktop
scp -r demo user@remote:Desktop
#把远程来自家目录下的 Desktop 复制到当前目录下的 demo 文件夹
scp -r user@remote:Desktop demo
选项 | 含义 |
---|---|
-r | 若给出的源文件时目录文件,则scp 将递归复制该目录下的所有子目录和文件,目标文件必须为一个目录名 |
-P | 若远程 SSH 服务器的端口不是22,需要使用大写字母 -P 选项指定端口 |
注意
scp
这个终端命令只能在Linux
或者UNIX
系统下使用- 如果在
windows
系统中,可以安装PuTTY
,使用pscp
命令行工具或者安装FileZilla
使用FTP
进行文件传输
2020/2/16
没连上网的时候 执行命令行 ifconfig | grep inet
和联网之后的结果好像不太一样。
联网之后好像就有IP了?
FileZilla
FileZilla
在传输文件时,使用的是FTP服务
而不是 SSH服务,因此端口号应该设置为21
评论:
-
xftp
-
在ubuntu输入命令sudo apt-get install vsftpd 就能使用21号端口啦
-
ftp有两个端口
-
不是22,21不行只是因为ftp没装
-
winscp也很好用
3.3 SSH 高级 (知道)
- 免密码登录
- 配置别名
提示: 有关 SSH 配置信息都保存在用户家目录下的 .ssh
(隐藏文件 -a)目录下
1) 免密码登录
步骤
- 配置公钥
- 执行
ssh-keygen
即生成 SSH 钥匙,一路回车即可
- 执行
- 上传公钥到服务器
- 执行
ssh-copy-id -p port user@remote
,可以让远程服务器记住我们的公钥
- 执行
.ssh/known_hosts : 已知的主机文件
示意图
SSH 客户端
ssh-keygen
生成两个文件 :
- id_rsa.pub 公钥–公共加密的钥匙(public)
- id_rsa 密钥 私钥–私用加密的钥匙
ssh-copy-id
把公钥给服务器
本地 使用 私钥 对数据进行加密/解密
服务器 使用 公钥 对数据进行加密/解密
因为数据都是加密过的,所以就不需要密码啦
非对称加密算法
使用 公钥 机密的数据,需要使用 私钥 解密
使用 私钥 加密的数据,需要使用 公钥 解密
评论
- 输入ssh localhost 就能创建
- windows的cmd以管理员身份运行,输入net start sshd
- 系统偏好设置-共享-远程登陆
- 连不上windows,因为没有安装ssh server
我。。怎么都不行。ssh-copy-id 搞不来。
直接复制过去好像没用。算了输密码把。。。
2) 配置别名
在 /.ssh
下新建一个 config
文件(别的名字不行)
然后在里面追加一下内容
Host ***(任意)
HostName ip地址
User 用户名
Port 22
之后 ssh ***
就可以了
评论
- windows的先百度开启ssh,然后管理员身份允许net start sshd
用户权限相关指令
目标
- 用户 和 权限 的基本概念
- 用户管理 终端命令
- 组管理 终端命令
- 修改权限 终端命令
01. 用户 和 权限 的基本概念
1.1 基本概念
- 用户 是 Linux系统工作中重要的一环,用户管理包括 用户 与 组 管理
- 在Linux系统中,不论是由本机或是远程登录系统,每个系统都 必须拥有一个账号 ,并且 对于不同的系统资源拥有不同的使用权限
- 在 Linux 中,可以指定 每一个用户 针对 不同的文件或目录 的 不同权限
- 对 文件/目录 的权限包括
序号 | 权限 | 英文 | 缩写 | 数字代号 |
---|---|---|---|---|
01 | 读(可读 | read | r | 4 |
02 | 写(可写 | write | w | 2 |
03 | 执行 | execute | x | 1 |
1.2 组
- 为了方便用户管理,提出了 组 的概念
- 在实际应用中,可以预先针对 组 设置好权限,然后 将不同的用户添加到对应的组中, 从而 不用依次为每一个用户设置权限
1.3 ls -l 拓展
ls -l
命令行:
如果是文件,第一列是 -
如果是目录 ,第一列是 d
紧接着是 三组 rwx | rwx| r-x
目录 | 第一组rwx | 第二组rwx | 第三组rwx |
---|---|---|---|
-/d | 文件的拥有者(用户的权限 | 文件的组(组的权限 | 其他用户 |
ls -l
可以查看文件夹下文件的详细信息,从左到右依次是:- 权限 ,第1个字符如果是
d
表示目录 - 硬链接数 通俗的讲,就是有多少种方式,可以访问到当前目录/文件
- 拥有者 在家目录下 文件/目录 的拥有者通常都是当前用户
- 组 在Linux中,很多时候,会出现组名和用户名相同的情况,后续会讲
- 大小
- 时间
- 名称
- 权限 ,第1个字符如果是
硬链接数:
- cd 绝对路径
- cd .
- 不同文件的 cd … 属于不同的硬链接
1.4 chmod 简单使用(重要)
chmod
可以修改 用户/组 对 文件/目录 的权限- 命令行如下:
chmod +/-rwx 文件名/目录名
评论
- sudo cat 01.py 可以查看没有rwx权限的01.py
- sudo 切换成管理员权限干啥都可以
其他
- 执行当前目录下的一个文件 :
./01.py
- 没有执行权限的01.py
python 01.py
可以允许
但是 ./01.py
会提示 bash: ./01.py:权限不够
- 而且命令行区分大小写
chmod +X 01.py
没有改变。chmod +x 01.py
才能有效更改文件权限 - 如果
./01.py
命令行运行py。需要在py文件中添加编译变量 如:#!/usr/bin/python
chmod 修改目录权限
- 目录没有可执行权限。无法切换到该目录下===cd
- 目录没有可读权限。无法
ls
该目录 - 目录没有可写权限。无法更改目录。如 新建文件
1.5 超级用户
- Linux 系统中的
root
账号通常用于 系统的维护和管理 ,对操作系统的所有资源 具有所以访问权限 - 在大多数版本的Linux中,都不推荐 直接使用root账号登录系统
- 在Linux按住安装的过程中,系统会自动创建一个用户账号,而这个默认的用户就称为“标准用户”
sudo
su
是substitute user
的缩写,表示 使用另一个用户的身份sudo
命令用来以其他身份执行命令, 预设的身份为root
- 用户使用
sudo
时,必须先输入密码,之后有 5分钟的有效期限, 超过期限则必须重新输入密码
若其未经授权的用户企图使用 sudo
,则会发出警告邮件给管理员
02. 组管理 终端命令
提示: 创建组/删除组 的终端命令都需要通过 sudo
执行
序号 | 命令 | 作用 |
---|---|---|
01 | groupadd 组名 | 添加组 |
02 | groupdel 组名 | 删除组 |
03 | cat /etc/group | 确认组信息 |
04 | chgrp -R 组名 文件/目录名 | 修改文件/目录所属组 |
提示:
-
组信息保存在
/etc/group
文件中 -
/etc
目录是专门用来保存 系统配置信息 的目录 -
在实际应用中,可以预先针对 组 设置好权限,然后 将不同的用户添加到对应的组中 ,从而 不用依次为每一个用户设置权限
2020/2/17
03.用户管理 终端命令
提示: 创建用户/删除用户/修改其他用户密码 的终端命令都需要通过 sudo
执行
3.1 创建用户/设置密码/删除用户
序号 | 命令 | 作用 | 说明 |
---|---|---|---|
01 | useradd -m -g 组 新建用户名 | 添加新用户 | -m 自动建立用户家目 (m—home的缩写 -g 指定用户所在的组,否则会建立一个和用户同名的组 (g—group的缩写 |
02 | passwd 用户名 | 设置用户密码 | 如果是普通用户,直接用passwd可以修改自己的账号密码 |
03 | userdel -r 用户名 | 删除用户 | -r 选项会自动删除用户家目录 |
04 | cat /etc/passwd |grep 用户名 | 确认用户信息 | 新建用户后,用户信息会保存在 /etc/passwd 文件中 |
提示:
- 创建用户时,如果忘记添加
-m
选项指定新用户的家目录 —— 最简单的方法就是 删除用户,重新创建 - 创建用户时,默认会创建一个和 用户名 同名的 组名 (如果
-g dev
就不会创建lisi
用户名的组) - 用户信息保存在
/etc/passwd
文件中
3.2 查看用户信息
序号 | 命令 | 作用 |
---|---|---|
01 | id [用户名] | (id查看当前)查看用户 UID 和 GID 信息 |
02 | who | 查看当前所有登录的用户列表 |
03 | whoami | 查看当前登录用户的账号名 |
passwd文件
/etc/passwd
文件存放的是用户的信息,由6个分号组成的7个信息,分别是
- 用户名
- 密码(x,表示加密的密码
- UID(用户标识/代号
- GID(组标识/代号
- 用户全名或本地账号
- 家目录
- 登录使用的shell,就是登录之后,使用的终端命令,
ubuntu
默认是dash
只有:
改了/bin/bash
之后就显示/bin/bash
将一个用户放到不同组里,那么这个用户拥有不同组的权限。
usermod
usermod
可以用来设置 用户 的 主组/附加组 和 登录shell,命令格式如下- 主组 :通常在新建用户时指定,在
/etc/passwd
的第4列 GID 对用的组 - 附加组 : 在
/etc/group
中最后一列表示该组的用户列表,用于指定 用户的附加权限
| 提示:设置了用户的附加组之后,需要重新登录才能生效
其实好像用usermod 的选项都要重新登录才能生效
# 修改用户的主组(passwd 中的 GID)
usermod -g 组 用户名
# 修改用户的附加组
usermod -G 组 用户名
#修改用户登录 Shell
usermod -s /bin/bash(与上面的dash不同
注意:默认使用 useradd
添加的用户是没有权限使用 sudo
以 root
身份执行命令的,可以使用以下命令,将用户添加到 sudo
附加组掌
usermod -G sudo 用户名
shell —一个软件。终端窗口
which(重要)
提示
/etc/passwd
是用于保存用户信息的文件 ==这是一个文本文件/usr/bin/passwd
是用于修改用户密码的程序 ==这是程序
rws
===s权限,平时极少用到,先把它看成 x(可执行
权限
which
命令可以查看执行命令所在位置,例如:
which ls
# 输出
# /bin/ls
which useradd
# 输出
# /usr/sbin/useradd
bin和sbin
- 在
linux
中,绝大多数可执行文件都是保存在/bin
,/sbin
,/usr/bin
,/usr/sbin
/bin
(binary
)是二进制执行文件目录,主要用于具体应用/sbin
(system binary
) 是系统管理员专用的二进制代码存放目录,主要用于系统管理/usr/bin
(user commands for applications
)后期安装的一些软件/usr/sbin
(super user commands for applications
)超级用户的一些管理程序
3.3 切换用户
序号 | 命令 | 作用 | 说明 |
---|---|---|---|
01 | su - 用户名 | 切换用户,并且切换目录 | - 可以切换到用户家目录,没有 - 位置保持不变 |
02 | exit | 对出当前登录账户 |
su
不接用户名,可以切换到root
,但是不推荐使用,因为不安全
评论
- 第一次切换到root账号需要先设置root账号密码
- 修改root密码:sudo passwd root
04.修改文件权限
序号 | 命令 | 作用 |
---|---|---|
01 | chown | 修改拥有者 |
02 | chgrp | 修改组 |
03 | chmod | 修改权限 |
- 命令格式如下:
# 递归修改文件|目录的拥有者
chown [-R] 用户名 文件名|目录名
/需要sudo
# 递归修改文件|目录的组
chgrp -R 组名 文件名|目录名
/需要sudo
# 递归修改文件权限
chmod -R 775 文件名|目录名
/不需要sudo
chmod
在设置权限时,可以简单地使用三个数字分别对应 拥有者/组 和 其他用户 的权限
# 直接修改文件|目录 的 读|写|执行 权限,但是不能精确到 拥有者|组|其他
chmod +/-rwx 文件名|目录名 /不需要sudo
拥 | 有 | 者 | 组 | 其他 | ||||
---|---|---|---|---|---|---|---|---|
r | w | x | r | w | x | r | w | x |
4 | 2 | 1 | 4 | 2 | 1 | 4 | 2 | 1 |
- 常见数字组合有(
u
表示用户/g
表示组/o
表示其他):777
===>u=rwx,g=rwx,o=rwx1
755
===>u=rwx,g=r-x,o=r-x
644
===>u=rw,g=r--,o=r--
chmod 演练目标
- 将
01.py
的权限修改为u=rwx,g=rx,o=r
- 将
123.txt
的权限修改为u=rw,g=r,o=-
- 将
test
目录以及目录下的 所有 文件权限修改为u=rwx,g=rwx,o=rx
2020/2/18
系统信息相关命令
- 本节内容主要是为了方便通过远程终端维护服务器时,查看服务器上当前 系统日期和时间/磁盘空间占用情况/程序执行占用情况
- 本小节学习的终端命令基本都是查询命令,通过这些命令对系统资源的使用情况有个了解
目标
- 时间和日期
date
cal
- 磁盘和目录空间
df
du
- 进程信息
ps
top
kill
01.时间和日期
序号 | 命令 | 作用 |
---|---|---|
01 | date | 查看系统时间 |
02 | cal | calendar 查看日历,-y 选项可以查看一年的日历 |
02.磁盘信息
序号 | 命令 | 作用 |
---|---|---|
01 | df -h | disk free 显示磁盘剩余时间 |
02 | du -h [目录名] | disk usage 显示目录下的文件大小 |
- 选项说明
参数 | 含义 |
---|---|
-h | 以人性化的方式显示文件大小 |
03.进程信息
- 所谓 进程 ,通俗地说就是 当前正在执行的一个程序
序号 | 命令 | 作用 |
---|---|---|
01 | ps aux | process status 查看进程的详细状况 |
02 | top | 动态显示运行中的进程并且排序 |
03 | kill [-9] 进程代号 | 终止指定代号的进程,-9表示强行终止 |
ps
默认只会显示当前用户通过终端启动的应用程序
PID:进程代号
ps
选项说明功能
选项 | 含义 |
---|---|
a | 显示终端上的所有进程,包括其他用户的进程 |
u | 显示进程的详细状态 |
x | 显示没有控制终端的进程 |
提示:使用 kill
命令是,最好只终止当前用户开启的进程,而不要终止 root
身份开启的进程,否则可能导致系统崩溃
- 退出
top
可以直接输入q
kill
杀不死进程就kill -9
其他命令
目标
-
查找文件
-
find
-
软链接
ln
-
打包和压缩
tar
-
软件安装
apt-get
01.查找文件
find
命令功能非常强大,通常用来在 特定的目录下 搜索 符合条件的文件
序号 | 命令 | 作用 |
---|---|---|
01 | find [路径] -name “*.py” | 查找指定路径下扩展名是.py的文件,包括子目录 |
- 如果省略路径,表示在当前文件夹下查找
- 之前学习的通配符,在使用
find
命令时同时可用 - 有关
find
的高级使用,在就业班会讲
演练目标
- 1.搜索桌面目录下,文件名包含 1 的文件
find -name "*1*"
- 2.搜索桌面目录下,所有以
.txt
为扩展名的文件
find -name "*.txt"
- 3.搜索桌面目录下,以数字
1
开头的文件
find -name "1*"
02.软链接
序号 | 命令 | 作用 |
---|---|---|
01 | ln -s 被链接的源文件 链接文件 | 建立文件的软链接,用通俗的方式 类似于windows下的快捷方式 |
-
注意:
-
没有
-s
选项建立的是一个 硬链接文件(两个文件占用相同大小的硬盘空间,工作中几乎不会建立文件的硬链接
-
-
源文件要使用绝对地址 不能使用相对路径,这样可以方便移动链接文件。移动后仍然能够正常使用
硬链接简介(知道)
- 在使用
ln
创建链接时,如果没有-s
选项,会创建一个 硬链接 ,而不是软链接
文件软硬链接的示意图
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-UK1HlWUW-1586912906866)(C:\Users\lenovo\Desktop\截图\批注 2020-02-18 151222.png)]
在 Linux 中, 文件名 和 文件的数据 是分开存储的
- 提示:
- 在 Linux 中,只有文件的
硬链接数==0
才会被删除 - 使用
ls -l
可以查看一个文件的硬链接的数量 - 在日常工作中,几乎不会创建文件的硬链接(知道即可
- 在 Linux 中,只有文件的
03.打包压缩
- 打包压缩 是日常工作中备份文件的一种方式
- 在不同操作系统中,常用的打包压缩方式是不同的
windows
常用rar
mac
常用zip
linux
常用tar.gz
3.1 打包/解压
tar
是 Linux 中常用的 备份 工具,此命令可以把 一系列文件 打包到 一个大文件中 ,也可以把一个 打包的大文件恢复成一系列文件tar
的命令格式如下:
# 打包文件
tar -cvf 打包文件.tar 被打包的文件/路径(多个文件用空格
#解包文件
tar -xvf 打包文件.tar
tar
选项说明
选项 | 含义 |
---|---|
c | 生成档案文件,创建打包文件 |
x | 解开档案文件 |
v | 列出归档解档的详细过程,显示进度 |
f | 指定档案文件名称,f后面一定是.tar文件,所以必须放选项最后 |
注意: f
选项必须放在最后,其他选项顺序可以随意
tar
只负责打包,不负责压缩
3.2 压缩/解压缩
tar
与gzip
命令结合可以使用实现文件 打包和压缩tar
只负责打包文件,但不压缩- 用
gzip
压缩tar
打包后的文件,其扩展名一般用xxx.tar.gz
在 Linux
中,最常用的压缩文件格式就是 xxx.tar.gz
- 在
tar
命令中有一个选项 -z 可以调用gzip
,从而可以方便的实现压缩和解压缩的功能 - 命令格式如下:
# 压缩文件
tar -zcvf 打包文件.tar.gz 被压缩的文件/路径
#解压缩文件
tar -zxvf 打包文件.tar.gz
#解压到指定路径
tar -zxvf 打包文件.tar.gz -C 目标路径
选项 | 含义 |
---|---|
-C | 接压缩到指定目录,注意:要解压缩的目录必须存在 |
2)bzip2(two)
tar
与bzip2
命令结合可以使用实现文件 打包和压缩 (用法和gzip
一样)tar
只负责打包文件,但不压缩- 用
bzip2
压缩tar
打包后的文件,其扩展名一般用xxx.tar.bz2
- 在
tar
命令中有一个选项-j
可以调用bzip2
,从而可以方便的实现压缩和解压缩的功能 - 命令格式如下:
# 压缩文件
tar -jcvf 打包文件.tar.bz2 被压缩的文件/路径
# 解压缩文件
tar -jxvf 打包文件.tar.bz2
04.软件安装
4.1 通过 apt 安装/卸载软件
- apt 是
Advanced Packaging Tool
,是 Linux 下的一款安装包管理工具 - 可以在终端中方便地 安装/卸载/更新软件包
# 安装软件
$ sudo apt install 软件包
# 卸载软件
$ sudo apt remove 软件名
# 更新已安装的包
$ sudo apt upgrade
# 一个小火车提示
sudo apt install sl
#一个比较漂亮的查看当前进程排名的软件
sudo apt install htop
4.2 配置软件源
- 如果希望在
ubuntu
中安装软件, 更加快速 ,可以通过设置 镜像源 ,选择一个访问网速更快的服务器,来提供下载/安装服务 - 提示:更换服务器后,需要一个相对比较长时间的更新过程,需要耐心等待。更新完成后,再安装软件都会从新设置的服务器下载软件了
序可以随意*
tar
只负责打包,不负责压缩
3.2 压缩/解压缩
tar
与gzip
命令结合可以使用实现文件 打包和压缩tar
只负责打包文件,但不压缩- 用
gzip
压缩tar
打包后的文件,其扩展名一般用xxx.tar.gz
在 Linux
中,最常用的压缩文件格式就是 xxx.tar.gz
- 在
tar
命令中有一个选项 -z 可以调用gzip
,从而可以方便的实现压缩和解压缩的功能 - 命令格式如下:
# 压缩文件
tar -zcvf 打包文件.tar.gz 被压缩的文件/路径
#解压缩文件
tar -zxvf 打包文件.tar.gz
#解压到指定路径
tar -zxvf 打包文件.tar.gz -C 目标路径
选项 | 含义 |
---|---|
-C | 接压缩到指定目录,注意:要解压缩的目录必须存在 |
2)bzip2(two)
tar
与bzip2
命令结合可以使用实现文件 打包和压缩 (用法和gzip
一样)tar
只负责打包文件,但不压缩- 用
bzip2
压缩tar
打包后的文件,其扩展名一般用xxx.tar.bz2
- 在
tar
命令中有一个选项-j
可以调用bzip2
,从而可以方便的实现压缩和解压缩的功能 - 命令格式如下:
# 压缩文件
tar -jcvf 打包文件.tar.bz2 被压缩的文件/路径
# 解压缩文件
tar -jxvf 打包文件.tar.bz2
04.软件安装
4.1 通过 apt 安装/卸载软件
- apt 是
Advanced Packaging Tool
,是 Linux 下的一款安装包管理工具 - 可以在终端中方便地 安装/卸载/更新软件包
# 安装软件
$ sudo apt install 软件包
# 卸载软件
$ sudo apt remove 软件名
# 更新已安装的包
$ sudo apt upgrade
# 一个小火车提示
sudo apt install sl
#一个比较漂亮的查看当前进程排名的软件
sudo apt install htop
4.2 配置软件源
- 如果希望在
ubuntu
中安装软件, 更加快速 ,可以通过设置 镜像源 ,选择一个访问网速更快的服务器,来提供下载/安装服务 - 提示:更换服务器后,需要一个相对比较长时间的更新过程,需要耐心等待。更新完成后,再安装软件都会从新设置的服务器下载软件了
所谓镜像源,就是所有服务器的内容都是相同的(镜像),但是根据所在位置不同,国内服务器通常速度会更快一些!