Linux(基础)

自己以前整理的笔记,不太完整,后续会不断更新。。。。

  • [ ] 补全Linux常用命令,如末行模式下的命令、保存相关的命令
  • [ ] ?
常用命令 多个命令之间加可实现顺序执行多个命令
命令 含义 可选项
cd(change directory) 改变当前路径 cd ~ 回到当前用户的主目录(/home/用户目录)
cd - 进入上次所在目录
ls(list) 当前目录下的文件列表 -a 显示指定目录下的所有子目录与文件,包括隐藏文件
-l 以列表方式显示文件的详细信息
-h配合-l以人性化方式显示文件大小
pwd(print work directory) 查看当前路径
touch 创建文件
mkdir(make directory) 创建目录 mkdir -p a/b/c 创建递归目录
clear 清屏
man(manual)command 命令的解释文档
rm 删除 -i 以交互方式执行
-f 强制删除,无序提示
-r 递归地删除目录下的内容,删除文件夹时必须加此参数
cp 复制 -a 复制目录时使用
-f 已经存在的目标文件不提示
-i 交互式复制,覆盖同名文件前提示
-r 递归复制文件下的所有子目录和文件
-v 显示复制进度
mv 移动+重命名 -f 禁止交互式操作,覆盖不给提示
-i 交互式操作,同名需确认
-v 显示移动进度
tree 查看当前目录下的文件树
cat 查看或合并文件内容 结合>对文件内容进行合并
> 和>> 重定向
grep 对文本文件进行模式查找
结合正则表达式匹配文件内容
-v 显示不包含匹配文本的所有行
-n 显示匹配行及行号
-i 忽略大小写
which command 查看命令位置
chmod 修改文件权限
ls -lh 获得文件详细信息解释:
文件存取控制参考chmod
Linux(基础)
文章图片
01-linux基础-31.png 与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 检查是否有损坏的依赖
系统连接及文件传输
  1. 图形界面Linux系统文件传输
直接拖动文件到虚拟机中
  1. 命令行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中的内容
【Linux(基础)】https://mirrors.tuna.tsinghua.edu.cn/help/ubuntu/
  • 更新源
sudo apt-get update

  • 然后可以进行Ubuntu软件操作的相关命令

    推荐阅读