Linux入门大全

一 Linux入门概述
1.1 概述
Linux内核最初只是由芬兰人林纳斯·托瓦兹(Linus Torvalds)在赫尔辛基大学上学时出于个人爱好而编写的。
Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。Linux能运行主要的UNIX工具软件、应用程序和网络协议。它支持32位和64位硬件。Linux继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。
目前市面上较知名的发行版有:Ubuntu、RedHat、CentOS、Debain、Fedora、SuSE、OpenSUSE

1.2 下载地址
centos下载地址:
网易镜像:http://mirrors.163.com/centos/6/isos/
搜狐镜像:http://mirrors.sohu.com/centos/6/isos/
1.3 Linux特点
Linux里面一切皆是文件
Linux里面没有后缀名这一说
1.4 Linux和Windows区别
目前国内Linux更多的是应用在服务器上,而桌面操作系统更多使用的是window。主要区别如下。
比较 Window Linux
界面 界面统一,外壳程序固定所有Windows程序菜单几乎一致,快捷键也几乎相同 图形界面风格依发布版本不同而不同,可能互不兼容。GNU/Linux的终端机是从UNIX传承下来,基本命令和操作方法也几乎一致。
驱动程序 驱动程序丰富,版本更新频繁。默认安装程序里面一般包含有该版本发布时流行的硬件驱动程序,之后所出的新硬件驱动依赖于硬件厂商提供。对于一些老硬件,如果没有了原配的驱动有时候很难支持。另外,有时硬件厂商未提供所需版本的Windows下的驱动,也会比较头痛。 由志愿者开发,由Linux核心开发小组发布,很多硬件厂商基于版本考虑并未提供驱动程序,尽管多数无需手动安装,但是涉及安装则相对复杂,使得新用户面对驱动程序问题会一筹莫展。但是在开源开发模式下,许多老硬件尽管在Windows下很难支持的也容易找到驱动。HP、Intel、AMD等硬件厂商逐步不同程序支持开源驱动,问题正在得到缓解。
使用 使用比较简单,容易入门。图形化界面对没有计算机背景知识的用户使用十分有利。 图形界面使用简单,容易入门。文字界面,需要学习才能掌握。
学习 系统构造复杂、变化频繁、且知识、技能淘汰快,深入学习困难 系统构造简单、稳定,且知识、技能传承性好,深入学习相对容易
软件 每一种特定功能可能都需要商业软件的支持,需要购买相应的授权 大部分软件都可以自由获取,同样功能的软件选择较少。
二 VM安装相关

Vmave 虚拟化原理图

2.1 安装VMWare虚拟机

2/验证VMWARE是否安装成功

(有些同学的机器在安装vmware的时候会出现一个错误:virtual XT,这需要重启电脑<按F2/按DELET/…>进入BIOS,开启这个虚拟加速开关)
(有些WINDOWS8/10系统会出现虚拟网卡安装失败的现象,这需要关闭windows的驱动程序安装签名验证)
解决wmware软件卸载不干净导致的再次安装失败:
打开系统注册表,搜索wmware软件相关的注册表,把这些注册表全部删除之后,再次安装即可;
2.2 安装CentOS
1、启动虚拟机,将自动进入centos安装界面

swap交换分区:把硬盘的一部分空间开辟出来当做内存使用
swap的大小建议是内存的2倍
系统运行时会把内存不常用的数据放到swap中

2、centos系统安装完后,需要设置网络
首先在vmware中,查看NAT网络模式中的虚拟路由器的网段和IP地址

3、接下来设置windows的vmnet8的ip地址和虚拟机中centos的ip地址,即可联网

1)解决虚拟机重启时错误:

虚拟机磁盘有损坏;(因为是虚拟化的磁盘)

Fsck : filesystem Check

修复之后,重启虚拟机;如果还有其他磁盘有损坏,按照此方法解决即可;
2.3 安装VMTools工具
2.3.1 什么是VMtools
VM tools顾名思义就是Vmware的一组工具。主要用于虚拟主机显示优化与调整,另外还可以方便虚拟主机与本机的交互,如允许共享文件夹,甚至可以直接从本机向虚拟主机拖放文件、鼠标无缝切换、显示分辨率调整等,十分实用。
先启动CentOS并成功登录如下图,发现底部提示且窗口中等大小,准备安装。
友情提示:如果“安装 VMware Toos”按钮为灰色,需要“虚拟机”—>“设置”—>“CD/DVD”和“CD/DVD 2”—>“连接”—>“使用物理驱动器§”

3)选择虚拟机菜单栏–安装VMware tools

4)光驱自动挂载VMTools

5)右键解压VMwareTools-10.1.6-5214329.tar到桌面

进入文件夹并确认看到vmware-tools-distrib文件

6)运行vmware-install.pl文件

最后用“./vmware-install.pl”命令来运行该安装程序,然后根据屏幕提示一路回车。到此整个安装过程算是完成了。
7)直接按到/dev/hdc…停止为止,安装完成

8)重启CentOS, 这时候屏幕变成全屏了

9)设置共享文件夹,实现Windows --------CentOS文件共享

2.4 虚拟机屏幕保护设置

2.5 IVT虚拟化支持
1)异常情况

2)宿主机BIOS设置中的硬件虚拟化被禁用了
需要打开笔记本BIOS中的IVT对虚拟化的支持:
1、首先,你需要确认的使你的计算机型号和CPU、BIOS的型号,因为过老的计算机是不支持虚拟化技术的。
2、那么怎么知道呢,方法很简单。开机时按F2、F12、DEL、ESC等键就可以进入到BIOS,这就需要根据电脑的品牌和采用的BIOS才能确定到底是哪一个按键了,当你知道你的BIOS或者说主板的型号的时候,可以上网找度娘查找。
3、好了,进入到BIOS后,找到Configuration选项或者Security选项,然后选择Virtualization,或者Intel Virtual Technology,就可以开始你的操作了。

4、然后回车,将其值设置成:设置为Enabled。

5、再然后,就是保存BIOS设置,重启计算机。

6、然后进入到操作系统。

7、单击右键,选择:任务管理器。

8、这时你能看到任务管理器出来了。

9、这里,选择“性能”标签。

10、选择左侧的“CPU”,单击。

11、此时,你会看到右侧出现了有关计算机的信息情况,在最下面有一个叫做“虚拟化”状态的显示(图中以用红色圆圈标出)。可以明显的看出,我这里的虚拟化状态是:已启用。

12、好了,这就是虚拟化启用的办法。
三 Linux目录结构
3.1 概览

3.2 树状目录结构

/bin 是Binary的缩写,这个目录存放着系统必备执行命令
/boot 这里存放的是启动Linux时使用的一些核心文件,包括一些连接文件以及镜像文件,自己的安装别放这里
/dev Device(设备)的缩写,该目录下存放的是Linux的外部设备,在Linux中访问设备的方式和访问文件的方式是相同的。
/etc 所有的系统管理所需要的配置文件和子目录。

/home 存放普通用户的主目录,在Linux中每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的。
/lib 系统开机所需要最基本的动态连接共享库,其作用类似于Windows里的DLL文件。几乎所有的应用程序都需要用到这些共享库。
/lost+found 这个目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件。
/media linux系统会自动识别一些设备,例如U盘、光驱等等,当识别后,linux会把识别的设备挂载到这个目录下。

/misc 该目录可以用来存放杂项文件或目录,即那些用途或含义不明确的文件或目录可以存放在该目录下。
/mnt 系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将光驱挂载在/mnt/上,然后进入该目录就可以查看光驱里的内容了。

/net 存放着和网络相关的一些文件.

/opt 这是给主机额外安装软件所摆放的目录。比如你安装一个ORACLE数据库则就可以放到这个目录下。默认是空的。
/proc 这个目录是一个虚拟的目录,它是系统内存的映射,我们可以通过直接访问这个目录来获取系统信息。
/root 该目录为系统管理员,也称作超级权限者的用户主目录。

/sbin s就是Super User的意思,这里存放的是系统管理员使用的系统管理程序。
/selinux 这个目录是Redhat/CentOS所特有的目录,Selinux是一个安全机制,类似于windows的防火墙

/srv service缩写,该目录存放一些服务启动之后需要提取的数据。
/sys 这是linux2.6内核的一个很大的变化。该目录下安装了2.6内核中新出现的一个文件系统 sysfs 。

/tmp 这个目录是用来存放一些临时文件的。

/usr 这是一个非常重要的目录,用户的很多应用程序和文件都放在这个目录下,类似于windows下的program files目录。
/var 这个目录中存放着在不断扩充着(动态)的东西,我们习惯将那些经常被修改的目录放在这个目录下。包括各种日志文件。
四 VI/VIM编辑器
4.1 概述
所有的 Unix Like 系统都会内建 vi 文书编辑器,其他的文书编辑器则不一定会存在。但是目前我们使用比较多的是 vim 编辑器。
Vim 具有程序编辑的能力,可以主动的以字体颜色辨别语法的正确性,方便程序设计。Vim是从 vi 发展出来的一个文本编辑器。代码补完、编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用。
简单的来说vi 是老式的字处理器,不过功能已经很齐全了,但是还是有可以进步的地方。vim 则可以说是程序开发者的一项很好用的工具。连vim 的官方网站 (http://www.vim.org) 自己也说 vim 是一个程序开发工具而不是文字处理软件。
4.2 测试数据准备

4.3 一般模式
以 vi 打开一个档案就直接进入一般模式了(这是默认的模式)。在这个模式中, 你可以使用『上下左右』按键来移动光标,你可以使用『删除字符』或『删除整行』来处理档案内容, 也可以使用『复制、贴上』来处理你的文件数据。

常用语法:
yy 复制光标当前一行
数字yy 复制光标(含)当前几行
yy数字 复制光标(含)当前一行几份
p 箭头移动到目的行粘贴
u 撤销上一步
dd 删除光标当前行(相当于剪切)
数字dd 删除光标(含)后多少行
x 删除一个字母,相当于del
X 删除一个字母,相当于Backspace
yw 复制一个词(从光标所在字母开始到单词字母结束)
dw 删除一个词(从光标所在字母开始到单词字母结束)
数字+dw 删除几个词(从光标所在字母开始到第几个单词字母结束)
shift+^ 移动到行头
shift+$ 移动到行尾
1+shift+g 光标移动到首行
gg 光标移动到首行
shift+g 移动到末行
G 移动到末行
数字+shift+g 移动到目标行
数字+gg 移动到目标行
数字+G 移动到目标行
ctrl + v 块操作,常用在块区域删除操作
4.4 编辑模式
在一般模式中可以进行删除、复制、贴上等等的动作,但是却无法编辑文件内容的! 要等到你按下『i, I, o, O, a, A, r, R』等任何一个字母之后才会进入编辑模式。
注意了!通常在 Linux 中,按下这些按键时,在画面的左下方会出现『INSERT 或 REPLACE 』的字样,此时才可以进行编辑。而如果要回到一般模式时, 则必须要按下『Esc』这个按键即可退出编辑模式。

常用语法
1)进入编辑模式
i 当前光标前
I 当前光标行的行首
a 当前光标后
A 当前光标行的行末
o 当前光标行的下一行
O 当前光标行的上一行

2)退出编辑模式
按『Esc』键
4.5 指令模式
在一般模式当中,输入『 : / ?』3个中的任何一个按钮,就可以将光标移动到最底下那一行。
在这个模式当中, 可以提供你『搜寻资料』的动作,而读取、存盘、大量取代字符、离开 vi 、显示行号等动作是在此模式中达成的!

常用语法:
选项
:w 保存
:q 退出
:! 感叹号强制执行
:wq! 强制保存退出

/ 查找,/被查找词,n是查找下一个,shift+n是往上查找
? 查找,?被查找词,n是查找上一个,shift+n是往下查找
五 系统管理操作
5.1 查看网络IP和网关
0)网络模式介绍:

NAT模式:
网络地址转换;包含有两层路由。第一层是外面的路由器,也就是宿主机的网络。第二层才是虚拟机的路由。
该模式需要我们自己配置ip地址,相当与windows下的自己设计ip方式,
一般在集群坏境下使用,因为我们需要对集群的ip进行规划;
桥接模式、仅主机模式:
Hdcp,只有一层路由,就是宿主机的路由。选择了桥接模式,就相当于我们在windows系统的网络配置选择了自动获取ip,它会连接网络。这种方式在集群坏境下一般不用。
当只有一层路由时,ip地址最多只能有256个,在上课教学的坏境下,我们每个人都会搭建5-6台虚拟机,每台虚拟机都会占用一个ip,这时就有可能同一网段ip地址不够用的情况;

修改网络地址:
1、设置网卡为net模式;
2、确保windows下的服务是否启动(dhcp,net服务)

1)查看虚拟网络编辑器

2)修改ip地址

3)查看网关

5.2 配置网络ip地址
0)查看当前ip基本语法:
[root@localhost /]# ifconfig

1)在终端命令窗口中输入(如果不是克隆的虚拟机可以跳过这一步)
[root@localhost /]#vim /etc/udev/rules.d/70-persistent-net.rules

进入如下页面,删除eth0该行;将eth1修改为eth0,同时复制物理ip地址

2)修改IP地址
[root@localhost /]#vi /etc/sysconfig/network-scripts/ifcfg-eth0

需要修改的内容有5项:
IPADDR=192.168.1.3 设置静态的ip地址
GATEWAY=192.168.1.2 设置网关
ONBOOT=yes 表示使用etho这个网卡
BOOTPROTO=static 表示使用静态路由,dhcp是动态路由协议
DNS1=8.8.8.8或者114.114.114.114 设置NDS域名解析服务器
DEVICE=eth0 网卡名称
NETMASK=255.255.255.0 子网掩码配置

(1)修改前

(2)修改后,:wq 保存退出

3)执行service network restart重启网络
成功:

失败:

4)如果失败报错,reboot,重启虚拟机
5) 如果重启网络成功,则使用ifconfig命令,验证ip地址是否修改成功

5.3 配置主机名
0)查看主机名基本语法:
[root@localhost /]#hostname

1)修改linux的主机映射文件(hosts文件)
(1)进入Linux系统查看本机的主机名。通过hostname命令查看
[root@localhost ~]# hostname
localhost.localdomain
(2)如果感觉此主机名不合适,我们可以进行修改。通过编辑/etc/sysconfig/network文件
[root@localhost /]# vim /etc/sysconfig/network

将HOSTNAME选项配置我们想要的主机名node01

注意:主机名称不要有“_”下划线
(3)保存退出。
(4)打开/etc/hosts,对ip地址和主机名做映射
[root@localhost /]# vim /etc/hosts
添加如下内容:
192.168.43.101 node01
(5)并重启设备,重启后,查看主机名,已经修改成功

(6)测试能否连接外网
[root@node01 /]# ping www.baidu.com
成功:

失败(则检查配置的网络的配置文件中单词等是否拼写错误):

测试虚拟机与宿主机之间双向通信
在宿主机:

在虚拟机:

2)修改window的主机映射文件(hosts文件)
(1)进入C:\Windows\System32\drivers\etc路径
(2)打开hosts文件并添加如下内容
192.168.43.101 node01
192.168.43.102 node02
192.168.43.103 node03
5.4 防火墙
1)基本语法:
service iptables status 查看防火墙状态
chkconfig iptables --list 查看防火墙开机启动状态
service iptables stop 临时关闭防火墙
chkconfig iptables off 关闭防火墙开机启动
chkconfig iptables on 开启防火墙开机启动

2)扩展
Linux系统有7个运行级别(runlevel)
运行级别0 系统停机状态,系统默认运行级别不能设为0,否则不能正常启动
运行级别1 单用户工作状态,root权限,用于系统维护,禁止远程登陆
运行级别2 多用户状态(没有NFS)
运行级别3 完全的多用户状态(有NFS),登陆后进入控制台命令行模式
运行级别4 系统未使用,保留
运行级别5 X11控制台,登陆后进入图形GUI模式
运行级别6 系统正常关闭并重启,默认运行级别不能设为6,否则不能正常启动
5.5 关机重启
在linux领域内大多用在服务器上,很少遇到关机的操作。毕竟服务器上跑一个服务是永无止境的,除非特殊情况下,不得已才会关机 。
正确的关机流程为:sync > shutdown > reboot > halt
1)基本语法:
(1)sync (功能描述:将数据由内存同步到硬盘中,场景:机器或计算重要)
(2)shutdown [选项] 时间
选项:
-h:关机
-r:重启
(3)halt (功能描述:关闭系统,等同于shutdown -h now 和 poweroff)
(4)reboot (功能描述:就是重启,等同于 shutdown -r now)

2)案例
(1)将数据由内存同步到硬盘中
[root@node01 /]#sync
(2)计算机将在10分钟后关机,并且会显示在登录用户的当前屏幕中
[root@node01 /]#shutdown -h 10 ‘This server will shutdown after 10 mins’
(3)立马关机
[root@node01 /]# shutdown -h now
(4)系统立马重启
[root@node01 /]# shutdown -r now
(5)重启(等同于 shutdown -r now)
[root@node01 /]# reboot
(6)关机(等同于shutdown -h now 和 poweroff)
[root@node01 /]#halt

注意:不管是重启系统还是关闭系统,首先要运行sync命令,把内存中的数据写到磁盘中。
5.6 找回root密码
重新安装系统吗?当然不用!进入单用户模式更改一下root密码即可。
1)重启Linux,见到下图,在3秒钟之内按下回车

2)三秒之内要按一下回车,出现如下界面

3)按下e键就可以进入下图

4)移动到下一行,再次按e键

5)移动到下一行,进行修改

修改完成后回车键,然后按b键进行重新启动进入系统

6)移动到下一行,进行修改

最终修改完密码,reboot一下即可。
六 远程登录
6.1 安装Xshell
Linux远程登录及相关工具介绍
Linux一般作为服务器使用,而服务器一般放在机房,你不可能在机房操作你的Linux服务器。这时我们就需要远程登录到Linux服务器来管理维护系统。
Linux系统中是通过SSH服务实现的远程登录功能,默认SSH服务端口号为 22。Window系统上 Linux 远程登录客户端有XShell,SecureCRT, Putty, SSH Secure Shell等

安装步骤
登录xshell官网,点击“DOWNLOAD”按钮,下载安装程序

这里需要填写一下用户信息,填写完成后点击“SUBMIT”提交。

下载完成后运行安装程序,授权这一步我们选择“Free for Home/School”(家庭、校园免费版)即可。

同意使用协议,点击“Next”

选择安装路径,点击“Next”

选择语言,默认是简体中文,也可以选择英文,点击“Install”,等待安装完成。

运行xshell,建立一个新连接(以局域网内一台Centos主机为例)。点击菜单栏中的“新建”,打开新建会话窗口,在窗口右侧“连接”中填入会话名称及主机ip地址,点击“确定”。

连接会话:

输入‘root’用户名:

输入‘root’密码:

七 常用基本命令
7.1 帮助命令
7.1.1 man 获得帮助信息
1)基本语法:
man [命令或配置文件] 获得帮助信息
(1)显示说明

NAME 命令的名称和单行描述
SYNOPSIS 怎样使用命令
DESCRIPTION 命令功能的深入讨论
EXAMPLES 怎样使用命令的例子
SEE ALSO 相关主题(通常是手册页)

内容比较多,回车键或j或向下键(一行行的往下翻)、向上键或k(一行行的往上翻)、

(2)数字说明q
1.用户在shell环境中可以操作的命令或是可执行的文件
2.系统内核(kernel)可以调用的函数
3.常用的函数or函数库
4.设备配置文件
5.配置文件的格式
6.游戏相关
7.linux网络协议和文件系统
8.系统管理员可以用的命令
9.跟内核有关系的文件

2)案例
[root@hadoop106 home]# man ls
退出:q
7.1.2 help 获得shell内置命令的帮助信息
1)基本语法:
命令 --help 获得shell内置命令的帮助信息

2)案例:
[root@node01 bin]# help cd

7.1.3 常用快捷键
ctrl + c 停止进程
ctrl+l 清屏(等同于clear)
ctrl + q 退出
善于用tab键
上下键 查找执行过的命令
ctrl +alt linux和Windows之间切换
7.2 文件目录类
7.2.1 pwd 显示当前工作目录的绝对路径
1)基本语法:
pwd 显示当前工作目录的绝对路径

2)案例
[root@node01 home]# pwd
/home
7.2.2 ls 列出目录的内容
1)基本语法:
ls [选项] [目录或是文件]
-a 全部的文件,连同隐藏档( 开头为 . 的文件) 一起列出来(常用)
-l (ll) 长数据串列出,包含文件的属性与权限等等数据;(常用)
每行列出的信息依次是: 文件类型与权限 链接数 用户 用户组 文件大小用byte来表示 修改时间 文件名

2)案例
[root@node01 ~]# ls -l
total 96
-rw-------. 1 root root 3330 Jun 23 02:13 anaconda-ks.cfg
drwxr-xr-x. 3 root root 4096 Jun 23 04:51 Desktop
drwxr-xr-x. 2 root root 4096 Jun 23 02:20 Documents
drwxr-xr-x. 2 root root 4096 Jun 23 02:20 Downloads
-rw-r–r--. 1 root root 41364 Jun 23 02:12 install.log
-rw-r–r--. 1 root root 9154 Jun 23 02:10 install.log.syslog
drwxr-xr-x. 2 root root 4096 Jun 23 02:20 Music
drwxr-xr-x. 2 root root 4096 Jun 23 02:20 Pictures
drwxr-xr-x. 2 root root 4096 Jun 23 02:20 Public
drwxr-xr-x. 2 root root 4096 Jun 23 02:20 Templates
drwxr-xr-x. 2 root root 4096 Jun 23 02:20 Videos

7.2.3 mkdir 创建一个新的目录
1)基本语法:
mkdir [-p] 要创建的目录
-p 创建多层目录

2)案例
[root@node01 opt]# mkdir test
[root@node01 opt]# mkdir -p /opt/test1/word
7.2.4 rmdir 删除一个空的目录
1)基本语法:
rmdir 要删除的空目录
2)案例
[root@node01 opt]# mkdir test
[root@node01 opt]# rmdir test
7.2.5 touch 创建空文件
1)基本语法:
touch 文件名称
2)案例
[root@node01 opt]# touch test.java
7.2.6 cd 切换目录
1)基本语法:
cd 绝对路径
cd 相对路径
cd ~ 回到自己的家目录
cd - 回到上一次所在目录
cd … 回到当前目录的上一级目录
cd -P 跳转到实际物理路径,而非快捷方式路径,软连接中讲解

2)案例
(1)使用 mkdir 命令创建java目录
[root@node01 ~]# mkdir java
(2)使用绝对路径切换到java目录
[root@node01 ~]# cd /root/java/
(3)使用相对路径切换到java目录
[root@node01 ~]# cd ./java/
或者
[root@node01 ~]# cd java/
(4)表示回到自己的家目录,亦即是 /root 这个目录
[root@node01 java]# cd ~
(5)cd- 回到上一次所在目录
[root@node01 hello]# cd -
(6)表示回到当前目录的上一级目录,亦即是 /root 的上一级目录的意思;
[root@node01 ~]# cd …
7.2.7 cp 复制文件或目录
1)基本语法:
cp source dest 复制source文件到dest
cp -r sourceFolder targetFolder 递归复制整个文件夹

2)案例
(1)复制文件
[root@node01 opt]# cp test.java test
(2)递归复制整个文件夹
[root@node01 opt]# cp -r test test1
7.2.8 rm 移除文件或目录
1)基本语法:
rmdir deleteEmptyFolder 删除空目录
rm -f deleteFile 删除文件
rm -rf deleteFolderAndFile 递归删除目录及目录中所有内容

2)案例
1)删除空目录
[root@node01 opt]# rmdir test
2)递归删除目录及目录中所有内容
[root@node01 opt]# rm -rf test1
7.2.9 mv 移动文件与目录或重命名
1)基本语法:
mv oldNameFile newNameFile 重命名
mv /temp/movefile /targetFolder 递归移动文件

2)案例:
1)重命名
[root@node01 opt]# mv test.java test1.java
2)移动文件
[root@node01 opt]# mv test1.java test1
7.2.10 cat 查看文件内容
查看文件内容,从第一行开始显示。
1)基本语法
cat [选项] 要查看的文件
-A 相当于 -vET 的整合选项,可列出一些特殊字符而不是空白而已;
-b 列出行号,仅针对非空白行做行号显示,空白行不标行号!
-E 将结尾的断行字节 $ 显示出来;
-n 列出行号,连同空白行也会有行号,与 -b 的选项不同;
-T 将 [tab] 按键以 ^I 显示出来;
-v 列出一些看不出来的特殊字符

2)案例:
[hello@node01 ~]$ cat -A test.txt
hellda $
dasadf ^I$
daII^I$
das$

3)面试题:查看CentOS版本命令
[root@node01 桌面]$ cat /etc/redhat-release
CentOS release 6.5 (Final)
7.2.11 tac查看文件内容
查看文件内容,从最后一行开始显示,可以看出 tac 是 cat 的倒著写。
1)基本语法:
tac [选项参数] 要查看的文件
2)案例
[root@node01 test1]# cat test1.java
hello
you
He

[root@node01 test1]# tac test1.java
heloo1
hello2
hello3
7.2.12 more 查看文件内容
查看文件内容,一页一页的显示文件内容。
1)基本语法:
more 要查看的文件

2)功能使用说明:
空白键 (space) 代表向下翻一页
Enter 代表向下翻『一行』
:q 代表立刻离开 more ,不再显示该文件内容。
Ctrl+F 向下滚动一屏 F(follow 后面的)
Ctrl+B 返回上一屏 B(back 返回)
:= 输出当前行的行号
:f 输出文件名和当前行的行号

3)案例
[root@node01 test1]# more test1.java
7.2.13 less 查看文件内容
less 的作用与 more 十分相似,都可以用来浏览文字档案的内容,不同的是 less 允许使用[pageup] [pagedown]往回滚动。
1)基本语法:
less 要查看的文件
2)功能使用说明
空白键 向下翻动一页
Ctrl+F 向下滚动一屏 F(follow 后面的)
Ctrl+B 返回上一屏 B(back 返回)
:[pagedown] 向下翻动一行;
:[pageup] 向上翻动一行;
:/字串 向下搜寻『字串』的功能;n:向下查找;N:向上查找;
:?字串 向上搜寻『字串』的功能;n:向上查找;N:向下查找;
:q 离开 less 这个程序

3)案例
[root@node01 test1]# less test1.java
7.2.14 head查看文件内容
查看文件内容,只看头几行。
1)基本语法
head -n 10 文件 查看文件头10行内容,10可以是任意行数
head -10 文件 查看文件头10行内容,10可以是任意行数

2)案例
[root@node01 test1]# head -n 2 test1.java
hello
you
7.2.15 tail 查看文件内容
查看文件内容,只看尾巴几行。
1)基本语法
tail -n 10 文件 查看文件最后10行内容,10可以是任意行数
tail -f 文件 实时追踪该文档的所有更新,当文件改名或被删除,追踪停止,等同于–follow=descriptor,默认是打印最后10行
tail -F 文件 实时追踪该文档的所有更新,该文件被删除或改名后,如果再次创建相同的文件名,会继续追踪,等同于–follow=name --retry,默认是打印最后10行

2)案例
(1)查看文件头1行内容
[root@node01 test1]# tail -n 1 test1.java
haha
(2)实时追踪该档的所有更新
[root@node01 test1]# tail -F test1.java
hello
you
he
7.2.16 重定向命令
1)基本语法:
ls -l >文件 列表的内容写入文件a.txt中(覆盖写)
ls -al >>文件 列表的内容追加到文件aa.txt的末尾

2)案例
[root@node01 opt]# ls -l>t.txt
[root@node01 opt]# ls -l>>t.txt
[root@node01 test1]# echo hello>>test1.java
7.2.17 echo 回写命令
1)基本语法:
echo 要显示的内容 >> 存储内容的的文件 将要显示的内容,存储到文件中
echo 变量 显示变量的值

2)案例
[root@node01 test1]# echo $JAVA_HOME
/opt/module/jdk1.8.0_144
7.2.18 ln软链接
可以当成是windos下的“快捷方式”,将软件安装目录中的启动脚本在桌面创建快捷方式同样可以启动软件。
1)基本语法:
注意:创建软链接的时候原文件和目标文件最好使用绝对路径

ln -s [原文件] [目标文件] 给原文件创建一个软链接,软链接存放在目标文件目录,-s是soft的意思
ln –s [原目录] [目标目录] 给原目录创建一个软链接,软链接存放在目标目录,-s是soft的意思
rm -f aaa.txt 删除文件软链接
rm -rf aa,而不是rm -rf aa/ 删除目录软链接

2)案例:
①创建一个文件软链接
[root@node01 test1]# ln -s /opt/test1/test1.txt /opt/
[root@node01 opt]# ll
lrwxrwxrwx 1 root root 20 Jun 26 11:10 test1.txt -> /opt/test1/test1.txt
[root@node01 opt]# cat test1.txt
Hello

②创建一个目录软链接
[root@node01 test2]# ln -s /opt/test2/test3/ /opt/test1/
[root@node01 test1]# ll
lrwxrwxrwx 1 root root 17 Jun 26 11:14 test3 -> /opt/test2/test3/

cd不加参数进入是软链接的地址
[root@node01 test1]# cd test3
[root@node01 test3]# pwd
/opt/test1/test3

cd加参数(-P)进入是实际的物理地址
[root@node01 test1]# cd -P test3
[root@node01 test3]# pwd
/opt/test2/test3
7.2.19 ln 硬链接
可以当成是windos下的“快捷方式”,将软件安装目录中的启动脚本在桌面创建快捷方式同样可以启动软件。
1)基本语法:
注意:创建硬链接的时候原文件和目标文件都使用绝对路径;
ln [原文件] [目标文件] 给原文件创建一个硬链接,软链接存放在目标文件目录
rm -rf aa,而不是rm -rf aa/ 删除硬链接;硬链接相当于对原文件内容进行了复制,当删除原文件的时候,硬链接文件。

7.2.20 history查看所有命令历史
1)基本语法:
history
2)案例
[root@node01 test1]# history
7.3 时间日期类
1)基本语法
date [OPTION]… [+FORMAT]
7.3.1 date显示当前时间
1)基本语法:
date 显示系统当前时间
date +%Y 显示当前年份
date +%m 显示当前月份
date +%d 显示当前是哪一天
date +%Y%m%d 显示当前年月日各种格式
date "+%Y-%m-%d %H:%M:%S 显示年月日时分秒 ,必须要加双引号(在命令行中,如果一个参数中间包含有空格,那么必须加双引号,否则系统会当做两个参数进行处理)

2)案例
[root@node01 /]# date
2017年 06月 19日 星期一 20:53:30 CST
[root@node01 /]# date +%Y%m%d
20170619
[root@node01 /]# date “+%Y-%m-%d %H:%M:%S”
2017-06-19 20:54:58
7.3.2 date显示非当前时间
1)基本语法:
date -d ‘1 days ago’ 显示前一天日期
date -d yesterday +%Y%m%d
date -d next-day +%Y%m%d 显示明天日期
date -d ‘next monday’ 显示下周一时间

2)案例:
[root@node01 /]# date -d ‘1 days ago’
2017年 06月 18日 星期日 21:07:22 CST
[root@node01 /]# date -d next-day +%Y%m%d
20170620
[root@node01 /]# date -d ‘next monday’
2017年 06月 26日 星期一 00:00:00 CST
7.3.3 date设置系统时间
1)基本语法:
date -s 字符串时间
2)案例
[root@hadoop106 /]# date -s “2017-06-19 20:52:18”
[root@uek ~]# date -s “2018-08-07”
2018年 08月 07日 星期二 00:00:00 CST
[root@uek ~]# date -s “2018-08-07 09:44:00”
2018年 08月 07日 星期二 09:44:00 CST
7.3.4 cal查看日历
1)基本语法:
cal [选项] 不加选项,显示本月日历
-3 显示系统前一个月,当前月,下一个月的日历,以当前月为中心具体某一年,显示这一年的日历。
2)案例:
[root@node01 /]# cal
[root@node01 /]# cal -3
[root@node01 /]# cal 2016
7.4 用户管理命令
运维人员必掌握;

当linux系统安装时,系统自带一个默认的linux超级管理员用户:root. 当登录进入linxu系统之后,命令行界面显示:
[root@node1 ~]#
Root : 用户名;
Node1 : 主机名;
~ : 当前所在目录名称;也代表用户主目录;([root@node5 ~]# pwd /root)

:当前用户属于root用户(什么时候使用root用户?在对系统进行配置管理时,需要使用root用户);如果此处是$ ,代表普通用户,普通用户是没有root的超级管理员权限的;

7.4.1 useradd 添加新用户
1)基本语法:
useradd 用户名 添加新用户

2)案例:
[root@node01 opt]# adduser rwd

7.4.2 passwd 设置用户密码
1)基本语法:
passwd 用户名 设置用户密码

2)案例
[root@node01 opt]# passwd rwd
7.4.3 id 判断用户是否存在
1)基本语法:
id 用户名
2)案例:
[root@node01 opt]#id rwd
7.4.4 su 切换用户
1)基本语法:
su 用户名称 切换用户,只能获得用户的执行权限,不能获得环境变量
su - 用户名称 切换到用户并获得该用户的环境变量及执行权限
2)案例
[root@node01 opt]#su rwd
[root@node01 opt]#su - rwd
7.4.5 userdel 删除用户
1)基本语法:
userdel 用户名 删除用户但保存用户主目录(home目录下)
userdel -r 用户名 用户和用户主目录,都删除
注意:如果删除的用户正在被占用则,则会提示:
userdel: user rwd is currently logged in
解决方法:退出该用户,使用exit命令退出

2)案例:
(1)删除用户但保存用户主目录
[root@node01 opt]#userdel rwd
(2)删除用户和用户主目录,都删除
[root@node01 opt]#userdel -r rwd
7.4.6 who 查看登录用户信息
1)基本语法
whoami 显示自身用户名称
who am i 显示登录用户的用户名
who 看当前有哪些用户登录到了本台机器上

2)案例
[root@node01 opt]# whoami
[root@node01 opt]# who am i
[root@node01 opt]# who
7.4.7 设置rwd普通用户具有root权限
1)修改配置文件(使用root用户修改)
修改 /etc/sudoers 文件,找到下面一行,在root下面添加一行,如下所示:

Allow root to run any commands anywhere

root ALL=(ALL) ALL
rwd ALL=(ALL) ALL
保存退出的时候:wq
提示:E45: ‘readonly’ option is set (add ! to override)
解决办法:强制保存退出:wq!
或者配置成采用sudo命令时,不需要输入密码

Allow root to run any commands anywhere

root ALL=(ALL) ALL
rwd ALL=(ALL) NOPASSWD:ALL
修改完毕,现在可以用rwd帐号登录,然后用命令 sudo ,即可获得root权限进行操作。
Sudo 命令 : 普通用户操作root用户权限的命令;

2)案例
[rwd@node01 opt]$ sudo mkdir module
[root@node01 opt]# chown hello:hello module/
7.4.8 cat /etc/passwd 查看创建了哪些用户
cat /etc/passwd
7.4.9 usermod修改用户
一个用户组下,可以包含有多个用户;
讲完“用户组管理命令”部分讲解
1)基本语法:
usermod -g 用户组 用户名
2)案例:
将用户rwd加入bigdata用户组
[root@node01 opt]#usermod -g bigdata rwd
7.5 用户组管理命令
每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同Linux 系统对用户组的规定有所不同,
如Linux下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。
用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对/etc/group文件的更新。
7.5.1 groupadd 新增组
1)基本语法
groupadd 组名
2)案例:
添加一个javaweb组
[root@node01 opt]#groupadd javaweb
7.5.2 groupdel删除组
1)基本语法:
groupdel 组名
2)案例
[root@node01 opt]# groupdel rwd
[root@node01 opt]# userdel rwd
[root@node01 opt]# groupdel rwd

[root@node01 ~]# groupdel rwd
提示:groupdel: cannot remove the primary group of user ‘rwd’
解决办法:先删除用户rwd再删除用户组rwd
7.5.3 groupmod修改组
1)基本语法:
groupmod -n 新组名 老组名
2)案例
修改javaweb组名称为bigdata
[root@node01 hello]# groupmod -n bigdata javaweb
7.5.4 cat /etc/group 查看创建了哪些组
cat /etc/group
7.5.5 综合案例
[root@node01 opt]# groupadd javaweb
[root@node01 opt]# groupmod -n bigdata javaweb
[root@node01 opt]# usermod -g bigdata rwd
[root@node01 opt]# su rwd
[rwd@node01 ~]$ mkdir hello
[rwd@node01 ~]$ ls -l
[root@node01 hello]# usermod -g rwd rwd
7.6 文件权限类
2.5 文件
举例:
-rw-r–r--. 1(文件硬连接的次数) root(文件的拥有者) root(拥有者所属的用户组) 23732(文件内容大小) Feb 2 23:06(文件创建的时间) install.log (文件名)
文件类型:
在Linux系统中,文件类型(常见三种类型):
1)文件

2)目录(类似windows下的文件夹)
d
3)连接(类似windows下的快捷方式)
l

案例:
drwxr-xr-x :d(文件类型:目录)
-rw-r–r-- : -(文件类型:文件)
lrw-r–r-- : l(文件类型:链接文件)

文件权限:
1)可读 r read
2)可写 w write
3)可执行(脚本,shell脚本)x executor
4)特殊字符 - 表示没有任何权限;
权限的数字表示方式:以二进制数字之和的方式表示;
R W X
2^2=4 2^1=2 2^0=1
举例:rw-(拥有者的权限) rw-(同组下其他用户的权限) r–(不同组下其他用户权限)
4+2 4+2 4 以数字的方式表示:664
文件的归属:
1)拥有者 owner u
2)属于组 group g
3)其他用户 other o

-rw-r–r--. 1 root root 5890 Feb 2 23:04 install.log.syslog
drwxr-xr-x. 3 root root 4096 Feb 4 09:35 workerSpace

第一部分:-rw-r–r--
十个字符,代表不同含义:- rw- r-- r–
第一个字符:表示文件的类型;
后面九个字符,分为三组,表示此文件针对的不同用户的权限关系;
为什么是三组?
一个文件对于用户,包含三个部分;
1)拥有者 rwx
2)拥有者所属的组 rwx
3)其他用户 r-- (只用读的权限)

第二部分: root root
第一个字符串表示文件的拥有者;
第二个字符串表示文件的所属组;

第三部分:文件的内容大小;
第四部分:文件的创建时间;

案例:
d r-x r-- --x : 目录 ,
r-x :当前用户对于该文件有读和执行的权限,没有写的权限;
r-- :和当前用户在一个组内的其他用户,对于该文件有读的权限,没有写和执行权限;
–x :和当前用户不在一个组内的其他用户,对于该文件只有执行的权限,没有读和写的权限;
–w-r-xr-- : 文件
lr-x—r-- : 硬链接
–wxrw–w-: 文件

2.6 文件权限操作:
Chmod
需要使用root用户设置文件对不同用户的权限:
举例:
对于同组用户来说,仅仅可读;对于其他用户来说,即不可读也不可写。
#chmod g-w xxx.txt
#chmod o-r xxx.txt

数字形式:
#chmod 664 xxx.txt
#chmod 777 xxx.txt (全部权限)

改变文件的拥有者:

chown 拥有者 文件名

改变文件的所属组:

chgrp 所属组 文件名

当对于目录设置权限,并且目录下有很多文件,也需要同样的文件权限:
-R (recursive) 递归
#chmod -R rwx(664) 目录名

案例:
将xxx.txt 文件的拥有者和所属组设置为shi用户和shi组
#chmod shi:shi xxx.txt

7.6.1 文件属性
Linux系统是一种典型的多用户系统,不同的用户处于不同的地位,拥有不同的权限。为了保护系统的安全性,Linux系统对不同的用户访问同一文件(包括目录文件)的权限做了不同的规定。在Linux中我们可以使用ll或者ls –l命令来显示一个文件的属性以及文件所属的用户和组。

1)从左到右的10个字符表示:
如果没有权限,就会出现减号[ - ]而已。从左至右用0-9这些数字来表示:

(1)0首位表示类型
在Linux中第一个字符代表这个文件是目录、文件或链接文件等等

  • 代表文件
    d 代表目录
    c 字符流,装置文件里面的串行端口设备,例如键盘、鼠标(一次性读取装置)
    s socket
    p 管道
    l 链接文档(link file);
    b 设备文件,装置文件里面的可供储存的接口设备(可随机存取装置)

(2)第1-3位确定属主(该文件的所有者)拥有该文件的权限。—User

(3)第4-6位确定属组(所有者的同组用户)拥有该文件的权限,—Group

(4)第7-9位确定其他用户拥有该文件的权限 —Other

文件类型 属主权限 属组权限 其他用户权限
0 1 2 3 4 5 6 7 8 9
d r w x r - x r - x
目录文件 读 写 执行 读 写 执行 读 写 执行

2)rxw作用文件和目录的不同解释
(1)作用到文件:
[ r ]代表可读(read) 可以读取,查看
[ w ]代表可写(write) 可以修改,但是不代表可以删除该文件,删除一个文件的前提条件是对该文件所在的目录有写权限,才能删除该文件
[ x ]代表可执行(execute) 可以被系统执行

(2)作用到目录:
[ r ]代表可读(read) 可以读取,ls查看目录内容
[ w ]代表可写(write) 可以修改,目录内创建+删除+重命名目录
[ x ]代表可执行(execute) 可以进入该目录

3)案例
[hello@node01 ~]$ ls -l
总用量 8
drwxrwxr-x. 2 root root 4096 5月 27 14:14 hello
-rw-rw-r–. 1 root root 34 5月 27 14:20 test.txt

(1)如果查看到是文件:链接数指的是硬链接个数。创建硬链接方法
ln [原文件] [目标文件]
硬链接使用的比较少,因为相当于对数据做了备份,而在一台机器上做备份如果这台机器宕掉,做备份是没有效果的。
[root@node01 opt]# ln sunhouzi/shz.txt ./shz.txt
(2)如果查看的是目录:链接数指的是子目录个数(包括该目录下的隐藏目录)。
[root@node01 opt]# ls -al hello/
总用量 8
drwxr-xr-x. 2 root root 4096 9月 3 19:02 .
drwxr-xr-x. 5 root root 4096 9月 3 21:21 …
注释:. 关联的是当前目录的个数;…关联的是上一级目录的个数
7.6.2 chmod改变权限
1)基本语法:
chmod [{ugoa}{±=}{rwx}] [文件或目录] [mode=421 ] [文件或目录]

2)功能描述
改变文件或者目录权限
文件: r-查看;w-修改;x-执行文件
目录: r-列出目录内容;w-在目录中创建和删除;x-进入目录
删除一个文件的前提条件:该文件所在的目录有写权限,你才能删除该文件。

3)案例
[root@node01 test1]# chmod u+x test1.java
[root@node01 test1]# chmod g+x test1.java
[root@node01 test1]# chmod o+x test1.java
[root@node01 test1]# chmod 777 test1.java
[root@node01 test1]# chmod -R 777 testdir
7.6.3 chown改变所有者
1)基本语法:
chown [-R][最终用户] [文件或目录] 修改文件或者目录的所有者,-R递归修改
chown 文件所属用户:文件所属用户组 修改的文件
chown -R 文件所属用户:文件所属用户组 修改的目录
2)案例
[root@node01 opt]# chown rwd:rwd aaa.txt
[root@node01 opt]# chown -R rwd:rwd haha
[root@node01 opt]# chown rwd:rwd aaa.txt
[root@node01 opt]# ll
-rw-r–r-- 2 rwd rwd 9 Jun 25 09:53 aaa.txt
修改前:
[root@node01 opt]# ll
drwxr-xr-x 2 root root 4096 Jun 25 09:54 test
修改后
[root@node01 opt]# chown -R rwd:rwd test/
[root@node01 opt]# ll -r
drwxr-xr-x 2 rwd rwd 4096 Jun 25 09:54 test
-rw-r–r-- 2 rwd rwd 9 Jun 25 09:53 aaa.txt
7.6.4 chgrp改变所属组
1)基本语法:
chgrp [最终用户组] [文件或目录] 改变文件或者目录的所属组

2)案例:
[root@node01 opt]# chgrp root test/
[root@node01 opt]# ll
drwxr-xr-x 2 rwd root 4096 Jun 25 09:54 test
7.6.5 su 切换用户
1)基本语法:
su username 切换用户

2)案例
[root@node01 opt]# su rwd
[rwd@node01 ~]$
[rwd@node01 ~]$ su root
密码:
[root@node01 opt]#
7.7 磁盘分区类
7.7.1 fdisk查看分区
1)基本语法:
注意:在root用户下才能使用
fdisk -l 查看磁盘分区详情
2)功能说明(了解):
(1)Linux分区
这个硬盘是42.9G的,有255个磁面;63个扇区;5221个磁柱;每个 cylinder(磁柱)的容量是 8225280 bytes=8225.280 K(约为)=8.225280M(约为);
Device Boot Start End Blocks Id System
分区序列 引导 从X磁柱开始 到Y磁柱结束 容量 分区类型ID 分区类型
(2)Win7分区

3)案例
[root@node01 /]# fdisk -l
Disk /dev/sda: 42.9 GB, 42949672960 bytes
255 heads, 63 sectors/track, 5221 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x00068807
Device Boot Start End Blocks Id System
/dev/sda1 * 1 39 307200 83 Linux
Partition 1 does not end on cylinder boundary.
/dev/sda2 39 543 4046848 82 Linux swap / Solaris
Partition 2 does not end on cylinder boundary.
/dev/sda3 543 5222 37587968 83 Linux
7.7.2 df查看硬盘
1)基本语法:
df 参数 列出文件系统的整体磁盘使用量,检查文件系统的磁盘空间占用情况
-a 列出所有的文件系统,包括系统特有的 /proc 等文件系统;
-k 以 KBytes 的容量显示各文件系统;
-m 以 MBytes 的容量显示各文件系统;
-h 以人们较易阅读的 GBytes, MBytes, KBytes 等格式自行显示;
-H 以 M=1000K 取代 M=1024K 的进位方式;
-T 显示文件系统类型,连同该 partition 的 filesystem 名称 (例如 ext3) 也列出;
-i 不用硬盘容量,而以 inode 的数量来显示

2)案例
[root@node01 ~]# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/sda2 15G 3.5G 11G 26% /
tmpfs 939M 224K 939M 1% /dev/shm
/dev/sda1 190M 39M 142M 22% /boot
7.7.3 mount/umount挂载/卸载
对于Linux用户来讲,不论有几个分区,分别分给哪一个目录使用,它总归就是一个根目录、一个独立且唯一的文件结构
Linux中每个分区都是用来组成整个文件系统的一部分,它在用一种叫做“挂载”的处理方法,它整个文件系统中包含了一整套的文件和目录,并将一个分区和一个目录联系起来,要载入的那个分区将使它的存储空间在这个目录下获得。
挂载:在光驱上插入一张光盘叫挂载
卸载:拔掉光盘叫卸载

0)挂载前准备(必须要有光盘或者已经连接镜像文件)

1)挂载光盘语法:
mount [-t vfstype] [-o options] device dir

(1)-t vfstype 指定文件系统的类型,通常不必指定。mount 会自动选择正确的类型。
常用类型有:
光盘或光盘镜像:iso9660
DOS fat16文件系统:msdos
Windows 9x fat32文件系统:vfat
Windows NT ntfs文件系统:ntfs
Mount Windows文件网络共享:smbfs
UNIX(LINUX) 文件网络共享:nfs

(2)-o options 主要用来描述设备或档案的挂接方式。常用的参数有:
loop:用来把一个文件当成硬盘分区挂接上系统
  ro:采用只读方式挂接设备
  rw:采用读写方式挂接设备(常用)
iocharset:指定访问文件系统所用字符集

(3)device 要挂接(mount)的设备
(4)dir设备在系统上的挂接点(mount point)

2)案例
(1)光盘镜像文件的挂载
[root@node01 ~]# cd /mnt/
[root@node01 ~]# mkdir /mnt/cdrom/ 提前创建挂载点
[root@node01 ~]# mount -t iso9660 /dev/cdrom /mnt/cdrom/ 设备/dev/cdrom挂载到挂载点 : /mnt/cdrom中
显示挂载成功,只读:mount: block device /dev/sr0 is write-protected, mounting read-only
如果还想写的话:‘mount -o remount,rw /dev/cdrom /mnt/cdrom’命令
[root@node01 ~]# ll /mnt/cdrom/

3)卸载光盘语法:
[root@node01 ~]# umount 设备文件名或挂载点
提示:umount: /mnt/cdrom: device is busy.
(In some cases useful info about processes that use
the device is found by lsof(8) or fuser(1))
显示设备正在被使用。
解决办法:cd… 退出挂载的目录

4)案例
[root@node01 ~]# umount /mnt/cdrom
[root@node01 ~]# cd /mnt/cdrom

5)开机自动挂载语法:
[root@node01 ~]# vi /etc/fstab
添加红框中内容,保存退出。

7.8 搜索查找类
7.8.1 find 查找文件或者目录
1)基本语法:
find [搜索范围] [匹配条件]
2)案例
(1)按文件名:根据名称查找/目录下的filename为.txt结尾的文件。
[root@node01 ~]# find /opt/ -name *.txt
(2)按拥有者:查找/opt目录下,用户名称为-user的文件
[root@node01 ~]# find /opt/ -user root
(3)按文件大小:在/home目录下查找大于200m的文件(+n 大于 -n小于 n等于)
[root@node01 ~]find /home -size +204800
7.8.2 grep 过滤查找及“|”管道符
0)管道符,“|”,表示将前一个命令的处理结果输出传递给后面的命令处理
1)基本语法
grep+参数+查找内容+源文件
参数(了解即可):
-c:只输出匹配行的计数。
-I:不区分大小写(只适用于单字符)。
-h:查询多文件时不显示文件名。
-l:查询多文件时只输出包含匹配字符的文件名。
-n:显示匹配行及行号。
-s:不显示不存在或无匹配文本的错误信息。
-v:显示不包含匹配文本的所有行。

2)案例
[root@node01 opt]# ll | grep hadoop
drwxr-xr-x 10 10021 10021 4096 May 19 04:59 hadoop
drwxr-xr-x 6 root root 4096 May 19 09:10 hadoop-repo
[root@node01 opt]# ls | grep -n haoop
drwxr-xr-x 10 10021 10021 4096 May 19 04:59 hadoop
drwxr-xr-x 6 root root 4096 May 19 09:10 hadoop-repo
7.8.3 which 文件搜索命令
1)基本语法:
which 命令 搜索命令所在目录及别名信息
2)案例
[root@node01 opt]# which ls
/bin/ls
7.9 进程线程类
进程是正在执行的一个程序或命令,每一个进程都是一个运行的实体,都有自己的地址空间,并占用一定的系统资源。
7.9.1 ps查看系统中所有进程
1)基本语法:
ps -aux 查看系统中所有进程

2)功能说明:
USER 该进程是由哪个用户产生的
PID 进程的ID号
%CPU 该进程占用CPU资源的百分比,占用越高,进程越耗费资源;

%MEM 该进程占用物理内存的百分比,占用越高,进程越耗费资源;
VSZ 该进程占用虚拟内存的大小,单位KB;---->例如执行函数开辟的虚拟内存

RSS 该进程占用实际物理内存的大小,单位KB;
TTY 该进程是在哪个终端中运行的。其中tty1-tty7代表本地控制台终端,tty1-tty6是本地的字符界面终端,tty7是图形终端。pts/0-255代表虚拟终端。
STAT 进程状态。常见的状态有:R:运行、S:睡眠、T:停止状态、s:包含子进程、+:位于后台
START 该进程的启动时间
TIME 该进程占用CPU的运算时间,注意不是系统时间
COMMAND 产生此进程的命令名

3)案例
[root@node01 datas]# ps -aux

7.9.2 top查看系统健康状态
1)基本命令
top [选项]
退出top: q
(1)选项:
-d 秒数:指定top命令每隔几秒更新。默认是3秒在top命令的交互模式当中可以执行的命令:
-i:使top不显示任何闲置或者僵死进程。
-p:通过指定监控进程ID来仅仅监控某个进程的状态。

(2)操作选项(在top命令中使用):
P: 以CPU使用率排序,默认就是此项
M: 以内存的使用率排序
N: 以PID排序
q: 退出top

(3)查询结果字段解释
第一行信息为任务队列信息
内容 说明
12:26:46 系统当前时间
up 1 day, 13:32 系统的运行时间,本机已经运行1天
13小时32分钟
2 users 当前登录了两个用户
load average: 0.00, 0.00, 0.00 系统在之前1分钟,5分钟,15分钟的平均负载。一般认为小于1时,负载较小。如果大于1,系统已经超出负荷。
第二行为进程信息
Tasks: 95 total 系统中的进程总数
1 running 正在运行的进程数
94 sleeping 睡眠的进程
0 stopped 正在停止的进程
0 zombie 僵尸进程。如果不是0,需要手工检
查僵尸进程
第三行为CPU信息
Cpu(s): 0.1%us 用户模式占用的CPU百分比
0.1%sy 系统模式占用的CPU百分比
0.0%ni 改变过优先级的用户进程占用的CPU百分比
99.7%id 空闲CPU的CPU百分比
0.1%wa 等待输入/输出的进程的占用CPU百分比
0.0%hi 硬中断请求服务占用的CPU百分比
0.1%si 软中断请求服务占用的CPU百分比
0.0%st st(Steal time)虚拟时间百分比。就是当有虚拟机时,虚拟CPU等待实际CPU的时间百分比。
第四行为物理内存信息
Mem: 625344k total 物理内存的总量,单位KB
571504k used 已经使用的物理内存数量
53840k free 空闲的物理内存数量,我们使用的是虚拟机,总共只分配了628MB内存,所以只有53MB的空闲内存了
65800k buffers 作为缓冲的内存数量
第五行为交换分区(swap)信息
Swap: 524280k total 交换分区(虚拟内存)的总大小
0k used 已经使用的交互分区的大小
524280k free 空闲交换分区的大小
409280k cached 作为缓存的交互分区的大小

2)案例
[root@node01 opt]# top -d 1
[root@node01 opt]# top -i
[root@node01 hello]# top -p 2575
执行上述命令后,可以按P、M、N对查询出的进程结果进行排序。
7.9.3 pstree查看进程树
1)基本语法:
pstree [选项]
选项
-p: 显示进程的PID
-u: 显示进程的所属用户

2)案例:
[root@node01 datas]# pstree -u
[root@node01 datas]# pstree -p
7.9.4 kill终止进程
1)基本语法:
kill -9 pid进程号
选项
-9 表示强迫进程立即停止
2)案例:
①图形化界面打开浏览器,使用top查看,并使用M对进程按照使用内存大小排序,将使用内存最大的进程kill掉(杀死对应进程号),查看到浏览器被强行关闭。
②启动mysql程序
切换到root用户执行
[root@node01 桌面]# kill -9 5102
7.9.5 netstat显示网络统计信息
1)基本语法:
netstat -anp 此命令用来显示整个系统目前的网络情况。例如目前的连接、数据包传递数据、或是路由表内容
-an 按一定顺序排列输出
-p 表示显示哪个进程在调用
-nltp 查看tcp协议进程端口号

2)案例
查看端口50070的使用情况
[root@node01 opt]# netstat -anp | grep 50070
tcp 0 0 0.0.0.0:50070 0.0.0.0:* LISTEN 6816/java
端口号 进程号
7.9.6 前后台进程切换
1)基本语法:
fg %1 (功能描述:把后台进程转换成前台进程)
ctrl+z bg %1 (功能描述:把前台进程发到后台)
7.10 压缩和解压类
7.10.1 gzip/gunzip压缩
1)基本语法:
gzip+文件 压缩文件,只能将文件压缩为*.gz文件
gunzip+文件.gz 解压缩文件命令;

2)特点:
(1)只能压缩文件不能压缩目录
(2)不保留原来的文件

3)案例
(1)gzip压缩
[root@node01 opt]# ls
test.java
[root@node01 opt]# gzip test.java
[root@node01 opt]# ls
test.java.gz
(2)gunzip解压缩文件
[root@node01 opt]# gunzip test.java.gz
[root@node01 opt]# ls
test.java
7.10.2 zip/unzip压缩
1)基本语法:
zip + 参数 + XXX.zip + 将要压缩的内容 压缩文件和目录的命令,window/linux通用且可以压缩目录且保留源文件
-r 压缩目录

2)案例:
(1)压缩 1.txt 和2.txt,压缩后的名称为test.zip
[root@node01 opt]# zip test.zip aaa.txt bbb.txt
adding: aaa.txt (stored 0%)
adding: bbb.txt (stored 0%)
[root@node01 opt]# ls
test1.java test.java test.zip

(2)解压 test.zip
[root@node01 opt]# unzip test.zip
Archive: test.zip
extracting: aaa.java
extracting: bbb.java
[root@node01 opt]# ls
Aaa.txt bbb.txt test.zip

(3)解压test.zip到指定目录-d
[root@node01 opt]# unzip test.zip -d /opt
7.10.3 tar打包
1)基本语法:
tar + 参数 + XXX.tar.gz + 将要打包进去的内容 打包目录,压缩后的文件格式.tar.gz
-c 产生.tar打包文件
-v 显示详细信息
-f 指定压缩后的文件名
-z 打包同时压缩
-x 解包.tar文件

2)案例
(1)压缩:tar -zcvf XXX.tar.gz n1.txt n2.txt
压缩多个文件
[root@node01 opt]# tar -zcvf test.tar.gz aaa.txt bbb.txt
aaa.txt
bbb.txt
[root@node01 opt]# ls
aaa.txt bbb.txt test.tar.gz

压缩目录
[root@node01 opt]# tar -zcvf test.java.tar.gz test1
test1/
test1/hello
test1/test1.java
test1/test/
test1/test/test.java
[root@hadoop106 opt]# ls
test1 test.java.tar.gz

(2)解压:tar -zxvf XXX.tar.gz
解压到当前目录
[root@node01 opt]# tar -zxvf test.tar.gz
解压到/opt目录
[root@node01 opt]# tar -zxvf test.tar.gz -C /opt
7.11 后台服务管理类
7.11.1 service后台服务管理
service network status 查看指定服务的状态
service network stop 停止指定服务
service network start 启动指定服务
service network restart 重启指定服务
service --status-all 查看系统中所有的后台服务
7.11.2 chkconfig设置后台服务的自启配置
chkconfig 查看所有服务器自启配置
chkconfig iptables off 关掉指定服务的自动启动
chkconfig iptables on 开启指定服务的自动启动

7.12 crond系统定时任务
7.12.1 crond服务管理
[root@node01 ~]# service crond start (启动服务)

[root@node01 ~]# service crond stop (关闭服务)

[root@node01 ~]# service crond restart (重启服务)

[root@node01 ~]# service crond reload (重新载入配置)

查看crontab服务状态:
[root@node01 ~]# service crond status
7.12.2 crontab定时任务设置
1)基本语法
crontab [选项]
-e 编辑crontab定时任务
-l 查询crontab任务
-r 删除当前用户所有的crontab任务

2)参数说明
[root@node01 ~]# crontab -e

          • 命令
            进入crontab编辑界面。会打开vim编辑你的工作。
            corn从左到右(用空格隔开):分 小时 月份中的日期 月份 星期中的日期
          • 执行的任务
            项目 含义 范围
            第一个“” 一小时当中的第几分钟 0-59
            第二个“
            ” 一天当中的第几小时 0-23
            第三个“” 一个月当中的第几天 1-31
            第四个“
            ” 一年当中的第几月 1-12
            第五个“*” 一周当中的星期几 0-7(0和7都代表星期日)

(2)特殊符号
特殊符号 含义

  • 代表任何时间。比如第一个“*”就代表一小时中每分钟都执行一次的意思。
    , 代表不连续的时间。比如“0 8,12,16 * * * 命令”,就代表在每天的8点0分,12点0分,16点0分都执行一次命令
  • 代表连续的时间范围。比如“0 5 * * 1-6命令”,代表在周一到周六的凌晨5点0分执行命令
    /n 代表每隔多久执行一次。比如“/10 * * * * 命令”,代表每隔10分钟就执行一遍命令

(3)特定时间执行命令
时间 含义
45 22 * * * 命令 在22点45分执行命令
0 17 * * 1 命令 每周1 的17点0分执行命令
0 5 1,15 * * 命令 每月1号和15号的凌晨5点0分执行命令
40 4 * * 1-5 命令 每周一到周五的凌晨4点40分执行命令
*/10 4 * * * 命令 每天的凌晨4点,每隔10分钟执行一次命令
0 0 1,15 * 1 命令 每月1号和15号,每周1的0点0分都会执行命令。注意:星期几和几号最好不要同时出现,因为他们定义的都是天。非常容易让管理员混乱。

3)案例:
[root@node01 ~]#crontab -e
*/1 * * * * echo ”aaa” >> /opt/testLinux/testcrontab.txt
aaaa
aaaa
aaaa
aaaa
八 RPM
3.1软件安装的3种方式:
1、rpm包安装,国内rpm源/yum源:http://mirrors.aliyun.com
rpm 的特点:安装无法指定安装到哪里,是包的创建者在打包时指定
安装命令:
rpm
-i /path/to/package file 安装
-h 以#显示进度,每个#表示2%;
-v 显示详细过程
-vv 更详细的过程
-ql jdk | more 查看jak包在哪个目录下
-qa | grep jdk (查看系统有没有安装) (qa:代表所有的软件包)
rpm -ivh /path/to/package file (用这个)
–nodeps 忽略依赖关系;
–replacepkgs 重新安装,替换原有安装
–force 强行安装,可以实现重装或降级;
rpm -e package_name 卸载软件

2、源码编译安装:
最为复杂,因为开发者只提供了源码,没有编译,先要对源码进行编译,然后再安装,一般不使用该方式;
通常,开源的技术,都会提供已经对源码编译好的tar包,我们拿来直接解压安装即可;

解压:
tar包,解压方式:tar -zxvf tar包 tar -zxvf tar包 -C 指定目录
分别是四个参数
x : 从 tar 包中把文件提取出来
z : 表示 tar 包是被 gzip 压缩过的,所以解压时需要用 gunzip 解压
v : 显示详细信息
f xxx.tar.gz : 指定被处理的文件是 xxx.tar.gz

Zip包,解压方式:unzip -zxvf zip包

3、yum源
默认是centos的yum源,它是连接国外服务器来实现下载的。
位置:/etc/yum.repos.d/CentOS-Base.repo
[base]
name=CentOS- r e l e a s e v e r − B a s e m i r r o r l i s t = h t t p : / / m i r r o r l i s t . c e n t o s . o r g / ? r e l e a s e = releasever - Base mirrorlist=http://mirrorlist.centos.org/?release= releaseverBasemirrorlist=http://mirrorlist.centos.org/?release=releasever&arch=KaTeX parse error: Expected 'EOF', got '&' at position 9: basearch&̲repo=os #baseur…releasever/os/$basearch/
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6

#released updates
[updates]
name=CentOS- r e l e a s e v e r − U p d a t e s m i r r o r l i s t = h t t p : / / m i r r o r l i s t . c e n t o s . o r g / ? r e l e a s e = releasever - Updates mirrorlist=http://mirrorlist.centos.org/?release= releaseverUpdatesmirrorlist=http://mirrorlist.centos.org/?release=releasever&arch=KaTeX parse error: Expected 'EOF', got '&' at position 9: basearch&̲repo=updates #b…releasever/updates/$basearch/
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6

#additional packages that may be useful
[extras]
name=CentOS- r e l e a s e v e r − E x t r a s m i r r o r l i s t = h t t p : / / m i r r o r l i s t . c e n t o s . o r g / ? r e l e a s e = releasever - Extras mirrorlist=http://mirrorlist.centos.org/?release= releaseverExtrasmirrorlist=http://mirrorlist.centos.org/?release=releasever&arch=KaTeX parse error: Expected 'EOF', got '&' at position 9: basearch&̲repo=extras #ba…releasever/extras/$basearch/
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6

#additional packages that extend functionality of existing packages
[centosplus]
name=CentOS- r e l e a s e v e r − P l u s m i r r o r l i s t = h t t p : / / m i r r o r l i s t . c e n t o s . o r g / ? r e l e a s e = releasever - Plus mirrorlist=http://mirrorlist.centos.org/?release= releaseverPlusmirrorlist=http://mirrorlist.centos.org/?release=releasever&arch=KaTeX parse error: Expected 'EOF', got '&' at position 9: basearch&̲repo=centosplus…releasever/centosplus/$basearch/
gpgcheck=1
enabled=0
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6

#contrib - packages by Centos Users
[contrib]
name=CentOS- r e l e a s e v e r − C o n t r i b m i r r o r l i s t = h t t p : / / m i r r o r l i s t . c e n t o s . o r g / ? r e l e a s e = releasever - Contrib mirrorlist=http://mirrorlist.centos.org/?release= releaseverContribmirrorlist=http://mirrorlist.centos.org/?release=releasever&arch=KaTeX parse error: Expected 'EOF', got '&' at position 9: basearch&̲repo=contrib #b…releasever/contrib/$basearch/
gpgcheck=1
enabled=0
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6

国内rpm源/yum源:http://mirrors.aliyun.com(从阿里云下载Yum源)
1)创建本地yum源
目的:创建yum源仓库,让安装更加方便;
1)插入完整版的ISO文件到光驱;
缺点:rpm包有限,因为是光盘,只能读,不能写,无法添加rpm包;
解决办法:创建本地yum源库。从服务器上下载rpm包,放在本地指定的目录下:/home/mirrors/

2)在linux系统中,在添加新的磁盘时,需要先挂载才能正常使用;
mount /dev/cdrom /mnt/ (挂载后需要退出当前目录,重新进入该目录)
:mount 挂载,/dev/cdrom 软连接,设备中的光盘, /mnt/ 指定挂载光盘到哪个目录下
挂载后,注意检查; 然后进到 Packages下,ls,查看rpm文件

3)查看之后,回到 /etc/yum.repos.d/ 目录下,修改yum源的配置文件:/etc/yum.repos.d/Centos.Base.repo
[base] 只需要配置base源即可,把下面的各种注释掉或者直接删除
name=CentOS-KaTeX parse error: Expected 'EOF', got '#' at position 29: …Base 把网络连接注释掉: #̲mirrorlist=http…releasever&arch=$basearch&repo=updates
打开本地连接:修改成本地路径:
baseurl=file:///root/mirrors (file:// 代表访问的协议,后面为指定的路径)
gpgcheck=1
gpgkey=file:///root/mirrors/RPM-GPG-KEY-CentOS-6 (换成本地的,认证方式)
4)该目录下的其他yum配置文件删除;
5)清除缓存:yum clean all 创建缓存数据库: yum makecache

创建本地yum源库:
需要用到工具: yum-utils ; 安装工具: yum install -y yum-utils
在指定目录 /home/mirrors/ 下下载:
下载命令:reposync -r base(从配置的yum源中把rpm包下载到本地指定目录)

2)创建阿里云yum源
1、备份
mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup
2、下载新的CentOS-Base.repo 到/etc/yum.repos.d/
CentOS 5 (wget linux直接从互联网上下载数据的命令)
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-5.repo
CentOS 6
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-6.repo
CentOS 7
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
3、之后运行yum makecache生成缓存
3)创建局域网yum源
通过nginx搭建局域网yum源:

Yum命令:
yum search 软件名:查看本地yum源中有没有此软件;
yum info 软件名:查看已经安装的软件信息
Yum install 软件名 : 安装指定软件; Yum install -y 不需要确认,连同依赖包直接安装
yum remove 软件名 :卸载已安装软件;
Yum update 软件名:给软件升级,
yum update_to 软件名:升级到指定版本
yum grouplist :查看软件包信息
Yum groupinfo 软件包:查看软件包信息 yum groupinfo “web Server”
Yum groupinstall “web server” : 安装一个软件包
3.2 安装JDK:
第一种rpm包安装方式:
1)上传:
2)安装:
3)检查是否按照成功:
4)配置JDK坏境变量:
配置环境变量:系统启动时,会按照顺序加载文件,首先加载ETC下的profile,用户登录后加载BASH下的prifile;
配置环境变量命令:第一种:vi /etc/profile(系统全局配置文件)
第二种:vi ~/.bash_profile :(个人用户,用这个)
配置文件内容: export JAVA_HOME=/usr/java/default : 确保本机只装了一个JDK
export PATH= P A T H : PATH: PATH:JAVA_HOME/bin
配置完用:source ~/.bash_profile 让其加载 查看配置文件命令:printenv

第二种tar包安装方式:
1.上传jdk-7u45-linux-x64.tar.gz到Linux上
2.解压jdk到/usr/local目录
tar -zxvf jdk-7u45-linux-x64.tar.gz -C /usr/local/
3.设置环境变量,在/etc/profile文件最后追加相关内容
vi /etc/profile
export JAVA_HOME=/usr/local/jdk1.7.0_45
export PATH= P A T H : PATH: PATH:JAVA_HOME/bin
4.刷新环境变量
source /etc/profile
5.测试java命令是否可用
java -version
3.4 安装Tomcat
1.上传apache-tomcat-7.0.68.tar.gz到Linux上
2.解压tomcat
tar -zxvf apache-tomcat-7.0.68.tar.gz -C /usr/local/
3.启动tomcat
/usr/local/apache-tomcat-7.0.68/bin/startup.sh
4.查看tomcat进程是否启动
jps

5.查看tomcat进程端口
netstat -anpt | grep 2465
6.通过浏览器访问tomcat
http://192.168.0.101:8080/

3.5 安装MySQL
1.注意:yum install -y mysql-server (mysql 代表客户端,要用mysql-server)
2.启动:service mysqld start / stop
同时设置成开机启动:chkconfig mysqld on chkconfig mysqld --list
3.输入命令:mysql (调用客户端工具)
show databases; 查看有哪几个数据库
use mysql;使用mysql数据库
show tables; 显示表的元数据
select host,user from user;(查看用户信息,默认状态,只验证用户名,不验证密码,所以在一开始调mysql就直接可以进来)
4.修改mysql权限:把所用权限赋予root用户
grant all privileges on . to ‘root’@’%‘identified by ‘root’ with grant option;
select host,user from user;(在查看,此时root用户就有密码了)
5.把其他的root 用户删除,避免验证冲突: delete from user where host !=’%’;
6.刷新权限(flush privileges) 或重启服务;
7.验证:quit;
8.再敲:mysql;(会报错没有输入密码错误)
Mysql -u root -p ,然后输入密码;
Quit 暂时退出, mysql就准备好了!!!!

8.1 概述
RPM(RedHat Package Manager),Rethat软件包管理工具,类似windows里面的setup.exe
是Linux这系列操作系统里面的打包安装工具,它虽然是RedHat的标志,但理念是通用的。
RPM包的名称格式:
Apache-1.3.23-11.i386.rpm
“apache” 软件名称
“1.3.23-11”软件的版本号,主版本和此版本
“i386”是软件所运行的硬件平台
“rpm”文件扩展名,代表RPM包
8.2 常用命令
8.2.1 查询(rpm -qa)
1)基本语法:
rpm -qa 查询Linux系统所安装的所有rpm软件包
rpm -qa | grep rpm软件包
过滤

2)案例
[root@node01 Packages]# rpm -qa |grep firefox
firefox-45.0.1-1.el6.centos.x86_64
8.2.2 卸载(rpm -e)
1)基本语法:
rpm -e RPM软件包 卸载
rpm -e --nodeps RPM软件包 由于系统中各个软件包之间相互有依赖关系。如果因存在依赖关系而不能卸载,rpm将给予提示并停止卸载。你可以使用–nodeps的命令来忽略依赖关系,直接开始卸载
–nodeps 安装的时候,如果该RPM包的安装依赖其它包,即使其它包没装,也强迫安装。

2)案例
[root@node01 Packages]# rpm -e firefox-17.0.10-1.el6.centos.x86_64
8.2.3 安装(rpm -ivh)
1)基本语法:
rpm -ivh RPM包全名
-i=install,安装
-v=verbose,显示详细信息
-h=hash,进度条
–nodeps,不检测依赖进度

2)案例
首先挂载Centos6.5镜像到/mnt/cdrom目录,在挂载点目录下有Packages目录(存放centos6.5系统相关的一些rpm包)
[root@node01 Packages]# pwd
/mnt/cdrom/Packages
[root@node01 Packages]# rpm -ivh firefox-17.0.10-1.el6.centos.x86_64.rpm
warning: firefox-17.0.10-1.el6.centos.x86_64.rpm: Header V3 RSA/SHA1 Signature, key ID c105b9de: NOKEY
Preparing… ########################################### [100%]
1:firefox ########################################### [100%]
[root@node01 Packages]# rpm -qa | grep firefox
firefox-17.0.10-1.el6.centos.x86_64

九 Shell编程
9.1 概述
Shell是一个命令行解释器,它为用户提供了一个向Linux内核发送请求以便运行程序的界面系统级程序,用户可以用Shell来启动、挂起、停止甚至是编写一些程序。
一句话:Shell是用来连接应用级别的程序和硬件级别的程序

Shell还是一个功能相当强大的编程语言,易编写、易调试、灵活性强。Shell是解释执行的脚本语言,在Shell中可以调用Linux系统命令。
9.2 shell脚本的执行方式
1)echo输出内容到控制台
(1)基本语法:
echo [选项] [输出内容]
选项:
-e: 支持反斜线控制的字符转换(转义)
控制字符 作 用
\ 输出\本身
\a 输出警告音
\b 退格键,也就是向左删除键
\c 取消输出行末的换行符。和“-n”选项一致
\e ESCAPE键
\f 换页符
\n 换行符
\r 回车键
\t 制表符,也就是Tab键
\v 垂直制表符
\0nnn 按照八进制ASCII码表输出字符。其中0为数字零,nnn是三位八进制数
\xhh 按照十六进制ASCII码表输出字符。其中hh是两位十六进制数

(2)案例
[rwd@node01 sbin]$ echo “hello\world”
hello\world
[root@node01 ~]# echo -e ‘hello\tworld’
hello world
[root@node01 ~]# echo -e ‘\’
\

2)脚本格式
(1)脚本以 #!/bin/bash (严格方式) 或者 #!/bin/sh 开头
(2)脚本必须有可执行权限

3)第一个Shell脚本
(1)需求:创建一个Shell脚本,输出helloworld
(2)实操:
[root@node01 opt]$ touch helloworld.sh
[root@node01 opt]$ vim helloworld.sh

在helloworld.sh中输入如下内容
#!/bin/bash
echo “hello World”

4)脚本的常用执行方式:
第一种:输入脚本的绝对路径或相对路径
(1)首先要赋予helloworld.sh 脚本的+x权限
[root@node01 opt]# chmod 744 helloworld.sh
(2)执行脚本
相对路径执行:
[root@node01 opt]# ./helloworld.sh
Aaa

绝对路径执行:
[root@node01 opt]# /opt/helloworld.sh
aaa

第二种:bash或sh+脚本(不用赋予脚本+x权限)
[root@node01 opt]#sh /opt/helloworld.sh
[root@node01 opt]#sh helloworld.sh
[root@node01 opt]#bash /opt/helloworld.sh
[root@node01 opt]#bash helloworld.sh
9.3 shell中的变量
1)Linux Shell中的变量分为,系统变量和用户自定义变量。
2)系统变量: H O M E 、 HOME、 HOMEPWD、 S H E L L 、 SHELL、 SHELLUSER等等($表示获取(使用)变量)
3)显示当前shell中所有变量:set
[root@uek ~]# echo $HOME 获取用户家目录
/root
[root@uek ~]# echo $PWD 获取当前路径
/root
[root@uek ~]# echo $SHELL 获取当前shell接口
/bin/bash
9.3.1 定义变量
1)基本语法:
(1)定义变量:变量=值
(2)撤销变量:unset 变量
(3)声明静态变量:readonly变量,注意:不能unset

2)变量定义规则
(1)变量名称可以由字母、数字和下划线组成,但是不能以数字开头。
(2)等号两侧不能有空格
(3)变量名称一般习惯为大写

3)案例:
(1)定义变量A : A=8
echo $A :获取变量的值

(2)撤销变量A : unset A

(3)声明静态的变量B=2,不能修改,不能unset(bash: unset: B: cannot unset: readonly variable只读变量) : readonly B=2

(4)可把变量提升为全局环境变量,可供其他shell程序使用(hadoop中讲解):export 变量名
9.3.2 将命令的返回值赋给变量
A=ls -la : 反引号,运行里面的命令,并把结果返回给变量A
A=$(ls -la) :等价于反引号

9.3.3 设置环境变量
Hadoop中讲解
1)基本语法:
export 变量名=变量值 设置环境变量的值
source 配置文件 让修改后的配置信息立即生效
echo $变量名 查询环境变量的值

2)案例:
(1)在/etc/profile文件中定义JAVA_HOME环境变量
export JAVA_HOME=/opt/module/jdk1.8.0_144
export PATH= P A T H : PATH: PATH:JAVA_HOME/bin

(2)查看环境变量JAVA_HOME的值
[root@node01 datas]$ echo $JAVA_HOME
/opt/module/jdk1.8.0_144
9.3.4 位置参数变量
1)基本语法
$n n为数字,
$0代表命令本身,
$1- 9 代 表 第 一 到 第 九 个 参 数 , 十 以 上 的 参 数 , 十 以 上 的 参 数 需 要 用 大 括 号 包 含 , 如 9代表第一到第九个参数,十以上的参数,十以上的参数需要用大括号包含,如 9{10}
∗ 这 个 变 量 代 表 命 令 行 中 所 有 的 参 数 , * 这个变量代表命令行中所有的参数, *把所有的参数看成一个整体
@ 这 个 变 量 也 代 表 命 令 行 中 所 有 的 参 数 , 不 过 @ 这个变量也代表命令行中所有的参数,不过 @@把每个参数区分对待
$# 这个变量代表命令行中所有参数的个数

2)案例
(1)输出输入的的参数1,参数2,所有参数,参数个数
#!/bin/bash
echo “$0”
echo “$1”
echo “ 2 " e c h o " 2" echo " 2"echo"*”
echo “ @ " e c h o " @" echo " @"echo"#”
运行脚本:
[root@node01 opt]# bash test1.sh a b
test1.sh
a
b
a b
a b
2

(2) ∗ 与 *与 @的区别
#!/bin/bash
for i in "KaTeX parse error: Expected 'EOF', got '#' at position 5: *" #̲*中的所有参数看成是一个整体,所以这个for循环只会循环一次
do
echo “The parameters is: i " d o n e x = 1 f o r y i n " i" done x=1 for y in " i"donex=1foryin"@”
# @ 中 的 每 个 参 数 都 看 成 是 独 立 的 , 所 以 “ @中的每个参数都看成是独立的,所以“ @@”中有几个参数,就会循环几次
do
echo "The parameter$x is: y " x = y" x= y"x=(( x + 1 ) ) d o n e a ) x +1 )) done a) x+1))donea和$@都表示传递给函数或脚本的所有参数,不被双引号“”包含时,都以$1 2 … 2 … 2n的形式输出所有参数
b)当它们被双引号“”包含时,“$
”会将所有的参数作为一个整体,以“$1 2 … 2 … 2n”的形式输出所有参数;“$@”会将各个参数分开,以“$1” “ 2 ” … ” 2”…” 2n”的形式输出所有参数
9.3.5 预定义变量
1)基本语法:
$? 最后一次执行的命令的返回状态。如果这个变量的值为0,证明上一个命令正确执行;如果这个变量的值为非0(具体是哪个数,由命令自己来决定),则证明上一个命令执行不正确了。
$$ 当前进程的进程号(PID)
$! 后台运行的最后一个进程的进程号(PID)

2)案例
[root@node01 opt]#vim /opt/test2.sh
#!/bin/bash
echo “$KaTeX parse error: Expected 'EOF', got '&' at position 19: …/helloworld.sh &̲ echo "!”
echo “$?”

[root@node01 opt]# ./test2.sh
2643 —>当前进程的id
2644 —>最后一次执行的后台进程的id
0 —>最后一次命令执行的返回值,成功为0,失败为非0
[root@node01 opt]# aaa —>最后一次后台进程执行的结果
9.4 运算符
掌握一种即可
1)基本语法:
(1)“ ( ( 运 算 式 ) ) ” 或 “ ((运算式))”或“ (())[运算式]”
(2)expr m + n
注意expr运算符间要有空格
(3)expr m - n
(4)expr *, /, % 乘,除,取余

2)案例:计算(2+3)*4的值
(1)采用 ( ( 运 算 式 ) ) 和 ((运算式))和 (())[运算式]方式
[root@node01 opt]# S=$(((2+3)*4))
[root@node01 testLinux]# echo KaTeX parse error: Expected 'EOF', got '#' at position 23: …oot@node01 opt]#̲ S=[(2+3)*4]
[root@node01 opt]# echo $S
20

(2)expr分布计算
[root@node01 opt]# S=expr 2 + 3
[root@node01 opt]# echo $S
5
[root@node01 opt]# R=expr $S \* 4
[root@node01 opt]# echo $R
20

(3)expr一步完成计算
[root@node01 opt]#expr expr 2 + 3 * 4
20
9.5 条件判断
9.5.1 判断语句
1)基本语法:
[ condition ](注意condition前后要有空格,condition–>条件)
#非空返回true,空会返回false,可使用$?验证(0为true,非0为false)

2)案例:
[hello] 返回true
$?
0
[] 返回false
$?
1
[condition] && echo OK || echo notok 条件满足,执行后面的语句
9.5.2 常用判断条件
1)两个整数之间比较
= 字符串比较
-lt 小于
-le 小于等于
-eq 等于
-gt 大于
-ge 大于等于
-ne 不等于

2)按照文件权限进行判断
-r 有读的权限
-w 有写的权限
-x 有执行的权限

3)按照文件类型进行判断
-f 文件存在并且是一个常规的文件
-e 文件存在
-d 文件存在并是一个目录

4)案例
(1)23是否大于等于22 : [ 23 -ge 22 ]
(2)student.txt是否具有写权限 : [ -w student.txt ]
(3)/root/install.log目录中的文件是否存在 : [ -e /root/install.log ]
9.6 流程控制
9.6.1 if判断
1)基本语法:
if [ 条件判断式 ];then
程序
fi
或者
if [ 条件判断式 ]
then
程序
fi
注意事项:(1)[ 条件判断式 ],中括号和条件判断式之间必须有空格

3)案例
“判断输入的数是否等于123,是否等于456”
vim /opt/test3.sh
#!/bin/bash
if [ $1 -eq “123” ]
then
echo “123”
elif [ $1 -eq “456” ]
then
echo “456”
fi

[root@node01 opt]# ./test3.sh 123
123
[root@node01 opt]# ./test3.sh 456
456
9.6.2 case语句
1)基本语法:
case $变量名 in
“值1”)
如果变量的值等于值1,则执行程序1
;;
“值2”)
如果变量的值等于值2,则执行程序2
;;
…省略其他分支…
*)
如果变量的值都不是以上的值,则执行此程序
;;
esac

2)案例
vim /opt/test4.sh
!/bin/bash
case $1 in
“1”)
echo “1”
;;

“2”)
echo “2”
;;
*)
echo “other”
;;
esac

[root@node01 opt]# ./test4.sh 1
1
[root@node01 opt]# ./test4.sh 2
2
[root@node01 opt]# ./test4.sh 3
other
9.6.3 for循环
1)基本语法1:
for 变量 in 值1 值2 值3…
do
程序
done

2)案例:
(1)打印输入参数
vim /opt/test5.sh
#!/bin/bash
#打印数字

for i in " ∗ " d o e c h o " *" do echo " "doecho"i "
done

for j in “ @ " d o e c h o " @" do echo " @"doecho"j”
done

[root@node01 opt]# ./test5.sh 1 2 3 4
1 2 3 4
1
2
3
4

3)基本语法2:
for (( 初始值;循环控制条件;变量变化 ))
do
程序
done

4)案例
(1)从1加到100
vim /opt/test6.sh
#!/bin/bash
s=0
for((i=1;i<=100;i++))
do

s= [ [ [s + $i] 第一种

s= ( ( (( ((s + $i)) 第二种

     s=`expr $s + $i`  第三种

done
echo “$s”
[root@node01 opt]# ./test6.sh
5050
9.6.4 while循环
1)基本语法:
while [ 条件判断式 ]
do
程序
done

2)案例
(1)从1加到100
vim /opt/test7.sh
#!/bin/bash
s=0
i=1
while [ i − l e 100 ] d o s = i -le 100 ] do s= ile100]dos=[ s + s+ s+i]
i= [ [ [i+1]
done
echo $s
[root@node01 opt]# ./test7.sh
5050
9.7 read读取控制台输入
1)基本语法:
read(选项)(参数)
-p 指定读取值时的提示符;
-t 指定读取值时等待的时间(秒)。
参数 变量:指定读取值的变量名

2)案例
读取控制台输入的名称
vim /opt/test8.sh
#!/bin/bash

read -t 10 -p “请在10秒内输入你的信息:” msg

echo $msg
[root@node01 opt]# ./test8.sh
请在10秒内输入你的信息: haha
haha
9.8 函数
9.8.1 系统函数
1)basename基本语法
basename [pathname] [suffix]
basename [string] [suffix] (功能描述:basename命令会删掉所有的前缀包括最后一个(‘/’)字符,然后将字符串显示出来。
选项:
suffix为后缀,如果suffix被指定了,basename会将pathname或string中的suffix去掉。

2)案例
[root@node01 opt]$ basename /opt/test.txt
test.txt
[root@node01 opt]$ basename /opt/test.txt .txt
test

3)dirname基本语法
dirname 文件绝对路径 (功能描述:从给定的包含绝对路径的文件名中去除文件名(非目录的部分),然后返回剩下的路径(目录的部分))

4)案例:
[hello@node01 opt]$ dirname /opt/test.txt
/opt
9.8.2 自定义函数
1)基本语法:
[ function ] funname[()]
{
Action;
[return int;]
}
funname
注意:
(1)必须在调用函数地方之前,先声明函数,shell脚本是逐行运行。不会像其它语言一样先编译。
(2)函数返回值,只能通过$?系统变量获得,可以显示加:return返回,如果不加,将以最后一条命令运行结果,作为返回值。return后跟数值n(0-255)

2)案例:
(1)计算输入参数的和
vim /opt/test9.sh
#!/bin/bash
function sum()
{
s=0
s=$[ $1 + 2 ] e c h o " 2 ] echo " 2]echo"s"
}
read -p "请输入第一个参数: " n1;
read -p "请输入第二个参数: " n2;
sum $n1 $n2;
[root@node01 opt]# ./test9.sh
请输入第一个参数: 1
请输入第二个参数: 2
3
十 YUM仓库配置
10.1 概述
YUM(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及CentOS中的Shell前端软件包管理器。基于RPM包管理,能够从指定的服务器自动下载RPM包并且安装,可以自动处理依赖性关系,并且一次安装所有依赖的软件包,无须繁琐地一次次下载、安装。
10.2 为什么要制作本地YUM源
YUM源虽然可以简化我们在Linux上安装软件的过程,但是生产环境通常无法上网,不能连接外网的YUM源,说以就无法使用yum命令安装软件了。为了在内网中也可以使用yum安装相关的软件,就要配置yum源。
YUM源其实就是一个保存了多个RPM包的服务器,可以通过http的方式来检索、下载并安装相关的RPM包。

10.3 yum的常用命令
1)基本语法:
yum install -y rpm软件包 安装httpd并确认安装
yum list 列出所有可用的package和package组
yum clean all 清除所有缓冲数据
yum deplist rpm软件包 列出一个包所有依赖的包
yum remove rpm软件包 删除httpd

2)案例实操

yum install -y tree
10.4 关联网络yum源
从关联的开源服务器上下载相关的包
1)前期文件准备
(1)前提条件linux系统必须可以联网
(2)在Linux环境中访问该网络地址:http://mirrors.163.com/.help/centos.html,在使用说明中点击CentOS6->再点击保存

(3)查看文件保存的位置

在打开的终端中输入如下命令,就可以找到文件的保存位置。
[rwd@node01 下载]$ pwd
/home/rwd/下载

2)替换本地yum文件
(1)把下载的文件移动到/etc/yum.repos.d/目录
[root@node01 下载]# mv CentOS6-Base-163.repo /etc/yum.repos.d/
(2)进入到/etc/yum.repos.d/目录
[root@node01 yum.repos.d]# pwd
/etc/yum.repos.d
(3)用CentOS6-Base-163.repo替换CentOS-Base.repo
[root@node01 yum.repos.d]# mv CentOS6-Base-163.repo CentOS-Base.repo

3)安装命令
(1)[root@node01 yum.repos.d]#yum clean all
(2)[root@node01 yum.repos.d]#yum makecache
(3)[root@node01 yum.repos.d]# yum install -y createrepo
(4)[root@node01 yum.repos.d]#yum install -y httpd
10.5 制作本地yum源
10.5.1 制作只有本机能访问的本地YUM源
(1)准备一台Linux服务器,版本CentOS-6.5-x86_64-bin-DVD.iso
(2)配置好这台服务器的IP地址
(3)将CentOS-6.5-x86_64-bin-DVD.iso镜像挂载到/mnt/cdrom目录
[root@node01 /]# mkdir /mnt/cdrom
[root@node01 /]# mount -t iso9660 /dev/cdrom /mnt/cdrom
(4)将挂载文件中的Packages包内容都拷贝到目录/var/www/html/Packages中
原因 /mnt/cdrom都读写的权限问题
(5)安装相应的软件
[root@node01 yum.repos.d]#yum install -y httpd
(6)启动httpd服务
[root@node01 yum.repos.d]#service httpd start
(7)使用浏览器访问http://192.168.43.101:80(如果访问不通,检查防火墙是否开启了80端口或关闭防火墙),测试网络是否畅通
(8)将YUM源配置到httpd(Apache Server)中
[root@node01 html]# mkdir Packages
[root@node01 html]# chown rwd:rwd Packages/
[root@node01 html]# cp -r /mnt/cdrom/Packages/* /var/www/html/Packages/
(9)执行创建仓库命令:createrepo 路径
[root@node01 Packages]# createrepo ./
(10)修改本机上的YUM源配置文件,将源指向自己
备份原有的YUM源的配置文件
[root@node01 /]# cd /etc/yum.repos.d/
[root@node01 yum.repos.d]# cp CentOS-Base.repo CentOS-Base.repo.bak
编辑CentOS-Base.repo文件
[root@node01 yum.repos.d]# vim CentOS-Base.repo
[base]
name=CentOS-Local
baseurl=file:///var/www/html/Packages
gpgcheck=0
enabled=1 #增加改行,使能
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6
添加上面内容保存退出
(11)清除YUM缓存
[root@node01 yum.repos.d]# yum clean all
(12)列出可用的YUM仓库
[root@node01 yum.repos.d]# yum repolist
(13)安装相应的软件
[root@node01 yum.repos.d]# yum install -y tree
[root@node01 Packages]# yum install -y firefox-45.0.1-1.el6.centos.x86_64.rpm
10.5.2 制作其他主机通过网络能访问的本地YUM源
(1)让其他需要安装RPM包的服务器指向这个YUM源,准备一台新的服务器,备份或删除原有的YUM源配置文件
备份原有的YUM源的配置文件
[root@ndoe02 /]#cd /etc/yum.repos.d/
[root@node02 yum.repos.d]# cp CentOS-Base.repo CentOS-Base.repo.bak
编辑CentOS-Base.repo文件
[root@node02 yum.repos.d]# vi CentOS-Base.repo
[base]
name=CentOS-node01
baseurl=http://192.168.43.101/Packages
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6
添加上面内容保存退出
(2)在这台新的服务器上执行YUM的命令
[root@ndoe02 yum.repos.d]# yum clean all
[root@node02 yum.repos.d]# yum repolist
(3)安装软件
[root@node02 yum.repos.d]# yum install -y httpd

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值