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

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 [email protected]:/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软件操作的相关命令

你可能感兴趣的:(Linux:基础)