自己以前整理的笔记,不太完整,后续会不断更新。。。。
- [ ] 补全Linux常用命令,如末行模式下的命令、保存相关的命令
- [ ]
常用命令
多个命令之间加;
可实现顺序执行多个命令
命令 | 含义 | 可选项 |
---|---|---|
cd(change directory) | 改变当前路径 | cd ~ 回到当前用户的主目录(/home/用户目录)<br />cd - 进入上次所在目录 |
ls(list) | 当前目录下的文件列表 | -a 显示指定目录下的所有子目录与文件,包括隐藏文件<br />-l 以列表方式显示文件的详细信息<br />-h配合-l以人性化方式显示文件大小 |
pwd(print work directory) | 查看当前路径 | |
touch | 创建文件 | |
mkdir(make directory) | 创建目录 | mkdir -p a/b/c 创建递归目录 |
clear | 清屏 | |
man(manual)command
|
命令的解释文档 | |
rm | 删除 | -i 以交互方式执行<br />-f 强制删除,无序提示<br />-r 递归地删除目录下的内容,删除文件夹时必须加此参数 |
cp | 复制 | -a 复制目录时使用<br />-f 已经存在的目标文件不提示<br />-i 交互式复制,覆盖同名文件前提示<br />-r 递归复制文件下的所有子目录和文件<br />-v 显示复制进度 |
mv | 移动+重命名 | -f 禁止交互式操作,覆盖不给提示<br />-i 交互式操作,同名需确认<br />-v 显示移动进度 |
tree | 查看当前目录下的文件树 | |
cat | 查看或合并文件内容 | 结合>对文件内容进行合并 |
> 和>> | 重定向 | |
grep | 对文本文件进行模式查找 | <br />结合正则表达式匹配文件内容<br />-v 显示不包含匹配文本的所有行<br />-n 显示匹配行及行号<br />-i 忽略大小写 |
which command
|
查看命令位置 | |
chmod | 修改文件权限 |
ls -lh 获得文件详细信息解释:
文件存取控制参考chmod
与DOS下的文件操作类似,在Unix/Linux系统中,也同样允许使用特殊字符来同时引用多个文件名,这些特殊字符被称为通配符
通配符 | 含义 |
---|---|
* | 文件代表文件名中所有字符 |
ls te* | 查找以te开头的文件 |
ls *html | 查找结尾为html的文件 |
? | 代表文件名中任意一个字符 |
ls ?.c | 只找第一个字符任意,后缀为.c的文件 |
ls a.? | 只找只有3个字符,前2字符为a.,最后一个字符任意的文件 |
[] | [”和“]”将字符组括起来,表示可以匹配字符组中的任意一个。“-”用于表示字符范围。 |
[abc] | 匹配a、b、c中的任意一个 |
[a-f] | 匹配从a到f范围内的的任意一个字符 |
ls [a-f]* | 找到从a到f范围内的的任意一个字符开头的文件 |
ls a-f | 查找文件名为a-f的文件,当“-”处于方括号之外失去通配符的作用 |
\ | 如果要使通配符作为普通字符使用,可以在其前面加上转义字符。“?”和“*”处于方括号内时不用使用转义字符就失去通配符的作用。 |
ls *a | 查找文件名为*a的文件 |
重定向
将命令执行结果重定向到一个文件,并将本来应显示在终端上的内容保存在文件中
如:ls > test.txt
( test.txt 如果不存在,则创建,存在则覆盖其内容 )
>输出重定向会覆盖原来的内容,>>输出重定向则会追加到文件的尾部
分屏显示
more 文件名
当文件内容太长时,可实现分页查看文件内容,空格:下一页,enter:下一行,f:下一页,b:上一页
管道:|
管道:一个命令的输出可以通过管道做为另一个命令的输入
如:ls -alh | more
软链接、硬链接
软链接:软链接不占用磁盘空间,源文件删除则软链接失效
格式:ln -s 源文件名 软链接名
硬链接:硬链接只能链接普通文件,不能链接目录,两个文件占用相同大小的硬盘空间,即使删除了源文件,链接文件还是存在
格式:ln 源文件名 链接文件名
软链接的坑:
- 通过相对路径创建软链接时,注意:软链接索引时也是按照创建时的相对路径来索引的
解决方法:尽量避免使用相对路径来创建软链接,而使用绝对路径来创建
搜索
grep
grep [-选项] ‘搜索内容串’文件名
正则表达式:
参数 | 含义 |
---|---|
^a | 行首,搜寻以 a 开头的行;grep -n '^a' 1.txt |
ke$ | 行尾,搜寻以 ke 结束的行;grep -n 'ke$' 1.txt |
[Ss]igna[Ll] | 匹配 [] 里中一系列字符中的一个;搜寻匹配单词signal、signaL、Signal、SignaL的行;grep -n '[Ss]igna[Ll]' 1.txt |
find
搜索目录和文件,名称搜索可采用通配符
命令 | 含义 |
---|---|
find ./ -name test.sh | 查找当前目录下所有 名为test.sh的文件 |
find ./ -name '*.sh' | 查找当前目录下所有后缀为.sh的文件 |
find ./ -name "[A-Z]*" | 查找当前目录下所有以大写字母开头的文件 |
find /tmp -size 2M | 查找在/tmp 目录下等于2M的文件 |
find /tmp -size +2M | 查找在/tmp 目录下大于2M的文件 |
find /tmp -size -2M | 查找在/tmp 目录下小于2M的文件 |
find ./ -size +4k -size -5M | 查找当前目录下大于4k,小于5M的文件 |
find ./ -perm 777 | 查找当前目录下权限为 777 的文件或目录 |
打包压缩解压拆包
1.tar 归档管理
此命令可以把一系列文件归档到一个大文件中,也可以把档案文件解开以恢复数据
格式:tar [参数] 打包后文件名 文件
参数 | 含义 |
---|---|
-c | 生成档案文件,创建打包文件 |
-v | 列出归档解档的详细过程,显示进度 |
-f | 指定档案文件名称,f后面一定是.tar文件,所以必须放选项最后 |
-t | 列出档案中包含的文件 |
-x | 解开档案文件 |
注意:除了f需要放在参数的最后,其它参数的顺序任意
2.gzip 文件压缩解压
tar只负责打包文件,但不压缩,用gzip压缩tar打包后的文件,其扩展名一般用xxxx.tar.gz
格式:gzip [选项] 被压缩文件
选项 | 含义 |
---|---|
-d | 解压 |
-r | 压缩所有子目录 |
完整过程:
1.打包:tar -cvf test.tar *.txt
2.压缩:gzip -r test.tar
3.解压:gzip -d test.tar.gz
4.拆包:tar -xvf test.tar
tar这个命令并没有压缩的功能,它只是一个打包的命令,但是在tar命令中增加一个选项(-z)可以调用gzip实现了一个压缩的功能,实行一个先打包后压缩的过程
合并过程:
打包压缩:tar -zcvf xxx.tar.gz *.txt
解压拆包:tar -zxvf xxx.tar.gz -C xx
-C 后跟解压到指定的目录
另外一种压缩方式bzip2:
打包压缩:tar -jcvf xxx.tar.bz2 *.txt
解压拆包:tar -jxvf xxx.tar.bz2 -C xx
另一种压缩解压方式zip:
通过zip压缩文件的目标文件不需要指定扩展名,默认扩展名为zip
压缩文件:zip [-r] 目标文件(没有扩展名) 源文件
解压文件:unzip -d 解压后目录文件 压缩文件
改变权限
chmod 修改文件权限有两种使用格式:字母法与数字法
字母法:
格式:chmod u/g/o/a +/-/= rwx 文件
[ u/g/o/a ] | 含义 |
---|---|
u | user 表示该文件的所有者 |
g | group 表示与该文件的所有者属于同一组( group )者,即用户组 |
o | other 表示其他以外的人 |
a | all 表示这三者皆是 |
[ +-= ] | 含义 |
---|---|
+ | 增加权限 |
- | 撤销权限 |
= | 设定权限 |
rwx | 含义 |
---|---|
r | read 表示可读取,对于一个目录,如果没有r权限,那么就意味着不能通过ls查看这个目录的内容。 |
w | write 表示可写入,对于一个目录,如果没有w权限,那么就意味着不能在目录下创建新的文件。 |
x | excute 表示可执行,对于一个目录,如果没有x权限,那么就意味着不能通过cd进入这个目录。 |
同时设置多个用户的访问权限:
chmod u=rw,g=x,o=r 1.py
chmod u=,g=,o= 1.py
# 无权限
数字法:
“rwx” 这些权限也可以用数字来代替
字母 | 说明 |
---|---|
r | 读取权限,数字代号为 "4" |
w | 写入权限,数字代号为 "2" |
x | 执行权限,数字代号为 "1" |
- | 不具任何权限,数字代号为 "0" |
如执行:chmod u=rwx,g=rx,o=r filename
就等同于:chmod u=7,g=5,o=4 filename
等同于:chmod 751 filename
**注意:如果想递归所有目录加上相同权限,需要加上参数“ -R ” **
如:chmod 777 test/ -R
递归 test 目录下所有文件加 777 权限
软链接的权限无法修改,对软链接的权限修改会体现在源文件或硬链接的权限上
管理员操作
1.进入到root账户:sudo -s
2.某个命令以root权限运行:sudo 命令
3.设置用户密码:passwd 用户名 (用户名省略则修改当前用户密码)
4.exit:- 退出终端 - ssh远程登录,退出登录账号 - 切换账号登录,退出并返回上个登录账号
5.who:查看当前所有登录系统的用户信息
选项 | 含义 |
---|---|
-q或--count | 只显示用户的登录账号和登录用户的数量 |
-u或--heading | 显示列标题 |
6.关机重启
命令 | 含义 |
---|---|
reboot | 重新启动操作系统 |
shutdown –r now | 重新启动操作系统,shutdown会给别的用户提示 |
shutdown -h now | 立刻关机,其中now相当于时间为0的状态 |
shutdown -h 20:25 | 系统在今天的20:25 会关机 |
shutdown -h +10 | 系统再过十分钟后自动关机 |
更新及备份Ubuntu默认源地址
备份:sudo cp /etc/apt/sources.list /etc/apt/sources.list.backup
更新:
- 复制:https://mirrors.tuna.tsinghua.edu.cn/help/ubuntu/
- 更新源:
sudo apt-get update
Ubuntu进程查看
top:动态显示当前进程
htop:人性化显示当前进程
ps:部分显示 / ps -aux | grep 'xxx' 全部显示,并从显示的结果中搜索目标字符串
Ubuntu软件操作的相关命令
软件的安装
1 安装包安装---类似于Windows中的exe文件安装方式
centos体系下:rpm格式
ubuntu体系下:deb格式
安装命令分别为:
rpm -i xxx.rpm
dpkg -i xxx.deb
查看所有安装的软件列表命令:
rpm -qa
dpkg -l
配合grep命令使用效率更高:
rpm -qa | grep python
dpkg -l | grep python
当然也可以将输出的列表分页显示:
rpm -qa | more
rpm -qa | less
软件的删除命令:
rpm -e 软件名
dpkg -r 软件名
2 软件管家---类似于Windows中的软件管家软件
centos体系下:yum
ubuntu体系下:apt-get
根据关键词搜索想要的软件:
yum search 软件名
apt-cache search 软件名
当然如果软件数量太多,也可以进行过滤:
yum search python | grep python3.7
选中一个之后就可以进行安装:
yum install xxx
apt-get install xxx
卸载方式:
yum erase xx
apt-get purge xxx
配置软件下载源
centos:
配置文件路径:/etc/yum.repos.d/CentOS-Base.repo
最好修改资源链接为国内的:
[base]
name=CentOS-$releasever - Base - 163.com
baseurl=http://mirrors.163.com/centos/releasever/os/basearch/
gpgcheck=1
gpgkey=http://mirrors.163.com/centos/RPM-GPG-KEY-CentOS-7
ubuntu:
配置文件路径:/etc/apt/sources.list
最好修改资源链接为国内的:
deb http://mirrors.163.com/ubuntu/ xenial main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ xenial-security main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ xenial-updates main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ xenial-proposed main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ xenial-backports main restricted universe multiverse
3 压缩包安装---类似于Windows中的拿到解压后的文件夹直接运行软件
下载软件的压缩包,解压后存放到特定目录下,然后设置环境变量
Linux中设置环境变量:
export xx_HOME=
export PATH=
但这种设置方式旨在当前命令行的会话中管用,一旦退出,重新登录就不管用了
这时可以在当前用户的默认工作目录下,编辑.bashrc文件
每次登录的时候,这个文件都会运行,这样每次登录就会自动执行该文件中的语句
软件的启动
只要文件有执行权限,都可以使用./filename来运行这个程序
但是当交互命令行退出,该程序就停止运行了
后台运行
nohup command >out.file 2>&1 &
1表示标准输出,2表示标准错误输出,“2>&1”表示标准输出和错误输出合并
既然是后台运行,那么在命令行输出的结果保存在哪里了:合并输出的内容写入out.file文件中
伴随系统启动的服务程序
比如安装的MySQL,它在开机时就跟随操作系统执行
在安装完MySQL之后,需要设置开机启动,通过systemctl enable mysql设置
Ubuntu中:
在/lib/systemd/system目录下会创建一个xxx.service的配置文件,里面定义了如何启动和关闭
centos中:
在/usr/lib/systemd/system目录下会创建一个xxx.service的配置文件
apt-get 常用命令
命令 | 解释 |
---|---|
sudo apt-get install package | 安装包 |
sudo apt-get remove package | 删除包 |
sudo apt-cache search package | 搜索软件包 |
sudo apt-cache show package | 获取包的相关信息,如说明、大小、版本等 |
sudo apt-get install package --reinstall | 重新安装包 |
sudo apt-get -f install | 修复安装 |
sudo apt-get remove package --purge | 删除包,包括配置文件等 |
sudo apt-get build-dep package | 安装相关的编译环境 |
sudo apt-get upgrade | 更新已安装的包 |
sudo apt-get dist-upgrade | 升级系统 |
sudo apt-cache depends package | 了解使用该包依赖那些包 |
sudo apt-cache rdepends package | 查看该包被哪些包依赖 |
sudo apt-get source package | 下载该包的源代码 |
sudo apt-get clean && sudo apt-get autoclean | 清理无用的包 |
sudo apt-get check | 检查是否有损坏的依赖 |
系统连接及文件传输
- 图形界面Linux系统文件传输
直接拖动文件到虚拟机中
- 命令行Linux系统
2-1 ftp传输文件--待验证!!!!!!!!!!!!!!!!!
FTP是file transfer protocol 文件传输协议的简称,用于网络上控制文件的双向传输
同时,它也是一个应用程序。基于不同的操作系统有不同的FTP应用程序,而所有这些应用程序都遵守同一种协议以传输文件,在不同的平台安装对应的应用程序即可实现跨平台文件传输
Ubuntu安装ftp,Windows/Mac安装FileZilla
- 安装vsftpd服务器
sudo apt-get install vsftpd
- 配置vsftpd.conf文件
sudo vi /etc/vsftpd.conf
# 不允许匿名用户登录
anonymous_enable=No
# 指定ftp上传下载目录
local_root=/home/pythonn/ftp
# 允许本机登录
local_enable=YES
# 允许vsftpd.chroot_list文件中的用户进行登录ftp服务器
chroot_list_enable=YES
chroot_list_file=/etc/vsftpd.chroot_list
# 允许上传文件到ftp服务器
write_enable=YES
- 在/etc/下创建vsftpd.chroot_list文件并将写入某个用户名到此文件中,用于登录使用
- 给用户设置密码
passwd 用户名
- 修改ftp文件夹读写权限,删除写权限
- 在ftp文件中新建一个share文件夹,此文件即为ftp客户端进行上传下载时的文件夹
- 重启ftp服务器
sudo /etc/init.d/vsftpd restart
远程连接方法:
- 命令行:
上传文件到ftp服务器:put somefile
从ftp服务器下载文件:get somefile
- ftp图形界面客户端filezillla
2-2 ssh远程连接
SSH为Secure Shell的缩写 ,SSH 为建立在应用层和传输层基础上的安全协议
SSH是目前较可靠,专为远程登录会话和其他网络服务提供安全性的协议。常用于远程登录,以及用户之间进行资料拷贝。利用SSH协议可以有效防止远程管理过程中的信息泄露问题。
使用SSH服务,需要安装相应的服务器和客户端。客户端和服务器的关系:如果,A机器想被B机器远程控制,那么,A机器需要安装SSH服务器,B机器需要安装SSH客户端
- 安装ssh服务器
sudo apt-get install openssh-server
- 远程登录
ssh 用户名@IP
ssh -p port_num user_name@ip
远程拷贝文件
scp 命令---Windows下该命令无法使用
前提是目标主机安装了openssh-server
1.将远程目标文件复制到本地
使用格式:
scp -r RemoteUserName@RemoteHostIp:RemoteFolder FolderName
操作文件夹需要-r,单个文件不需要
2.将本地文件复制到远程
使用格式:
scp -r FolderName RemoteUserName@RemoteHostIp:RemoteFolder
总结:从谁那里复制,谁放在前面
命令格式实例:scp -r itcast@192.168.1.100:/home/itcast/QQ_dir/ ./mytest/lisi
文件的复制操作也可以实现重命名和定义文件放置路径
python相关
1 安装pip
python2.x:
pip2安装:sudo apt-get install python-pip python-dev build-essential
pip2升级:sudo pip install --upgrade pip
python3.x:
pip3安装:sudo apt-get install pip3
pip3升级:sudo pip3 install --upgrade pip
其他操作:
-
pip -help
:查看pip帮助信息 -
pip -V
:查看pip版本 -
pip list
:查看已安装包 -
pip intall packageName
:安装新的python包 -
pip uninstall packageName
:卸载python包
一些问题
1 新安装Ubuntu之后安装软件可能会出现安装软件失败的情况
更新一下软件源即可,更新之前最好修改一下软件源文件,即改为国内的软件源地址
- 备份Ubuntu默认的源地址
sudo cp /etc/apt/sources.list /etc/apt/sources.list.backup
- 复制如下网站提供的内容,替换/etc/apt/sources.list中的内容
https://mirrors.tuna.tsinghua.edu.cn/help/ubuntu/
- 更新源
sudo apt-get update
- 然后可以进行Ubuntu软件操作的相关命令