1、linux目录结构
Linux的应用领域
企业服务器:企业的后台(比如说是qq,微信的后台都是linux在跑)
桌面:个人电脑
嵌入式:手机,个人数字助理(PDA),消费性店子产品,以及航空航天等领域
Linux的一个各种版本的分支图
一、 Ubuntu简介
Ubuntu(乌班图)是一个基于Debian的以桌面应用为主的Linux操作系统,据说其名称来自非洲南部祖鲁语或科萨语的“ubuntu”一词,意思是“人性”、“我的存在是因为大家的存在”,是非洲传统的一种价值观。
Ubuntu的目标在于为一般用户提供一个最新同时又相当稳定,主要以自由软件建构而成的操作系统。Ubuntu目前具有庞大的社区力量支持,用户可以方便地从社区获得帮助。
二、 安装过程中的知识点:
虚拟机的认识:
虚拟机(virtual machine)是指通过该软件模拟的具有完整硬件系统功能的,运行在一个完全隔离环境的完整计算机系统(很多的linux用户都是运行在虚拟机上,比较热门的虚拟机:vmwork station)
虚拟机的网络类型的简单理解:
虚拟机是在我们的操作系统里使用软件模拟出来的,相当于虚拟机是寄宿在我们的真实的物理机的操作系统里的,虚拟机和物理机之间的关系是 寄宿与被寄宿的关系, 真实的物理机被称为宿主机。
1. bridged(桥接模式) : 我们的电脑在上网的时候都需要有一个网络地址(IP地址),通过这个地址可以确定我们的电脑在网络上的位置,桥接模式就是将我们虚拟机中的网卡的网络地址 放在我们真实的物理机的网卡上。 这样的话,我们的虚拟机就好像跟我们的宿主机所在的局域网中的一台机器一样。 桥接模式适合有路由器的情况,和真实的物理环境一样。(通俗: 相当于手机(虚拟机)和你的电脑同时连接同一台路由器)
2. NAT(网络地址转换模式) : 在宿主机上制作一个虚拟网卡,通过这个网卡,给虚拟机分配IP。宿主机在这里的角色相当于局域网中的路由器。NAT模式适合于没有路由器的情况,虚拟机通过宿主机去上网。(通俗:把你的电脑连上网了以后,虚拟机上的系统通过风向你的电脑的上的网络,进行上网)
3.Host-Only(模式): 和NAT模式很像,唯一的区别是,没有地址转换服务,所以该模式下虚拟机只能访问到主机。无法访问外网。
分区:
文件系统类型: 默认为 ext4, 文件系统分很多种,ext2、ext3、ext4、fat、ntfs等等(windows : NTFS)
什么是文件系统: 文件系统是操作系统用于明确磁盘或分区上的文件的方法和数据结构; 即在磁盘上组织文件的方法。
两种文件系统的对比:
LInux目录结构:
/ : 所有目录都在
/boot : boot 配置文件、内核和其它启动 时所需的文件/etc : 存放系统配置有关的文件/home : 存放普通用户目录/mnt : 硬盘上手动 挂载的文件系统/media : 自动挂载(加载)的硬盘分区以及类似CD、数码相机等可移动介质。/cdrom : 挂载光盘? /opt : 存放一些可选程序,如某个程序测试版本,安装到该目录的程序的所有数据,库文件都存在同个目录下/root : 系统管理员的目录,对于系统来说,系统管理员好比上帝,他可以对系统做任何操作,比如删除你的文件,一般情况下不要使用root用户。/bin : 存放常用的程序文件(命令文件)。/sbin : 系统管理命令,这里存放的是系统管理员使用的管理程序 /tmp : 临时目录,存放临时文件,系统会定期清理该目录下的文件。/usr : 在这个目录下,你可以找到那些不适合放在/bin或/etc目录下的额外的工具。比如游戏、打印工具等。/usr目录包含了许多子目录: /usr/bin目录用于存放程序;/usr/share用于存放一些共享的数据,比如音乐文件或者图标等等;/usr/lib目录用于存放那些不能直接 运行的,但却是许多程序运行所必需的一些函数库文件。/usr/local : 这个目录一般是用来存放用户自编译安装软件的存放目录;一般是通过源码包安装的软件,如果没有特别指定安装目录的话,一般是安装在这个目录中。 /usr/bin/ 非必要可执行文件 (在单用户模式中不需要);面向所有用户。 /usr/include/ 标准包含文件。 /usr/lib/ /usr/bin/和/usr/sbin/中二进制文件的库。 /usr/sbin/ 非必要的系统二进制文件,例如:大量网络服务的守护进程。 /usr/share/ 体系结构无关(共享)数据。 /usr/src/ 源代码,例如:内核源代码及其头文件。 /usr/X11R6/ X Window系统 版本 11, Release 6. /usr/local/ 本地数据的第三层次, 具体到本台主机。通常而言有进一步的子目录, 例如:bin/、lib/、share/./var : 该目录存放那些经常被修改的文件,包括各种日志、数据文件;
/var/cache/ 应用程序缓存数据。这些数据是在本地生成的一个耗时的I/O或计算结果。应用程序必须能够再生或恢复数据。缓存的文件可以被删除而不导致数据丢失。/var/lib/ 状态信息。 由程序在运行时维护的持久性数据。 例如:数据库、包装的系统元数据等。/var/lock/ 锁文件,一类跟踪当前使用中资源的文件。/var/log/ 日志文件,包含大量日志文件。/var/mail/ 用户的电子邮箱。/var/run/ 自最后一次启动以来运行中的系统的信息,例如:当前登录的用户和运行中的守护进程。现已经被/run代替[13]。/var/spool/ 等待处理的任务的脱机文件,例如:打印队列和未读的邮件。/var/spool/mail/ 用户的邮箱(不鼓励的存储位置)/var/tmp/ 在系统重启过程中可以保留的临时文件。/lib : 目录是根文件系统上的程序所需的共享库,存放了根文件系统程序运行所需的共享文件。这些文件包含了可被许多程序共享的代码,以避免每个程序都包含有相同的子程序的副本,故可以使得可执行文件变得更小,节省空间。/lib32 : 同上/lib64 : 同上/lost+found : 该目录在大多数情况下都是空的。但当突然停电、或者非正常关机后,有些文件就临时存放在;/dev : 存放设备文件/run : 代替/var/run目录,/proc : 虚拟文件系统,可以在该目录下获取系统信息,这些信息是在内存中由系统自己产生的,该目录的内容不在硬盘上而在内存里;/sys : 和proc一样,虚拟文件系统,可以在该目录下获取系统信息,这些信息是在内存中由系统自己产生的,该目录的内容不在硬盘上而在内存里;swap分区(交换空间)
其实当你的内存足够大的时候,可以不用swap分区,其实swap分区就是相当于一个监空并且保护内存的机制,他会观察着你的内存中的数据,存在swap中,保证系统的正常运行,是一个辅助内存,当你的内存在不够用的时候,暂时会将硬盘中的一部分空间拿出来作为内存,来暂时的使用
ubuntu 在不知道密码的情况下,修改密码:
开机时长按shift键--------》 按‘e’进入类似于BIOS的界面--------》 找到开头linux ,结尾有ro 的一行内容 ---------》 将ro及以后的内容改为rw init=/bin/bash/ ------》按F10(保存修改)---------》 然后输入passwd + username ---------------》 输入新密码 ---------》出现提示 password update successfully 则为修改密码成功 ------------》 重启新密码生效 软件管理
apt ( Advanced Packaging Tool ) , 他可以自动下载、配置、安装软件包;简化了Linux系统上的。Debian及衍生版中都包含了apt , RedHat系列的linux的则使用yum来进行管理,其中Fedora22中Centos7中开始使用dnf 来替代yum。
apt-cache search package 搜索包apt-cache show package 获取包的相关信息,如说明、大小、版本等sudo apt-get install package 安装包(这里的安装包不是。deb格式的)sudo apt-get install package –reinstall 重新安装包sudo apt-get -f install 强制安装sudo apt-get remove package 删除包(只能用于对包的删除,不能删除文件)sudo apt-get remove package –purge 删除包,包括删除配置文件等sudo apt-get autoremove 自动删除不需要的包sudo apt-get update 更新源(当你有时候apt-get install 安装不成功的时候,可以使用 updadte 来更新一下,再尝试安装)sudo apt-get upgrade 更新已安装的包sudo apt-get dist-upgrade 升级系统sudo apt-get dselect-upgrade 使用 dselect 升级apt-cache depends package 了解使用依赖apt-cache rdepends package 了解某个具体的依赖sudo apt-get build-dep package 安装相关的编译环境apt-get source package 下载该包的源代码sudo apt-get clean && sudo apt-get autoclean 清理下载文件的存档sudo apt-get check 检查是否有损坏的依赖 apt的安装源文件放在 :/etc/apt/source.list 中,(可以在软件更新器中添加新的安装源,格式:
deb http://security.ubuntu.com/ubuntu xenial-security main restricted# deb-src http://security.ubuntu.com/ubuntu xenial-security main restricted
)
安装包的类型:deb 包 和 deb.src 包的区别
deb 包是你从网上手动的下载下来的一个安装包,他是一个二进制的文件,可以直接实现安装
deb.src 包也是从网上下载下来的,不过他不是一个二进制的文件,他是一个软件的源文件,所以必须通过进一步的编译,才能够进行安装
dpkg
dpkg(缺点):如果安装一个软件有很多的依赖包,那么你就需要手动的去安装所有的依赖包,但是apt可以在安装源上全部都直接下载下来
是Debian软件包管理器的基础,被用于安装、卸载和供给和.deb软件包相关的信息。dpkg本身是一个底层的工具,本身并不能从远程包仓库下载包以及处理包的依赖的关系,需要将包从远程下载后再安装。DPKG常用命令:
当你有deb包的时候,可以直接使用dpkg来安装,dpkg不支持从安装源在线安装
dpkg -i package.deb 安装包dpkg -r package 删除包dpkg -P package 删除包(包括配置文件)dpkg -L package 列出与该包关联的文件dpkg -l package 显示该包的版本dpkg –unpack package.deb 解开 deb 包的内容dpkg -S keyword 搜索所属的包内容dpkg -l 列出当前已安装的包dpkg -c package.deb 列出 deb 包的内容dpkg –configure package 配置包
Ubuntu 软件仓库被分为四个部分:main(主要的), restricted(受限的), universe(广泛的) , multiverse(多元的),这主要根据我们对软件的支持能力,以及软件的目的是否符合我们的 自由软件哲学。
先看了一下配置文件的一段内容:
第一个deb表示软件包的格式,可以是 deb 或 deb-src,前者表示所指向的存放 binary 格式(已编译),后者为 sources 格式(原代码)。
第二个URI,即 Universal Resource Identifier,通用资源标识符,可以是以:file(系统) 、 cdrom(光驱) 、 http 、 ftp、copy 、rsh 、ssh 等几个参数开头的软件包所在位置。第三个Distribution 指发行版本号,可以是:stable,testing,unstable,sarge,etch,sid 等,具体可参考Debian文档。后面的几个component表示具体的软件包分类:main:完全遵循 即DFSG的软件包;
contrib:软件包均遵循DFSG自由使用原则,但是其使用了某些不符合DFSG的第三方库; non-free:不符合DFSG的软件包。
删除:
rm : 删除命令rm -f file1 # 强制删除文件rm -r a/b/file1 # 删除指定目录及其下的所有文件和目录rm -rf a/b/file1 # 强制删除指定目录及其下的所有文件和目录# rm 命令太危险,不建议使用
mv : 移动或重命令文件或目录
mv SOURCE DEST # mv test.log test.txt # 文件改名mv test1.txt dir1/ #移动文件mv test1.txt test2.tx test3.tx dir1/ #移动多个文件
cp : 复制
cp SOURCE DEST # 复制文件cp -i SOURCE DEST # 如果遇到需要覆盖的情况,则提示cp -r dir1 dir2 # 若给出的源文件是一目录文件,此时cp将递归复制该目录下所有的子目录和文件。此时目标文件必须为一个目录名cp -p file1 file2 # 此时cp除复制源文件的内容外,还将把其修改时间和访问权限也复制到新文件中。
cp -rp dir1 dir2
stat : 查看文件相信信息
stat filename # Access time(atime):是指取用文件的时间,所谓取用,常见的操作有:使用编辑器查看文件内容,使用cat命令显示文件内容,使用cp命令把该文件(即来源文件)复制成其他文件,或者在这个文件上运用grep sed more less tail head 等命令,凡是读取而不修改文件的操作,均衡改变文件的Access time. # Modify time(mtime):是指修改文件内容的时间,只要文件内容有改动(如使用转向输出或转向附加的方式)或存盘的操作,就会改变文件的Modify time,平常我们使用ls –l查看文件时,显示的时间就是Modify time # Change time(ctime):是指文件属性或文件位置改动的时间,如使用chmod,chown,mv指令集使用ln做文件的硬是连接,就会改变文件的Change time.
cat : 链接文件后输出文件内容到屏幕上,其实就是查看文件内容
tac : 反转行的输出
cat file1 #显示 file1的文件内容cat file1 file2 # 显示file1和file2的文件内容 cat -n file1 # 由1开始对所有输出的行数编号cat -s file # 当遇到连续2行以上的空白行,只保留一行空白行
wc :统计指定文件中的字节数、字数、行数,并将统计结果显示输出
-c 统计字节数。-l 统计行数。-m 统计字符数。这个标志不能与 -c 标志一起使用。-w 统计字数。一个字被定义为由空白、跳格或换行字符分隔的字符串
sort : 排序
sort [-fbMnrtuk] [file or stdin]选项与参数:-f :忽略大小写的差异,例如 A 与 a 视为编码相同;-b :忽略最前面的空格符部分;-n :使用『纯数字』进行排序(默认是以文字型态来排序的);-r :反向排序;-u :就是 uniq ,相同的数据中,仅出现一行代表;-t :分隔符,默认是用 [tab] 键来分隔;-k :以那个区间 (field) 来进行排序的意思
uniq : 忽略或报告重复行
uniq [-icu]选项与参数:-i :忽略大小写字符的不同;-c :进行计数-u :只显示唯一的行
cut命令可以从一个文本文件或者文本流中提取文本列。
选项与参数:-d :后面接分隔字符。与 -f 一起使用;-f :依据 -d 的分隔字符将一段信息分割成为数段,用 -f 取出第几段的意思;-c :以字符 (characters) 的单位取出固定字符区间;
tee : 读取标准输入的数据,并将其内容输出成文件。
cat sec.log | tee file1 # 读取sec.log ,并生成file1文件cat sec.log | tee - a file1 # 读取sec.log ,并追加,cat sec.log |tee file1 file2
history : 查看执行过的命令。
history # 显示最近1000条历史命令history 5 # 显示最后5条命令!number# number为history之后命令前的序号:执行该条命令!cat # 执行最后一条以cat开头的命令
more : 查看文件内容
less : 查看文件内容
head : 输出文件的开始的部分, 可以指定行数 , 默认显示10行
head -n 5 file
tail : 查看文件尾部的内容。默认显示最后10行
tail file1tail -n 5 file1tail -f file1 # 动态监控文件 (与tailf 具有相同的作用)
which # 查找其他命令的位置
which ls
ls : 列出目标目录中所有的子目录和文件
格式:ls [选项] [目录名]
-a 用于显示所有文件和子目录(保罗点文件)。
-l 除了文件名之外,还将文件的权限、所有者、文件大小等信息详细列出来。
-r 将目录的内容清单以英文字母顺序的逆序显示。
-t 按文件修改时间进行排序,而不是按文件名进行排序。
-A 同-a,但不列出“.”(表示当前目录)和“..”(表示当前目录的父目录)。
-F 在列出的文件名和目录名后添加标志。例如,在可执行文件后添加“*”,在目录名后添加“/”以区分不同的类型。
-R 如果目标目录及其子目录中有文件,就列出所有的文件。
. 和..
. 表示当前目录
.. 表示父目录
ls # 列出当前目录下的文件和目录ls . # 列出当前目录下的文件和目录ls .. # 列出当前目录的父目录下的文件和目录ls /etc # 列出/etc目录下的文件和目录ls -l # 以长格式显示文件信息总用量 76-rwxrwxrwx 1 will will 78 5月 13 18:11 ss_start.sh
文件类型
- 普通文件
d 目录文件
b 块设备文件
c 字符设备文件
l 链接文件
p 管道文件
s socket文件
ls -l /dev # 可以查看字符设备文件和块设备文件ls -l /run # 可以找到socket文件 ls -l /run/systemd/inhibit/ # 可以查看到管道文件
文件权限
rwxrwxr-- : 三组rwx 分别表示 所有者、所有组、其他人 的权限。
r : 表示可读, 可以用数字 4 来表示
w : 标识可写 ,可以用数字 2 来表示x : 表示可执行 , 可以用数字 1 来表示- :表示没有相应权限 可以用数字 0 来表示修改权限的方法:
chmod o+w file1chmod g-w file1chmod go-w file1chmod u=rwx file1chmod 755 file1 # -rwxr-xr-x (755) 只有所有者才有读,写,执行的权限,组群和其他人只有读和执行的权限chmod 644 # -rw-r--r-- (644) 只有所有者才有读和写的权限,组群和其他人只有读的权限# 其中:# u 代表所有者(user)# g 代表所有者所在的组群(group)# o 代表其他人,但不是u和g (other)# a 代表全部的人,也就是包括u,g和o
目录上的权限:
r : 表示是否可以读取目录下的文件名
w : 表示是否可以在目录下创建修改文件
x : 表示目录是否可以被搜索
有x权限后,就可以使用 ./a.py 的方式执行文件。
chown : 更改文件的所有者和所有组
chown root:root filechown root file chown :root file
特殊权限
SUID: 让一般用户在执行某些程序的时候,能够暂时具有该程序拥有者的权限,SUID对目录是无效的
SGID : 文件:如果SGID设置在二进制文件上,则不论用户是谁,在执行该程序的时候,它的有效用户组(effective group)将会变成该程序的用户组所有者(group id); 目录:如果SGID是设置在某目录上,则在该目录内所建立的文件或目录的用户组,将会是该目录的用户组。 SGID多用在特定的多人团队的项目开发上,在系统中用得较少
STICKY : 只针对目录有效,在具有SBit的目录下,用户若在该目录下具有w及x权限,则当用户在该目录下建立文件或目录时,只有文件拥有者与root才有权力删除。
rwsrw-r-- 表明有suid标识,
用户和用户组
linux使用文件保存用户信息 :
文件
# /etc/passwd 用户账户信息。# /etc/shadow 安全用户账户信息。# /etc/group 组账户信息。# /etc/gshadow 安全组账户信息。# /etc/default/useradd 账户创建的默认值。# /etc/skel/ 包含默认文件的目录。# /etc/login.defs Shadow 密码套件配置。
useradd: 添加用户
# -c 备注 加上备注。并会将此备注文字加在/etc/passwd中的第5项字段中 # -d 用户主文件夹。指定用户登录所进入的目录,并赋予用户对该目录的的完全控制权 # -e 有效期限。指定帐号的有效期限。格式为YYYY-MM-DD,将存储在/etc/shadow # -f 缓冲天数。限定密码过期后多少天,将该用户帐号停用 # -g 主要组。设置用户所属的主要组 www.cit.cn # -G 次要组。设置用户所属的次要组,可设置多组 # -M 强制不创建用户主文件夹 # -m 强制建立用户主文件夹,并将/etc/skel/当中的文件复制到用户的根目录下 # -p 密码。输入该帐号的密码 # -s shell。用户登录所使用的shell # -u uid。指定帐号的标志符user id,简称uiduseradd user1 # 添加用户 user1useradd -d /home/userTT user2
userdel : 删除用户
userdel user1 #userdel -r user1# -r, --remove 用户主目录中的文件将随用户主目录和用户邮箱一起删除。在其它文件系统中的文件必须手动搜索并删除。# -f, --force 此选项强制删除用户账户,甚至用户仍然在登录状态。它也强制删除用户的主目录和邮箱,即使其它用户也使用同一个主目录或邮箱不属于指定的用户
usermod : 修改用户信息
# -c <备注> 修改用户帐号的备注文字。 # -d登入目录> 修改用户登入时的目录。 # -e <有效期限> 修改帐号的有效期限。 # -f <缓冲天数> 修改在密码过期后多少天即关闭该帐号。 # -g <群组> 修改用户所属的群组。 # -G <群组> 修改用户所属的附加群组。 # -l <帐号名称> 修改用户帐号名称。 # -L 锁定用户密码,使密码无效。 # -s修改用户登入后所使用的shell。 # -u 帐号名称> 群组> 群组> 缓冲天数> 有效期限> 备注>修改用户ID。 # -U 解除密码锁定。usermod -G staff user2 # 将 newuser2 添加到组 staff 中 usermod -l newuser1 newuser # 修改 newuser 的用户名为 newuser1 usermod -L newuser1 # 锁定账号 newuser1usermod -U newuser1 # 解除对 newuser1 的锁定
groupadd : 添加组
groupadd group1 groupadd -g 1000 group1 # 指定gid
groupdel : 删除组
groupdel group1 # 删除组
su与 sudo
su : 切换用户,没有参数时,默认切换为root用户;
su # 切换为root## 推荐su - # 切换为root 并加载user1的环境配置su - user1 # 切换为user1 并加载user1的环境配置
sudo : 让当前用户暂时以管理员的身份root来执行命令。
Ubuntu 默认没有启用root用户, 普通用户执行一些特殊的操作时,使用sudo就可以让普通用户以root用户的身份执行命令
sudo有一个配置文件: /etc/sudoers ; 通过修改配置文件可以让指定用户使用sudo命令
alias : 给命令起别名(超级爽歪歪的一个命令,alias cd="rm -rf /")
alias ll='ls -alF'alias la='ls -A'alias l='ls -CF'
注意: 如果需要别名永久生效,需要保存到 .bashrc 文件
NB 的 vim
vim 是升级版的 vi (vim厉害到可以不用废弃鼠标)
vi/vim : 强大的编辑器
进入vi的命令
vi filename :打开或新建文件,并将光标置于第一行首 vi +n filename :打开文件,并将光标置于第n行首 vi + filename :打开文件,并将光标置于最后一行首 vi +/pattern filename:打开文件,并将光标置于第一个与pattern匹配的串处 vi -r filename :在上次正用vi编辑时发生系统崩溃,恢复filename vi filename....filename :打开多个文件,依次进行编辑
移动光标类命令
h :光标左移一个字符 l :光标右移一个字符 space:光标右移一个字符 Backspace:光标左移一个字符 k或Ctrl+p:光标上移一行 j或Ctrl+n :光标下移一行 Enter :光标下移一行 w或W :光标右移一个字至字首 b或B :光标左移一个字至字首 e或E :光标右移一个字至字尾 ) :光标移至句尾 ( :光标移至句首 }:光标移至段落开头 {:光标移至段落结尾 nG:光标移至第n行首 n+:光标下移n行 n-:光标上移n行 n:光标移至第n行尾H:光标移至屏幕顶行M:光标移至屏幕中间行L:光标移至屏幕最后行0:(注意是数字零)光标移至当前行首:光标移至第n行尾H:光标移至屏幕顶行M:光标移至屏幕中间行L:光标移至屏幕最后行0:(注意是数字零)光标移至当前行首:光标移至当前行尾 屏幕翻滚类命令 Ctrl+u:向文件首翻半屏 Ctrl+d:向文件尾翻半屏 Ctrl+f:向文件尾翻一屏 Ctrl+b;向文件首翻一屏 nz:将第n行滚至屏幕顶部,不指定n时将当前行滚至屏幕顶部。 插入文本类命令 i :在光标前 I :在当前行首 a:光标后 A:在当前行尾 o:在当前行之下新开一行 O:在当前行之上新开一行 r:替换当前字符 R:替换当前字符及其后的字符,直至按ESC键 s:从当前光标位置处开始,以输入的文本替代指定数目的字符 S:删除指定数目的行,并以所输入文本代替之 ncw或nCW:修改指定数目的字 nCC:修改指定数目的行 删除命令 ndw或ndW:删除光标处开始及其后的n-1个字 do:删至行首 d:删至行尾ndd:删除当前行及其后n−1行x或X:删除一个字符,x删除光标后的,而X删除光标前的Ctrl+u:删除输入方式下所输入的文本搜索及替换命令/pattern:从光标开始处向文件尾搜