,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,
Linux
,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,
1. Linux 目录
- /:根目录,一般根目录下只存放目录,在Linux下有且只有一个根目录。所有的东西都是从这里开始。当你在终端里输入“/home”,你其实是在告诉电脑,先从/(根目录)开始,再进入到home目录。
- /bin、/usr/bin: 可执行二进制文件的目录,如常用的命令ls、tar、mv、cat等。
- /boot:放置linux系统启动时用到的一些文件,如Linux的内核文件:/boot/vmlinuz,系统引导管理器:/boot/grub。
- /dev:存放linux系统下的设备文件,访问该目录下某个文件,相当于访问某个设备,常用的是挂载光驱 mount /dev/cdrom /mnt。
- /etc:系统配置文件存放的目录,不建议在此目录下存放可执行文件,重要的配置文件有 /etc/inittab、/etc/fstab、/etc/init.d、/etc/X11、/etc/sysconfig、/etc/xinetd.d。
- /home:系统默认的用户家目录,新增用户账号时,用户的家目录都存放在此目录下,~表示当前用户的家目录,~edu 表示用户 edu 的家目录。
- /lib、/usr/lib、/usr/local/lib:系统使用的函数库的目录,程序在执行过程中,需要调用一些额外的参数时需要函数库的协助。
- /lost+fount:系统异常产生错误时,会将一些遗失的片段放置于此目录下。
- /mnt: /media:光盘默认挂载点,通常光盘挂载于 /mnt/cdrom 下,也不一定,可以选择任意位置进行挂载。
- /opt:给主机额外安装软件所摆放的目录。
- /proc:此目录的数据都在内存中,如系统核心,外部设备,网络状态,由于数据都存放于内存中,所以不占用磁盘空间,比较重要的目录有 /proc/cpuinfo、/proc/interrupts、/proc/dma、/proc/ioports、/proc/net/* 等。
- /root:系统管理员root的家目录。
- /sbin、/usr/sbin、/usr/local/sbin:放置系统管理员使用的可执行命令,如fdisk、shutdown、mount 等。与 /bin 不同的是,这几个目录是给系统管理员 root使用的命令,一般用户只能"查看"而不能设置和使用。
- /tmp:一般用户或正在执行的程序临时存放文件的目录,任何人都可以访问,重要数据不可放置在此目录下。
- /srv:服务启动之后需要访问的数据目录,如 www 服务需要访问的网页数据存放在 /srv/www 内。
- /usr:应用程序存放目录,/usr/bin 存放应用程序,/usr/share 存放共享数据,/usr/lib 存放不能直接运行的,却是许多程序运行所必需的一些函数库文件。/usr/local: 存放软件升级包。/usr/share/doc: 系统说明文件存放目录。/usr/share/man: 程序说明文件存放目录。
- /var:放置系统执行过程中经常变化的文件,如随时更改的日志文件 /var/log,/var/log/message:所有的登录文件存放目录,/var/spool/mail:邮件存放的目录,/var/run:程序或服务启动后,其PID存放在该目录下。
2.用户目录
位于/home/user,称之为用户工作目录或家目录,表示方式:
相对路径和绝对路径
绝对路径
从/目录开始描述的路径为绝对路径,如:
相对路径
从当前位置开始描述的路径为相对路径,如:
.和..
每个目录下都有.和..
. 表示当前目录
.. 表示上一级目录,即父目录
根目录下的.和..都表示当前目录
文件权限
文件权限就是文件的访问控制权限,即哪些用户和组群可以访问文件以及可以执行什么样的操作。
Unix/Linux系统是一个典型的多用户系统,不同的用户处于不同的地位,对文件和目录有不同的访问权限。为了保护系统的安全性,Unix/Linux系统除了对用户权限作了严格的界定外,还在用户身份认证、访问控制、传输安全、文件读写权限等方面作了周密的控制。
在 Unix/Linux中的每一个文件或目录都包含有访问权限,这些访问权限决定了谁能访问和如何访问这些文件和目录。
访问用户
通过设定权限可以从以下三种访问方式限制访问权限:
- 只允许用户自己访问(所有者) 所有者就是创建文件的用户,用户是所有用户所创建文件的所有者,用户可以允许所在的用户组能访问用户的文件。
- 允许一个预先指定的用户组中的用户访问(用户组) 用户都组合成用户组,例如,某一类或某一项目中的所有用户都能够被系统管理员归为一个用户组,一个用户能够授予所在用户组的其他成员的文件访问权限。
- 允许系统中的任何用户访问(其他用户) 用户也将自己的文件向系统内的所有用户开放,在这种情况下,系统内的所有用户都能够访问用户的目录或文件。在这种意义上,系统内的其他所有用户就是 other 用户类
3.常用基本命令:
linux的格式:command [-options] [parameter1] ...
自由主题
输出重定向命令:> 覆盖原来的内容, >> 输出重定向则会追加到文件尾部
切换工作目录: cd[~ . .. -]的类型,切换不同
自动补全:tab
绝对路径和相对路径的差距: 输入路经时,最前面的加与不加,/ ~
删除目录与文件: rmdir rm /-i /-f / -r
建立链接文件:ln
使用格式: ln ln -s
软连接:ln -s name name_sort.txt
硬链接:ln name name.hard.txt
文本搜索:grep 查找文件find,两者的区别
查看与编辑文件: cat/ gedit
创建目录/文件与显示当前路径:mkdir /touch pwd
历史命令:history
查看文件信息:ls
管道和清屏: | clear
分屏显示:help
4.归档管理:
-c--create
创建归档文件
-t--list
显示归档文件内容
-x---
恢复(释放)归档文件
-C--
保存归档文件时指定外部介质
-f--
指定归档文件的名称
-v--
显示执行过程中的详细内容
1)
创建归档文件(备份)不是压缩
tar –cvf user.tar
passwd shadow
2)查看归档文件内容(多个归档文件共存)
tar -tvf
user.tar
3)释放归档文件(需要还原系统)
tar -xtf user.tar
5.压缩
zip 批量压缩
.zip
创建压缩包 zip *
解压 unzip
*(或者指定解压文件名)
gzip
单个压缩 .gz
创建压缩文件 gzip 文件名称
解压 gzip –d
压缩文件名
解压 gunzip
压缩文件名
tar与gzip命令结合使用实现文件打包、压缩。 tar只负责打包文件,但不压缩,用gzip压缩tar打包后的文件,其扩展名一般用xxxx.tar.gz。
gzip使用格式如下:
常用选项:
选项
含义
9-d
解压
-r
压缩所有子目录
tar
-z
普通文件
例:tar
-czvf user1.tar.gz passwd shadow 解压
tar
-zxvf
user1.tar.gz
释放
计算机中的数据经常需要备份,tar是Unix/Linux中最常用的备份工具,此命令可以把一系列文件归档到一个大文件中,也可以把档案文件解开以恢复数据。
tar使用格式 tar [参数] 打包文件名 文件
tar命令很特殊,其参数前面可以使用“-”,也可以不使用。
常用参数:
参数
含义
-c
生成档案文件,创建打包文件
-v
列出归档解档的详细过程,显示进度
-f
指定档案文件名称,f后面一定是.tar文件,所以必须放选项最后
-t
列出档案中包含的文件
-x
解开档案文件
注意:除了f需要放在参数的最后,其它参数的顺序任意。
6.Linux 命令-用户管理:Linux 用户和用户组管理详解_Linux教程_Linux公社-Linux系统门户网站
7.系统管理:
查看当前日历:cal -y 2018
关机与重启:init 0/init 6
查看进程信息: ps
查看或配置网卡信息;ifconfig
终止进程:kill
测试远程主机连通性; ping www.baidu.com
8.GITHUB的安装:Linux下安装GitHub - CSDN博客
9.编辑器之神:
vi简介
vi是“Visual interface”的简称,它在Linux上的地位就仿佛Edit程序在DOS上一样。它可以执行输出、删除、查找、替换、块操作等众多文本操作,而且用户可以根据自己的需要对其进行定制。Vi不是一个排版程序,它不象Word或WPS那样可以对字体、格式、段落等其他属性进行编排,它只是一个文本编辑程序。 vi没有菜单,只有命令,且命令繁多。emacs
Vi有三种基本工作模式:
+ 命令模式
+ 文本输入模式
+ 末行模式。
任何时候,不管用户处于何种模式,只要按一下ESC键,即可使Vi进入命令模式;我们在shell环境(提示符为$)下输入启动Vi命令,进入编辑器时,也是处于该模式下。在该模式下,用户可以输入各种合法的Vi命令,用于管理自己的文档。此时从键盘上输入的任何字符都被当做编辑命令来解释,若输入的字符是合法的Vi命令,则Vi在接受用户命令之后完成相应的动作。但需注意的是,所输入的命令并不在屏幕上显示出来。若输入的字符不是Vi的合法命令,Vi会响铃报警。
文本输入模式
在命令模式下输入插入命令i、附加命令a 、打开命令o、修改命令c、取代命令r或替换命令s都可以进入文本输入模式。在该模式下,用户输入的任何字符都被Vi当做文件内容保存起来,并将其显示在屏幕上。在文本输入过程中,若想回到命令模式下,按键ESC即可。
末行模式
末行模式也称ex转义模式。在命令模式下,用户按“:”键即可进入末行模式下,此时Vi会在显示窗口的最后一行(通常也是屏幕的最后一行)显示一个“:”作为末行模式的提示符,等待用户输入命令。多数文件管理命令都是在此模式下执行的(如把编辑缓冲区的内容写到文件中等)。末行命令执行完后,Vi自动回到命令模式。例如:
则分出一个窗口编辑newfile文件。如果要从命令模式转换到编辑模式,可以键入命令a或者i;如果需要从文本模式返回,则按Esc键即可。在命令模式下输入“:”即可切换到末行模式,然后输入命令。
vim基础操作
vim是从 vi 发展出来的一个文本编辑器 。代码补完、编译及错误跳转等方便编程的功能特别丰富
进入插入模式:
i: 插入光标前一个字符
I: 插入行首
a: 插入光标后一个字符
A: 插入行未
o: 向下新开一行,插入行首
O: 向上新开一行,插入行首
进入命令模式:
ESC:从插入模式或末行模式进入命令模式
移动光标:
h: 左移
j: 下移
k: 上移
l: 右移
M: 光标移动到中间行
L: 光标移动到屏幕最后一行行首
G: 移动到指定行,行号G
w: 向后一次移动一个字
b: 向前一次移动一个字
{: 按段移动,上移
}: 按段移动,下移
Ctr-d: 向下翻半屏
Ctr-u: 向上翻半屏
Ctr-f: 向下翻一屏
Ctr-b: 向上翻一屏
gg: 光标移动文件开头
G: 光标移动到文件末尾
删除命令:
x: 删除当前光标字符,相当于 Del
X: 删除光标前一个字符,相当于 Backspace
dd: 删除光标所在行,n dd 删除指定的行数 D: 删除光标后本行所有内容,包含光标所在字符
d0: 删除光标前本行所有内容,不包含光标所在字符
dw: 删除光标开始位置的字,包含光标所在字符
撤销命令:
重复命令:
文本行移动:
复制粘贴:
yy: 复制当前行,n yy 复制 n 行
p: 在光标所在位置向下新开辟一行,粘贴
可视模式:
v: 按字符移动,选中文本
V: 按行移动,选中文本可视模式可以配合 d, y, >>, << 实现对文本块的删除,复制,左右移动 重复执行.
替换操作:
查找命令:
替换命令:
把abc全部替换成123
末行模式下,将光标所在行的abc替换成123
:%s/abc/123/g
末行模式下,将第一行至第10行之间的abc替换成123
:1, 10s/abc/123/g
vim里执行 shell 下命令:
末行模式里输入!,后面跟命令1
Ubuntu软件操作的相关命令
sudo apt-get update 更新源
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.ssh
<1>ssh介绍
SSH为Secure Shell的缩写,由 IETF 的网络工作小组(Network Working Group)所制定;SSH 为建立在应用层和传输层基础上的安全协议。
SSH是目前较可靠,专为远程登录会话和其他网络服务提供安全性的协议。常用于远程登录,以及用户之间进行资料拷贝。
利用SSH协议可以有效防止远程管理过程中的信息泄露问题。SSH最初是 UNIX 系统上的一个程序,后来又迅速扩展到其他操作平台。SSH 在正确使用时可弥补网络中的漏洞。SSH 客户端适用于多种平台。几乎所有 UNIX 平台—包括 HP-UX、Linux、AIX、Solaris、Digital UNIX、Irix,以及其他平台,都可运行SSH。
使用SSH服务,需要安装相应的服务器和客户端。客户端和服务器的关系:如果,A机器想被B机器远程控制,那么,A机器需要安装SSH服务器,B机器需要安装SSH客户端。默认端口是22
<2>安装ssh
A.安装ssh服务器
sudo apt-get install openssh-server
B.远程登陆
使用ssh访问,如访问出现错误。可查看是否有该文件 ~/.ssh/known_ssh 尝试删除该文件解决。
<3>使用ssh连接服务器
SSH 告知用户,这个主机不能识别,这时键入"yes",SSH 就会将相关信息,写入" ~/.ssh/know_hosts" 中,再次访问,就不会有这些信息了。然后输入完口令,就可以登录到主机了。
2.scp
远程拷贝文件,scp -r 的常用方法:
1.使用该命令的前提条件要求目标主机已经成功安装openssh-server
如没有安装使用 sudo apt-get install openssh-server 来安装
2.使用格式:
scp -r 目标用户名@目标主机IP地址:/目标文件的绝对路径 /保存到本机的绝对/相对路径
举例:
scp -r python@192.168.1.100:/home/xiaoyuan/haha/ ./mytest/lisi
在后续会提示输入“yes”此时,只能输“yes”而不能简单输入“Y”
拷贝单个文件可以不加 -r参数,拷贝目录必须要加。
本地文件复制到远程:
scp FileName RemoteUserName@RemoteHostIp:RemoteFile
scp FileName RemoteHostIp:RemoteFolder
scp FileName RemoteHostIp:RemoteFile
本地目录复制到远程:
scp -r FolderName RemoteUserName@RemoteHostIp:RemoteFolder
scp -r FolderName RemoteHostIp:RemoteFolder
远程文件复制到本地:
scp RemoteUserName@RemoteHostIp:RemoteFile FileName
scp RemoteHostIp:RemoteFolder FileName
scp RemoteHostIp:RemoteFile FileName
远程目录复制到本地:
scp -r RemoteUserName@RemoteHostIp:RemoteFolder FolderName
scp -r RemoteHostIp:RemoteFolder FolderName
LINUX 的总结:
1、返回上一级目录 cd ..
2、返回上两级目录 cd ../..
3、返回上次所在的目录 cd -
4、显示当前路径 pwd
5、查看目录中的文件 ls
6、显示隐藏文件 ls -a
7、显示包含数字的文件名和目录名(通配符) ls *[0-9]*
8、创建一个叫做 'dir1' 的目录’ mkdir dir1
9、创建一个'/dir1/dir2/'目录树 mkdir -p /dir1/dir2/
10、删除一个叫做 'file1' 的文件 rm -f file1
11、删除一个叫做 'dir1' 的目录并同时删除其内容 rm -rf dir1
12、把文件’test’重命名为’test1' mv test test1
13、把文件’test’移动到’test1’目录下 mv test test1/
14、复制test1文件到/home/python/Desktop下 cp test1 /home/python/Desktop
15、给test文件创建一个软连接名字为test1 ln -s test test1
16、新建test test1两个文件 touch test test1
17、查看本机ip地址 ifconfig
19、用grep搜索8832进程 ps -aux | grep 8832
20、搜索根目录下名字为test的文件 find / -name test
21、查看文件test的内容 cat test gedit test vi test
22、归档并压缩当前目录所有文件用gz结尾(压缩包名随变) tar -zcvf test.tar.gz *
23、解压test.tar.gz到/home/python/Desktop tar -zxvf test.tar.gz -C /home/python/Desktop
25、把文件test拥有者 同组者 其他用户全部改成可读可写可执行 chmod 777 test
26、用grep搜索test.txt已a开头的内容 grep ‘^a’ test.txt
27、用grep搜索test.txt已a结尾的内容 grep ‘a$’ test.txt
28、远程登录用户名为python IP地址为127.0.0.1的电脑 ssh python@127.0.01
29、把当前目录下名字为test.txt拷贝到 python IP地址为127.0.0.1的电脑的/home/python/Desktop下 scp -r test.txt python@127.0.01:/home/python/Desktop
30、重启和立刻关机命令是 reboot init6 shutdown -r now 或 shutdown -h now init0
31、请写出15个vi命令 并说出作用
yy 复制
p 粘贴
n yy 复制多行
dd 删除光标所在行 又是剪切
dw 删除一个单词
d0 删除光标前
n dd 删除多行
M 屏幕中间行
H 屏幕顶行
G 最后一行的行首
30G 定位30行
gg 回到第一行
j 往下走
k 往上走
h 往左走
l 往右走
x 删除光标所在字符
X 删除光标前一个字符
ctrl+f向下翻一屏
ctrl+d向下翻半屏
ctrl+b 向上翻一屏
ctrl+u 向上翻半屏
shift+} 向下按段走
shift+{ 向上按段走
u 撤销
ctrl+r 反撤销
w 向后移动一个单词
b 向前移动一个单词
v 选中 shift+右方向键
末行模式下
wq! 强制保存并退出
wq 保存并退出
x 保存并退出
用git提交代码的几个命令
git add .
git commit -m “描述”
git push origin master