Linux 学习笔记

     
  Linux开山偏  
01_内容介绍 02_学习方向 03应用领域
 04学习方法费分享     
  Linux 基础篇    
05_Linuz介绍  06_Linux 和Unix的关系  07_Linux 和Windows的关系 
08_VMWare的安装和说明  09_CentOS的安装和说明  10_终端使用和联网 
11_vmtools的安装和使用  12_文件系统目录结构   
  Linux实操篇   
 13_远程登录Linux-Xshell5 14_远程上传下载文件XFTP5  15_vi和vim的使用
16_关机重启登陆注销 17_用户管理 创建用户指定密码 18_用户管理 删除用户
19_用户管理 查询切换用户 20_用户管理 组的管理 21_用户管理 用户和组的配置文件
22_实用指令 运行级别和找回root密码 23_实用指令 帮助指令  24_实用指令 pwd ls cd 
25_实用指令 mkdir rmdir 26_实用指令 touch cp 27_实用指令 rm mv
28_实用指令 cat more less 29_实用指令 >重定向 和 >>追加 30_实用指令 echo head tail
31_实用指令 ln history  32_实用指令 date cal 33_实用指令 find locate grep 管道符 
34_实用指令 压缩和解压类指令 35_组管理  36_权限详细介绍 
37_权限管理  38_权限最佳实践  39_任务调度基本说明 
40_任务调度应用实例 41_磁盘分区介绍  42_Linux分区 
43_给Linux添加一块新硬盘 44_磁盘查询实用指令  45_网络配置原理和说明 
46_自动获取IP 47_修改配置文件指定IP 48_进程管理 进程介绍和查询
49_进程管理 终止进程 50_进程管理 服务管理 51_进程管理 监控服务 
52_RPM包管理 53_YUM 54_JDK安装和配置
  JavaEE定制篇  
 54_JDK安装和配置 55_Tomcat安装和配置 56_Eclipse安装和配置  
57_MySQL安装和配置     
  大数据定制篇   
58_Shell快速入门 59_Shell变量 60_Shell环境变量 
61_Shell位置参数变量 62_Shell预定义变量 63_Shell运算符
64_Shell判断语句 65_Shell流程控制if 66_Shell流程控制case
67_Shell流程控制for 68_Shell流程控制while 69_Shell读取控制台输入
70_Shell系统函数简介 71_Shell自定义函数 72_Shell定时维护数据库

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

Linux 开山篇

01_内容介绍

学习视频

  • 基础篇
  • Linux 入门
  • vm和Linux安装
  • Linux目录结构 
  • 实操篇
  • 远程登录(XShell XFtp)
  • Vi 和 Vim编辑器
  • 开机、重启和用户登录注销
  • 用户管理
  • 实用指令
  • 定时任务调度
  • 磁盘分区。挂载
  • 网络配置
  • 进程管理
  • RPM和YUM
  • Linux之JavaEE定制篇
  • JDK安装
  • Idea的安装
  • Tomcat的安装
  • MySQL的安装
  • Linux 之大数据定制篇
  • Shell编程
  • 概述
  • Shell脚本执行方式
  • Shell变量
  • 运行符
  • 条件判断
  • 流程控制
  • 函数
  • 定时维护Mysql 数据库

 

  • Linux 之Python 定制篇
  • python 专业开发平台-Ubuntu
  • Ubuntu下开发pyhton 开发环境
  • APT 软件管理和远程登录

02_学习方向

  • Linux 下运维工程师
  • Linux 下 嵌入式开发工程师
  • Linux 下 做各种程序开发

 03_应用领域

 个人桌面应用领域

此领域是传统Linux应用最薄弱的环节,传统 Linux由于界面简单、操作复杂、应用软件少的缺点,一直被 Windows所压制,但近些年来随着Ubuntu、Fedora等优秀桌面环境的兴起,同时各大硬件厂商对其支持的加大,Linux在个人桌面领域的占有率在逐渐的提高

 

服务应用领域

Linux在服务器领域的应用是最强的。

Linux免费、稳定、高效等特点在这里得到了很好的体现,近些年来Linux服务器市场得到了飞速的提升,尤其在一些高端领域尤为广泛

嵌入式应用领域

近些年来Linux在嵌入式领域的应用得到了飞速的提高。

Linux运行稳定、对网络的良好支持性、低成本,且可以根据需要进行软件裁剪,内核最小可以达到几百 KB 等特点,使其近些年来在嵌入式领域的应用得到非常大的提高。

主要应用:机顶盒、数字电视、网络电话、程控交换机、手机、PDA、智能家居、智能硬件等都是其应用领域。以后再物联网中应用会更加广泛。

 

04_学习Linux 的阶段(高手进阶过程)

linux 是一个开源、免费的操作系统,其稳定性、安全性、处理多并发已经得到业界的认可,目前很多中型,大型甚至是集群项目都在使用 Linux,很多软件公司考虑到开发成本都首选Linux,在中国软件公司得到广泛的使用

可供参考学习Linux流程如下:

  •  第1阶段:Linux环境下的基本操作命令,包括 文件操作命令(rm mkdir chmod, chown) 编辑工具使用(vi vim)Linux用户管理(useradd userdel usermod)等
  •  第2阶段:Linux的各种配置(环境变量配置,网络配置,服务配置)
  •  第3阶段:Linux下如何搭建对应语言的开发环境(大数据,JavaEE, Python 等) 第 4 阶段:能编写 shell 脚本,对 Linux 服务器进行维护
  •  第4阶段:Linux下能编写 shell 脚本,对 Linux 服务器进行维护。
  •  第5阶段:能进行安全设置,防止攻击,保障服务器正常运行,能对系统调优。
  •  第6阶段:  深入理解Linux系统(对内核有研究),熟练掌握大型网站应用架构组成、并熟悉各个环节的部署和维护方法

Linux的学习方法和建议

  • 高效而愉快的学习。
  • 先建立一个整体框架,然后细节。
  • 不需要掌握所有的Linux指令,要学会查询手册和百度。
  • 先 know how,再 know why。
  • 计算机是一门“做中学”的学科,不是会了再做,而是做了才会。
  • 适当的囫囵吞枣。
  • Linux不是编程,重点是实际操作,各种常用指令要玩的溜。

Linux 基础篇

 05_Linuz介绍

  • Linux  怎么读吗 [里纽克斯,利尼克斯,里纳克斯]
  • Linux 是一款操作系统,免费,开源, 安全,高效,稳定, 处理高并发非常强悍,现在很多的企业级的项目都部署到 Linux/Unix 服务器运行
  • Linux创始人-linus (林纳斯) 

  

  Linus  Torvalds

  • Linux 的吉祥物:一只名叫Tux的企鹅。

      

  • Linux发行版
  • RedHat
  • CentOS
  • Ubuntu
  • Suse
  • 红旗Linux

 

06_Linux 和Unix的关系

 

07_Linux 和Windows的关系

比较 Windows Linux
免费与收费 收费且很贵 Linux 免费或少许费用
软件与支持 数望和质里的优势,不过大部分为收费软件,由微软官方提供支持和服务 开源自由软件,用户可以修改定制和再发布,由于基本免费没有资金支持,部分软件质巢和体验欠缺主有全球所有的Linx开发者和自由软件社区提供支持
安全性 三天两头打补丁安装系统安全更新,还是会中病毒木马 要说Linux没有安全问题,那当然是不可能的,这―点仁者见仁智者见智,相对来说肯定比Windows平台要更加安全
使用习惯 普通用户基本都是纯图形界面下操作使用,依靠鼠标和键盘完成一切操作,用户上手容易入门简单 兼具图形界面操作和完全的命令行操作,可以只用键盘完成一切操作,新手A门较困雅,需要一些学习和指导,一旦熟练之后效军极高
可定制性 封闭的,系统可定制性很差 开源,可定制化非常强
应用场景 桌面操作系统主要使用的是Windows 支挥百度,谷歌,淘宝等应用软件和服务的,是后台成千上方的Linux服务器主机世界上大部分软件和服务都是运行在Linux之上的

 

 

 

 

 

 

 

 

 

 

 

 

 

 

08_VMWare的安装和说明

学习 Linux 需要一个环境,我们需要创建一个虚拟机,然后在虚拟机上安装一个 Centos 系统来学习。

  1. 先安装 virtual machine,VM12。

  2. 再安装 Linux (CentOS 6.8)。

  3. 原理示意图,这里我们画图说明一下 VM 和 CentOS 的关系

 

VM软件 和 Centos 的安装软件

 VM安装的步骤

1. 去 BIOS 里修改设置开启虚拟化设备支持(f2,f10)

2. 安装虚拟机软件 vm12

 

09_CentOS的安装和说明

CentOS 安装步骤

安装步骤略

  • 设置硬件,配置网络连接时,有三种方式:
  • 桥连接,Linux可以和其它的系统通信。但是可能造成ip冲突
  • NAT:用于共享主机的IP地址,Linux可以访问外网,不会造成ip冲突。
  • 主机模式:你的linux是一个独立的主机,不能访问外网

10_终端使用和联网

CentOS 的终端 使用和联网

1.终端的使用,点击鼠标右键,即可选择打开终端

2.演示使用

 

 3.配置网络可以上网

点击上面的按钮:两个计算机的图片,选择启用eth0,即可成功连接网络

 

 

11_vmtools的安装和使用

vmtools安装后,可以让我们在windows下更好的管理vm虚拟机:

  1. 可以直接粘贴命令在windows和centos系统之间
  2. 可以设置windows和centos的共享文件夹

 安装vmtools的步骤:

  1. 进入centos
  2. 点击vm菜单栏的“虚拟机”->install vmware tools
  3. centos会出现一个vm的安装包,将其复制到桌面\
  4. 点击右键解压,得到一个安装文件(或命令行 tar -xzvf vm安装包名 来进行解压)
  5. 进入该vm解压的目录
  6. 安装./vmware-install.pl
  7. 全部使用默认设置即可
  8. 需要命令行reboot,重新启动即可生效

 

设置Windows和CentOS的共享文件夹

  1. 点击VM菜单栏“虚拟机”->“设置”->“选项”->“共享文件夹”-“总是启用”
  2. 添加假设共享目录路径D:\Share
  3. 在CentOS的/mnt/hgfs路径下,便可看到共享文件Share

演示一把

1.设置一个共享文件夹擦D:/myDir,该文件编写一个hello.txt 文件 

2.在Linux 这边打开 可以看到 hello.txt  文件

12_文件系统目录结构

Linux的文件系统是采用级层式的树状目录结构,在此结构中的最上层是根目录“/”,然后在此目录下再创建其他的目录。

深刻理解Linux树状文件目录是非常重要的。

 

记住一句经典的话:在Linux世界里,一切皆文件。

 

 

 

具体的目录结构:

  • /bin[重点] (/usr/bin、/usr/local/bin)
  • 是Binary的缩写,这个目录存放着最经常使用的命令。
  • /sbin (/usr/sbin、/usr/local/sbin)
  • s就是Super User的意思,这里存放的是系统管理员使用的系统管理程序
  • /home[重点]
  • 存放普通用户的主目录,在Linux中每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的。
  • /root[重点]
  • 该目录为系统管理员,也称作超级权限者的用户主目录
  • /boot[重点]
  • 存放的是启动Linux时使用的一些核心文件,包括一些连接文件以及镜像文件
  • /proc
  • 这个目录是一个虚拟的目录,它是系统内存的映射,访问这个目录来获取系统信息
  • /srv
  • service缩写,该目录存放一些服务启动之后需要提取的数据。
  • /sys
  • 这是linux2.6内核的一个很大的变化。该目录下安装了2.6内核中新出现的一个文件系
  • /tmp
  • 这个目录是用来存放一些临时文件的
  • /dev
  • 类似于 window的 设备管理器,把所有的硬件用于文件形式存储
  • /media[重点]
  • linux系统会自动识别一些设备,例如U盘、光驱等等、当识别后、linux 会吧识别的设备挂载到这个目录下
  • /mnt[重点]
  • 系统提供目录是为了让用户临时挂载别的文件系统,我们可以将外部的存储挂载在/mnt 上,然后进入该目录就可以查看里的内容了 d:myshare
  • /opt
  • 这是给主机额外安装软件所摆放的目录。如安装ORACLE数据库 就可放到该目录下 默认为空
  • /usr/local[重点]
  • 这是另外一个给主机额外安装软件多安装的目录、一般是通过编译源码方式安装的程序
  • /var[重点]
  • 这个目录中存放着在 不断扩充的东西,习惯将经常被修改的目录放在这个目录下 包括各种日志文件
  • /selinux[security-enhanced linux]360
  • SELinux是一种安全子系统,它能控制程序只能访问特定文件

Linux目录总结一下

Linux 的目录中有且只要一个根目录 /

Linux 的各个目录存放的内容是规定好的,不要乱发东西

Linux 是以文件的形式管理我们的设备,因此,linux 系统,一切皆为文件 

Linux实操篇

13_远程登录Linux-Xshell5

  1. Linux服务器是开发小组共享的。
  2. 正式上线的项目是运行在公网的
  3. 因此程序员需要远程登录到CentOS进行项目管理或者开发
  4. 画出简单的网络拓扑示意图(帮助理解)
  5. 远程登录客户端有XShell5、Xftp5,我们学习使用XShell5和Xftp,其它的远程工具大同小异。

  

 

说明Xshell 是目前最好的远程登录 到 Linux 操作的软件,流畅的速度并且完美解决中文乱码的问题

是目前程序员首选的软件。Xshell是一个强大的安全终端模拟软件,它支持SSH1、SSH2,以及Microsoft Windows平台的TELNET协议。Xshell可以在Windows界面下用来访问远端不同系统下的服务器,从而比较好的达到远程控制终端的目的。

特别说明:如果希望安装好XShell 5就可以远程访问Linux系统的话,需要有一个前提,就是Linux启用了SSHD服务,该服务会监听22号端口

 具体操作:

在Windows暗转XShell,根据安装向导步骤安装即可。

在Linux查看或开启SSHD:命令行setup->系统服务->SSHD,*号表示开启(空格键确定,TAB键改变焦点)。

在Linux用netstat -antp |grep sshd 看是否启动了22端口。

在Linux用ifconfig获取Linux IPv4地址。

用XShell新建会话:

 

 确定后,输入Linux的用户名与密码,便后远程操控Linux:

 

 

14_远程上传下载文件XFTP5

是一个基于Windows平台的功能强大的SFTP、FTP文件传输软件。使用了Xftp以后,Windows用户能安全地在UNIX/Linux和Windows PC之间传输文件。

具体操作:

安装Xftp,跟随安装向导步骤即可。

新建会话属性

 

如果出现文件或文件夹名中文乱码,可在选项中设置UTF8编码:

 

 

15_vi和vim的使用

所有的 Linux 系统都会内建 vi 文本编辑器。

Vim 具有程序编辑的能力,可以看做是 Vi 的增强版本,可以主动的以字体颜色辨别语法的正确性,方便程序设计。代码补完、编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用

 

 

 

vi/vim 的使用

基本上 vi/vim 共分为三种模式,分别是命令模式(Command mode),输入模式(Insert mode)和底线命令模式(Last line mode)。 这三种模式的作用分别是:

命令模式(一般模式)
用户刚刚启动 vi/vim,便进入了命令模式。

此状态下敲击键盘动作会被Vim识别为命令,而非输入字符。比如我们此时按下i,并不会输入一个字符,i被当作了一个命令。

以下是常用的几个命令:

  • i 切换到输入模式,以输入字符。
  • x 删除当前光标所在处的字符。
  • : 切换到底线命令模式,以在最底一行输入命令。

若想要编辑文本:启动Vim,进入了命令模式,按下i,切换到输入模式。

命令模式只有一些最基本的命令,因此仍要依靠底线命令模式输入更多命令。

输入模式(编辑模式)
在命令模式下按下i就进入了输入模式。

按下 i,I,o,O,a,A,r,R 等任何一个字母之后才会 进入编辑模式,一般来说按 i 即可

在输入模式中,可以使用以下按键:

  • 字符按键以及Shift组合,输入字符
  • ENTER,回车键,换行
  • BACK SPACE,退格键,删除光标前一个字符
  • DEL,删除键,删除光标后一个字符
  • 方向键,在文本中移动光标
  • HOME/END,移动光标到行首/行尾
  • Page Up/Page Down,上/下翻页
  • Insert,切换光标为输入/替换模式,光标将变成竖线/下划线
  • ESC,退出输入模式,切换到命令模式

命令模式(指令行模式

在命令模式下按下:(英文冒号)就进入了底线命令模式。

底线命令模式可以输入单个或多个字符的命令,可用的命令非常多。

在底线命令模式中,基本的命令有(已经省略了冒号):

  • q 退出程序
  • w 保存文件

按ESC键可随时退出底线命令模式。

 

简单的说,我们可以将这三个模式想成底下的图标来表示:

 

vi/vim 按键说明

移动光标的方法 -
h 或 向左箭头键(←) 光标向左移动一个字符
j 或 向下箭头键(↓) 光标向下移动一个字符
k 或 向上箭头键(↑) 光标向上移动一个字符
l 或 向右箭头键(→) 光标向右移动一个字符
如果你将右手放在键盘上的话,你会发现 hjkl 是排列在一起的,因此可以使用这四个按钮来移动光标。 如果想要进行多次移动的话,例如向下移动 30 行,可以使用 “30j” 或 “30↓” 的组合按键, 亦即加上想要进行的次数(数字)后,按下动作即可!  
[Ctrl] + [f] 屏幕『向下』移动一页,相当于 [Page Down]按键 (常用)
[Ctrl] + [b 屏幕『向上』移动一页,相当于 [Page Up] 按键 (常用)
[Ctrl] + [d] 屏幕『向下』移动半页
[Ctrl] + [u] 屏幕『向上』移动半页
+ 光标移动到非空格符的下一行
- 光标移动到非空格符的上一行
n 那个 n 表示『数字』,例如 20 。按下数字后再按空格键,光标会向右移动这一行的 n 个字符。例如 20 则光标会向后面移动 20 个字符距离。
或功能键[Home] 这是数字『 0 』:移动到这一行的最前面字符处 (常用)
$ 或功能键[End] 移动到这一行的最后面字符处(常用)
H 光标移动到这个屏幕的最上方那一行的第一个字符
M 光标移动到这个屏幕的中央那一行的第一个字符
L 光标移动到这个屏幕的最下方那一行的第一个字符
G 移动到这个档案的最后一行(常用)
nG n 为数字。移动到这个档案的第 n 行。例如 20G 则会移动到这个档案的第 20 行(可配合 :set nu)
gg 移动到这个档案的第一行,相当于 1G 啊! (常用)
n 为数字。光标向下移动 n 行(常用)

 

搜索替换

搜索替换  
/word 向光标之下寻找一个名称为 word 的字符串。例如要在档案内搜寻 vbird 这个字符串,就输入 /vbird 即可! (常用)
?word 向光标之上寻找一个字符串名称为 word 的字符串。
n

这个 n 是英文按键。代表重复前一个搜寻的动作。举例来说, 如果刚刚我们执行 /vbird 去向下搜寻 vbird 这个字符串,则按下 n 后,会向下继续搜寻下一个名称为 vbird 的字符串。如果是执行 ?vbird 的话,那么按下 n 则会向上继续搜寻名称为 vbird 的字符串!

N 这个 N 是英文按键。与 n 刚好相反,为『反向』进行前一个搜寻动作。 例如 /vbird 后,按下 N 则表示『向上』搜寻 vbird 。
使用 /word 配合 n 及 N 是非常有帮助的!可以让你重复的找到一些你搜寻的关键词!  
:n1,n2s/word1/word2/g n1 与 n2 为数字。在第 n1 与 n2 行之间寻找 word1 这个字符串,并将该字符串取代为 word2 !举例来说,在 100 到 200 行之间搜寻 vbird 并取代为 VBIRD 则: 『:100,200s/vbird/VBIRD/g』。(常用)
:1,$s/word1/word2/g 或 :%s/word1/word2/g 从第一行到最后一行寻找 word1 字符串,并将该字符串取代为 word2 !(常用)
:1,$s/word1/word2/gc 或 :%s/word1/word2/gc 从第一行到最后一行寻找 word1 字符串,并将该字符串取代为 word2 !且在取代前显示提示字符给用户确认 (confirm) 是否需要取代!(常用)

 

 删除、复制与贴上

删除、复制与贴上  
:%d  不管光标在哪里,删除所有 
x, X 在一行字当中,x 为向后删除一个字符 (相当于 [del] 按键), X 为向前删除一个字符(相当于 [backspace] 亦即是退格键) (常用)
nx n 为数字,连续向后删除 n 个字符。举例来说,我要连续删除 10 个字符, 『10x』。
dd 删除游标所在的那一整行(常用)
ndd n 为数字。删除光标所在的向下 n 行,例如 20dd 则是删除 20 行 (常用)
d1G 删除光标所在到第一行的所有数据
dG 删除光标所在到最后一行的所有数据
d$ 删除游标所在处,到该行的最后一个字符
d0 那个是数字的 0 ,删除游标所在处,到该行的最前面一个字符
yy 复制游标所在的那一行(常用)
nyy n 为数字。复制光标所在的向下 n 行,例如 20yy 则是复制 20 行(常用)
y1G 复制游标所在行到第一行的所有数据
yG 复制游标所在行到最后一行的所有数据
y0 复制光标所在的那个字符到该行行首的所有数据
y$ 复制光标所在的那个字符到该行行尾的所有数据
p, P

p 为将已复制的数据在光标下一行贴上,P 则为贴在游标上一行! 举例来说,我目前光标在第 20 行,且已经复制了 10 行数据。则按下 p 后, 那 10 行数据会贴在原本的 20 行之后,亦即由 21 行开始贴。但如果是按下 P 呢? 那么原本的第 20 行会被推到变成 30 行。 (常用)

J 将光标所在行与下一行的数据结合成同一行
c 重复删除多个数据,例如向下删除 10 行,[ 10cj ]
u 复原前一个动作。(常用)
[Ctrl]+r 重做上一个动作。(常用)
这个 u 与 [Ctrl]+r 是很常用的指令!一个是复原,另一个则是重做一次~ 利用这两个功能按键,你的编辑,嘿嘿!很快乐的啦!  
  不要怀疑!这就是小数点!意思是重复前一个动作的意思。 如果你想要重复删除、重复贴上等等动作,按下小数点『.』就好了! (常用)
 
 第二部分:一般模式(命令模式)切换到编辑模式(输入模式)的可用的按钮说明
进入输入或取代的编辑模式  
i, I 进入输入模式(Insert mode): i 为『从目前光标所在处输入』, I 为『在目前所在行的第一个非空格符处开始输入』。 (常用)
a, A 进入输入模式(Insert mode): a 为『从目前光标所在的下一个字符处开始输入』, A 为『从光标所在行的最后一个字符处开始输入』。(常用)
o, O 进入输入模式(Insert mode): 这是英文字母 o 的大小写。o 为在目前光标所在的下一行处输入新的一行; O 为在目前光标所在的上一行处输入新的一行!(常用)
r, R 进入取代模式(Replace mode): r 只会取代光标所在的那一个字符一次;R会一直取代光标所在的文字,直到按下 ESC 为止;(常用)
上面这些按键中,在 vi 画面的左下角处会出现『–INSERT–』或『–REPLACE–』的字样。 由名称就知道该动作了吧!!特别注意的是,我们上面也提过了,你想要在档案里面输入字符时, 一定要在左下角处看到 INSERT 或 REPLACE 才能输入喔!  
[Esc] 退出编辑模式,回到一般模式中(常用)

 

第三部分:一般模式切换到指令行模式的可用的按钮说明

指令行的储存、离开等指令  
:w 将编辑的数据写入硬盘档案中(常用)
:w! 若文件属性为『只读』时,强制写入该档案。不过,到底能不能写入, 还是跟你对该档案的档案权限有关啊!
:q 离开 vi (常用)
:q! 若曾修改过档案,又不想储存,使用 ! 为强制离开不储存档案。
注意一下啊,那个惊叹号 (!) 在 vi 当中,常常具有『强制』的意思~  
:wq 储存后离开,若为 :wq! 则为强制储存后离开 (常用)
ZZ 这是大写的 Z 喔!如果修改过,保存当前文件,然后退出!效果等同于(保存并退出)
ZQ 不保存,强制退出。效果等同于 :q!。
:w [filename] 将编辑的数据储存成另一个档案(类似另存新档)
:r [filename] 在编辑的数据中,读入另一个档案的数据。亦即将 『filename』 这个档案内容加到游标所在行后面
:n1,n2 w [filename] 将 n1 到 n2 的内容储存成 filename 这个档案。
:! command 暂时离开 vi 到指令行模式下执行 command 的显示结果!例如 『:! ls /home』即可在 vi 当中察看 /home 底下以 ls 输出的档案信息!

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

vim 环境的变更  
:set nu 显示行号,设定之后,会在每一行的前缀显示该行的行号
:set nonu 与 set nu 相反,为取消行号!

 

 

 

 

特别注意,在 vi/vim 中,数字是很有意义的!数字通常代表重复做几次的意思! 也有可能是代表去到第几个什么什么的意思。

举例来说,要删除 50 行,则是用 『50dd』 对吧! 数字加在动作之前,如我要向下移动 20 行呢?那就是『20j』或者是『20↓』即可。

 

16_关机重启登陆注销

关机重启

  • shutdown -h now 立该进行关机
  • shudown -h 1 "hello,1分钟后会关机了”
  • shutdown -r now 现在重新启动计算机
  • halt 关机,作用和上面―样
  • reboot 现在重新启动计算机
  • sync 把内存的数据同步到磁盘

注意细节:

不管是重启系统还是关闭系统,首先要运行sync命令,把内存中的数据写到磁盘中

登陆注销

基本介绍:

  1. 登录时尽量少用root帐号登录,因为它是系统管理员,最大的权限,避免操作失误。可以利用普通用户登录,登录后再用“su 用户名”命令来切换成系统管理员身份。
  2. 在提示符下输 logout即可注销用户。

使用细节:

  1. logout 注销指令在图形运行级别无效,在运行级别3下有效。
  2. 运行级别这个概念,后面给大家介绍。

 

 

 

17_用户管理 创建用户指定密码

 

  1. Linux 系统是一个多用户多任务的操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统。
  2. Linux 的用户需要至少要属于一个组。

 

添加用户

useradd [选项] 用户名

如:useradd xm
新加一个用户 xm

 

 

 

当创建用户成功后,会自动的创建和用户同名的家目录

也可以通过 useradd -d 指定目录 新的用户名,给新创建的用户指定家目录

 

 

给用户指定或者修改密码

passwd 用户名

如:passwd xm

 

 

18_用户管理 删除用户

userdel 用户

删除用户 xm,但是要保留home目录

 

 

 

 删除用户 xh 以及用户主目录

 

注意 在删除用户时,我们一般不会将home目录删除的。

19_用户管理 查询切换用户

查询用户

id 用户名

案例:

 

 

 当用户不存在时,返回”无此用户”。

 

切换用户

su – 切换用户

创建一个用户zf,指定密码,然后切换到zf。

 

 

 

 

从权限高的用户切换到权限低的用户,不需要输入密码,反之需要。

当需要返回到原来用户时,使用exit指令。

 

20_用户管理 组的管理

类似于角色,系统可以对有共性的多个用户进行统一的管理。

增加组

groupadd 组名

 

 

 

删除组

groupdel 组名

 

 

 

增加用户时直接加上组

useradd -g 用户组 用户名

 

 

 

 

修改用户的组

usermod -g 用户组 用户名

 

 

 

21_用户管理 用户和组的配置文件

  • /etc/passwd文件
  • 用户(user)的配置文件,记录用户的各种信息。
  • 每行的含义:用户名:口令:用户标识号:组标识号:注释性描述:主目录:登录shell

 

 

 

  • /etc/shadow文件
  • 口令的配置文件。
  • 每行的含义:登录名:加密口令:最后一次修改时间:最小时间间隔:最大时间间隔:警告时间:不活动时间:失效时间:标志

 

 

 

  • /etc/group文件
  • 组(group)的配置文件,记录Linux包含的组的信息。
  • 每行含义:组名:口令:组标识号:组内用户列表。

 

 

 

 

 

22_实用指令 运行级别和找回root密码

基本介绍

运行级别说明:

  1. 关机

  2. 单用户【找回丢失密码】

  3. 多用户状态没有网络服务

  4. 多用户状态有网络服务

  5. 系统未使用保留给用户

  6. 图形界面

  7. 系统重启

 

 

 

 

 

常用运行级别是3和5,要修改默认的运行级别可改文件

/etc/inittab

id:5:initdefault:

 

 也可以使用切换到指定运行级别的指令:init [012356]

案例一

通过imit来切换不同的运行级别,比如动5->3,然后关机

  1. init 3
  2. init 5
  3. init 0

案例二

如何找回 root 密码

思路:进入到 单用户模式,然后修改 root 密码。因为进入单用户模式,root 不需要密码就可以登录。

操作步骤:开机->在引导时输入 回车键-> 看到一个界面输入 e -> 看到一个新的界面,选中第二行(编辑内核)在输入 e-> 在这行最后输入 1 ,再输入 回车键->再次输入 b ,这时就会进入到单用户模式。

这时,我们就进入到单用户模式,使用 passwd 指令来修改 root 密码。

 

23_实用指令 帮助指令

当我们对某个指令不熟悉时,我们可以使用 Linux 提供的帮助指令来了解这个指令的使用方法。

  • man 命令名,如man cd
  • help 命令名,如help cd
  • 虽然上面两个都可以来获取指令帮助,但是需要英语功底,如果英语不太好的,我还是推荐大家直接百度靠谱。

 

24_实用指令 pwd ls cd

pwd 指令

print working directory

  • 基本语法

    pwd (功能描述:显示当前工作目录的绝对路径)

 

 

 

ls 指令

  • 基本语法

    ls [选项] [目录或是文件]

常用选项:

  • -a:显示当前目录所有的文件和目录,包括隐藏的。
  • -l:以列表的方式显示信息

应用实例

  案例查看 当前目录的所有内容信息

  

 

 

      

 

   cd 指令 

  • 基本语法

    cd [参数](功能描述:切换到指定目录)

  • 常用参数
  • 绝对路径和相对路径
  • cd ~或者cd :回到自己的家目录
  • cd …:回到当前目录的上一级目录
  • 应用实例
  • 案例1:使用绝对路径切换到root目录
  • cd  /root
  • 案例2:使用相对路径到/root目录、
  • 这里我们需要知道该用户目录在哪个目录下,才能写出这个指令,假设在d当前工作目录为/usr/lib
  • cd …/…/root
  • 案例3:表示回到当前目录的上一级目录
  • cd 
  • 案例4:回到家目录
  • cd ~
  • cd

  

25_实用指令 mkdir rmdir

mkdir

mkdir指令用于创建目录

  • 基本语法
  • mkdir [选项] 要创建的目录
  • 常用选项
  • -p:创建多级目录
  • 应用实例
  • 案例1:创建一个目录/home/dog
  • mkdir /home/dog
  • 案例2
  • 创建多级目录/home/animal/tiger
  • mkdir -p /home/animal/tiger

 

 

 

rmdir

rmdir指令删除空目录

  • 基本语法
  • rmdir [选项] 要册除的空目录
  • 应用实例
  • 案例1:删除一个目录/home/dog使用细节
  •  rmdir删除的是空目录,如果目录下有内容时无法删除的。
  • 提示,如果需要删除非空目录,需要使用rm -rf 要删除的目录
  • -r recursive
  • -f force
  • 系统自杀 rm -rf /

 

 

 

 

26_实用指令 touch cp

  touch

touch指令创建空文件

  • 基本语法
  • touch 文件名称s(可创建多个空文件)
  • 应用实例
  • 案例1:创建一个空文件hello.txt
  • touch hello.txt

 

 

 

 

 

cp

cp指令拷贝文件到指定目录

  • 基本语法
  • cp [选项] (source) (dest)
  • 常用选项
  • -r:递归复制整个文件夹
  • 应用实例
  • 案例1:将/home/aaa.txt拷贝到/home/bbb目录下(当前工作目录为/home)
  • cp aaa.txt /home/bbb
  • 案例2:递归复制整个文件夹,举例、
  • cp -r src/ target/
  • 注意一定要注意你当前的工作目录位置,然后准确地定位源目录和目标目录。
  • 使用细节
  • 强制覆盖不提示的方法: \cp
  • \cp -r src/ target/
  • 技术小技巧
  • 可以通过上下箭头的键,调出原来使用过的指令。

 

 

 

27_实用指令 rm mv

rm

rm指令移除文件或目录

  • 基本语法
  • rm [选项] (要删除的文件或目录)
  • 常用选项
  • -r:递归删除整个文件夹
  • -f:强制刚除不提示
  • 应用实例
  • 案例1:将/home/aaa.txt删除(当前工作目录为/home)
  • rm aaa.txt
  • 案例2:递归删除整个文件夹/home/bbb(当前工作目录为/home)
  • rm -rf bbb/
  • 使用细节
  • 强制删除不提示的方法。带上-f参数即可

 

 

 

mv

mv 移动文件 与 目录或重命名

  • 基本语法
  • mv (oldNameFile) (newNameFile):(功能描述:重命名)
  • mv (/temp/movefile) (/targetFolder):(功能描述:移动文件)
  • 应用实例
  • 案例1:将/home/aaa.txt文件重新命名为pig.txt(当前工作目录为/home)
  • mv aaa.txt pig.txt
  • 案例2:将/home/pig.txt文件移动到root目录下(当前工作目录为/home)
  • mv pig.txt /root

 

 

 

28_实用指令 cat more less

 cat

cat查看文件内容,是以只读的方式

  • 基本语法
  • cat [选项] 要查看的文件
  • 常用选项
  • -n:显示行号
  • 应用实例
  • 案例1: /ect/profile文件内容,并显示行号
  • cat -n /ect/profile
  • 使用细节
  • cat只能浏览文件,而不能修改文件,为了浏览方便,一般会带上管道命令| more
  • cat -n /ect/profile | more

 

 

 

 

more

more指令是一个基于vi编辑器的文本过滤器,它以全屏幕的方式按页显示文本文件的内容。

more指令中内置了若干快捷键,详见操作说明:

 

 

  •  基本语法
  • more 要查看的文件操作说明
  • 应用实例
  • 案例:采用more查看文件/etc/profile
  • more /etc/profile

less

less指令用来分屏查看文件内容,它的功能与more指令类似,但是比more指令更加强大,支持各种显示终端。

less指令在显示文件内容时,并不是一次将整个文件加载之后才显示,而是根据显示需要加载内容,对于显示大型文件具有较高的效率。

  • 基本语法
  • less 要查看的文件

 

  • 操作说明

 

 

  •  应用实例
  • 案例:采用less查看一个大文件文件
  • less /opt/金庸-射雕英雄传txt精校版.txt

 

 

 

29_实用指令 >重定向 和 >>追加

介绍

> 指令 和 >> 指令

> 输出重定向:会将原来的文件内网覆盖

>> 追加:不会覆盖原来的文件内容,而是追加到文件的尾部

 

  • 基本语法
  • ls -l > 文件 (功能描述:列表的内容写入文件a.txt中(覆盖写))
  • Is -al >> 文件 (功能描述:列表的内容追加到文件aa.txt的末尾)
  • cat 文件1 > 文件2 (功能描述:将文件1的内容覆盖到文件2)
  • echo “内容”>>文件

 

 

 

 

 

 

 

 

 

 

 

 

  • 应用实例
  • 案例1:将/home目录下的文件列表写入到/home/info.txt中
  • ls -l /home/ > /home/info.txt
  • 案例2:将当前日历信息.追加到/home/mycal文件中[提示cal]
  • cal >> /home/mycal

 

  • 30_实用指令 echo head tail

echo 输出内容到控制台

  • 基本语法
  • echo [选项] [输出内容]
  • 应用实例
  • 案例:使用echo指令输出环境变量,输出当前的环境路径
  • echo $PATH
  • 案例
  • echo ”hello,world!“

head  用于显示文件的开头部分内容,默认情况下head指令显示文件的前10行内容

  • 基本语法
  • head 文件路径(功能描述:查看文件头10行内容
  • head -n 5 文件路径(功能描述:查看文件头5行内容,5可以是任意行数)
  • 应用实例
  • 案例:查看/etc/profile的前面5行代码
  • head -n 5 /etc/profile

 

 

 

tail  用于输出文件中尾部的内容,默认情况下tail指令显示文件的后10行内容。

  • 基本语法
  • tail 文件路径(功能描述:查看文件后10行内容)
  • tail -n 5 文件路径(功能描述:查看文件后5行内容,5可以是任意行数)
  • tail -f 文件路径(功能描述:实时追踪该文档的所有更新)
  • 应用实例
  • 案例1:查看/etc/profile最后5行的代码
  • tail -n 5 /etc/profile
  • 案例2:实时监控mydate.txt,看看到文件有变化时,是否看到,实时的追加日期
  • tail -f mydate.txt

 

 

 

 

 

 

31_实用指令 ln history

ln

软链接也叫符号链接,类似于windows里的快捷方式,主要存放了链接其他文件的路径

  • 基本语法
  • ln -s [原文件或目录] [软链接名] (功能描述:给原文件创建一个软链接)(如果软链接名时目录路径,cd 软链接名 就能跳到目录)
  • 应用实例
  • 案例1:在/home目录下创建一个软连接linkToRoot,连接到/root目录
  • ln -s /root linkToRoot
  • 案例2:删除软连接linkToRoot
  • rm -rf linkToRoot(如果删除linkToRoot/,请三思)
  • 细节说明
  • 当我们使用pwd指令查看目录时,仍然看到的是软链接所在目录。''

 

 

 

 

 

 

 

history 查看已轻执行过历史命令,也可以执行历史指令

  • 基本语法
  • history(功能描述,查看已经执行过历史命令)
  • 应用实例
  • 案例1:显示所有的历史命令
  • history
  • 案例2:显示最近使用过的10个指令
  • history 10
  • 案例3:执行历史编号为5的指令
  • !5

 

 

 

 

 

32_实用指令 date cal

date

date指令-显示当前日期

  • 基本语法
  • date(功能描述:显示当前时间)
  • date +%Y(功能描述:显示当前年份)
  • date +%m(功能描述:显示当前月份)
  • date +%d(功能描述:显示当前是哪一天)
  • date "+%Y-%m-%d %H:%M:%S”(功能描述:显示年月日时分秒)
  • 应用实例
  • 案例1:显示当前时间信息
  • date
  • 案例2:显示当前时间年月日
  • date “+%Y-%m-%d”
  • date “+%Y %m %d”
  • 案例3:显示当前时间年月日时分秒
  • date “+%Y-%m-%d %H:%M:%S”

date指令-设置日期

  • 基本语法
  • date -s 字符串时间
  • 应用实例
  • 案例1:设置系统当前时间,比如设置成2021-11-11 11:22:22
  • date -s “2020-11-11 11:22:22”

cal

查看日历指令

  • 基本语法
  • cal [选项] (功能描述:不加选项,显示本月日历)
  • 应用实例
  • 案例1:显示当前日历
  • cal
  • 案例2:显示2020年日历
  • cal 2020

 

33_实用指令 find locate grep 管道符

find

find指令将从指定目录向下递归地遍历其各个子目录,将满足条件的文件或者目录显示在终端。

  • 基本语法
  • find [搜索范围] [选项]
  • 选项说明

 

 

  • 应用实例
  • 案例1:按文件名:根据名称查找/home目录下的hello.txt文件
  • find /home -name hello.txt
  • 案例2:按拥有者:查找/opt目录下,用户名称为nobody的文件
  • find /opt -user nobody
  • 案例3:查找整个linux系统下大于、等于、小于20m的文件
  • find / -size +20M
  • find / -size 20M
  • find / -size -20M
  • 案例4:按文件名:根据名称查找/目录下的以txt结尾的文件
  • find / -name *.txt

 

 

 

 

 

 

 

 

 

 

 

 

 

locate

locate指令可以快速定位文件路径。locate指令利用事先建立的系统中所有文件名称及路径的locate数据库实现快速定位给定的文件。

Locate指令无需遍历整个文件系统,查询速度较快。为了保证查询结果的准确度,管理员必须定期更新locate时刻。

 

  • 基本语法
  • locate 搜索文件
  • 特别说明
  • 由于locate指令基于数据库进行查询,所以第一次运行前,必须使用updatedb指令创建locate数据库。

 

  • 应用实例
  • 案例1:请使用locate指令快速定位hello.txt文件所在目录
  • updatedb -> locate hello.txt

 

 

 

grep与管道符

grep过滤查找,管道符“|“,表示将前一个命令的处理结果输出传递给后面的命令处理。

  • 基本语法
  • grep [选项] 查找内容源文件
  • 常用选项

 

  •  应用实例
  • 案例1:请在hello.txt文件中,查找"yes”所在行,并且显示行号
  • cat hello.txt | grep -n yes

 

34_实用指令 压缩和解压类指令

gzip/gunzip指令

gzip用于压缩文件,gunzip用于解压的

  • 基本语法
  • gzip (文件)(功能描述:压缩文件,只能将文件压缩为*.gz文件)
  • gunzip (文件.gz)(功能描述:解压缩文件命令)
  • 应用实例
  • 案例1:gzip压缩,将/home下的hello.txt文件进行压缩
  • gzip hello.txt
  • 案例2:gunzip压缩,将/home下的hello.txt.gz文件进行解压缩
  • gunzip hello.txt.gz

细节说明 

  • 当我们使用gzip对文件进行压缩后,不会保留原来的文件。

 

 

 

zip/unzip指令

zip用于压缩文件, unzip用于解压的,这个在项目打包发布中很有用的。

  • 基本语法
  • zip [选项] XXX.zip 将要压缩的内容(功能描述:压缩文件和目录的命令)
  • unzip [选项] XXX.zip (功能描述:解压缩文件)
  • zip常用选项
  • -r:递归压缩,即压缩目录unzip的常用选项
  • -d <目录>:指定解压后文件的存放目录
  • 应用实例
  • 案例1:将/home下的所有文件进行压缩成mypackage.zip
  • zip -r mypackage.zip /home/
  • 案例2:将mypackge.zip解压到/opt/tmp目录下
  • unzip -d /opt/tmp/ mypackage.zip

 

 

 

tar指令

tar指令是打包指令,最后打包后的文件是.tar.gz的文件。

  • 基本语法

tar [选项] XXX.tar.gz 打包的内容(功能描述,打包目录,压缩后的文件格式.tar.gz)。

  • 选项说明

 

 

  • 应用实例
  • 案例1:压缩多个文件,将/home/a1.txt和/home/a2.txt压缩成a.tar.gz
  • tar -zcvf a.tar.gz a1.txt a2.txt
  • 案例2:将/home的文件夹压缩成myhome.tar.gz
  • tar -zcvf myhome.tar.gz /home/
  • 案例3:将a.tar.gz解压到当前目录
  • tar -zxvf a.tar.gz
  • 案例4:将myhome.tar.gz解压到/opt/自录下
  • tar -zxvf myhome.tar.gz -C /opt/

 

 

细节说明

指定解压到的那个目录,事先要存在才能成功,否则会抛错

 

35_组管理

在Linux中的每个用户必须属于一个组,不能独立于组外。在Linux中每个文件有所有者、所在组、其它组的概态。

  1. 所有者
  2. 所在组
  3. 其它组
  4. 改变用户所在的组

用户家目录的概念

/home/

目录下有各个创建的用户对于的家目录,当用户登录时,会自动的进入到自己的家目录。

  • /home/xm
  • /home/xh
  • /home/zwj

文件/目录所有者

二般为文件的创建者,谁创建了该文件,就自然的成为该文件的所有者。

  • 查看文件的所有者
  • 指令:ls -ahl
  • 应用实例:创建一个组police,再创建一个用户tom,将tom放入police组,然后使用tom来创建一个文件ok.txt,看看情况如何
  • groupadd police
  • useradd -g police tom
  • passwd tom 修改密码
  • touch ok.txt
  • ls -ahl
  • 修改文件所有者
  • 指令:chown 用户名 文件名
  • 应用案例:使用root创建一个文件apple.txt ,然后将其所有者修改成tom
  • chown tom apple.txt

 

 

组的创建

  • 基本指令
  • groupadd 组名
  • 应用实例:
  • 创建一个组monster
  • groupadd monster
  • 创建一个用户fox ,并放入到monster组中
  • useradd -g monster fox
  • id fox

 

文件/目录所在组

当某个用户创建了一个文件后,这个文件的所在组就是该用户所在的组。

查看文件/目录所在组

  • 基本指令
  • ls -ahl
  • 应用实例

 

  • 修改文件所在的组
  • 基本指令
  • chgrp 组名 文件名
  • 应用实例:使用root用户创建文件 orange.txt,看看当前这个文件属于哪个组,然后将这个文件所在组,修改到police组。
  • touch orange.txt
  • chgrp police orange.txt

 

其它组

除文件的所有者和所在组的用户外,系统的其它用户都是文件的其它组。

改变用户所在组

在添加用户时,可以指定将该用户添加到哪个组中,同样的用root的管理权限可以改变某个用户所在的组。

  • 改变用户所在组
  • usermod -g 组名 用户名
  • usermod -d 目录名 用户名:改变该用户登陆的初始目录
  • 应用实例

 

  • 创建一个土匪组(bandit)将tom这个用户从原来所在的police组,修改到 bandit(土匪)组。
  • id tom:查看tom组信息
  • groupadd bandit
  • chmod -g bandit tom

 

 

36_权限详细介绍

权限的基本介绍

ls -l中显示的内容如下:

-rwxrw-r-- 1 root root 1213 Feb 2 09:39 abc

前0~9位字符说明

  1. 第0位确定文件类型(d, -, l, c, b)
  1. d:目录
  2. -:普通文件
  3. l:软链接
  4. c:字符设备(键盘,鼠标)
  5. b:块文件,硬盘

 

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

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

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

 

 

 

rwx权限详解

  • rwx作用到文件
  • [r]代表可读(read):可以读取,查看
  • [w]代表可写(write):可以修改,但是不代表可以删除该文件,删除一个文件的前提条件是对该文件所在的目录有写权限,才能删除该文件.
  • [x]代表可执行(execute):可以被执行
  • rwx作用到目录
  • [r]代表可读(read):可以读取,ls查看目录内容
  • [w]代表可写(write):可以修改,目录内创建+删除+重命名目录
  • [x]代表可执行(execute):可以进入该目录

 

文件及目录权限实际案例

ls -中显示的内容如下(重点:需要记住):

-rwxrw-r-- 1 root root 1213 Feb 2 09:39 abc
  • 前10个字符确定不同用户能对文件干什么
  • 第一个字符代表文件类型:文件(-),目录(d),链接(I)
  • 其余字符每3个一组(rwx)读(r)写(w)执行(x)
  • 第一组rwx:文件拥有者的权限是读、写和执行
  • 第二组rw-:与文件拥有者同一组的用户的权限是读、写但不能执行
  • 第三组r–:不与文件拥有者同组的其他用户的权限是读不能写和执行
  • 可用数字表示为:r=4,w=2,x=1因此rwx=4+2+1=7
  • 1:
  • 如果是文件,表示硬连接数
  • 如果是目录,表示子目录数
  • root:用户
  • root:组
  • 1213:文件大小(字节,如果是文件夹,显示4096字节)
  • Feb 2 09:39:最后修改日期
  • abc:文件名

37_权限管理

修改权限-chmod

  • 基本说明:
  • 通过chmod指令,可以修改文件或者目录的权限。
  • 第一种方式:+、-、=变更权限
  • 字符意义:
  • u:所有者
  • g:所有组
  • o:其他人
  • a:所有人(u、g、o的总和)
  • 一些示例
  • chmod u=rwx,g=rx,o=x(文件目录名)
  • chmod o+w(文件目录名)
  • chmod a-x(文件目录名)
  • 案例演示
  • 给abc文件的所有者读写执行的权限,给所在组读执行权限,给其它组读执行权限
  • chmod u=rwx,g=rx,o=rw abc
  • 给abc文件的所有者除去执行的权限,增加组写的权限
  • chmod u-x,g+x abc
  • 给abc文件的所有用户添加读的权限
  • chmod a+r abc

 

 

  • 第二种方式:通过数字变更权限
  • r=4 w=2 x=1 rwx=4+2+1=7
  • (chmod u=rwx,g=rx,o=x 文件目录名)相当于 (chmod 751文件目录名)
  • 案例演示
  • 将/home/abc.txt文件的权限修改成rwxr-xr-x,使用给数字的方式实现  rwx=4+2+1=7 ,r-x=4+1=5, r-x=4+1=5
  • chmod 755 /home/abc.txt

修改文件所有者-chown

  • 基本介绍
  • chown newowner file 改变文件的所有者
  • chown newowner:newgroup file 改变用户的所有者和所有组
  • -R 如果是目录则使其下所有子文件或目录递归生效
  • 案例演示:
  • 请将/home/abc .txt 文件的所有者修改成tom
  • chown tom abc.txt

    

  • 请将/home/kkk 目录下所有的文件和目录的所有者都修改成tom
  • chown -R tom kkk/

  • 细节说明:
  • 首选使用root操作

修改文件所在组-chgrp

  • 基本介绍
  • chgrp newgroup fle 改变文件的所有组
  • 案例演示:
  • 请将/home/abc .txt文件的所在组修改成shaolin
  • chgrp shaolin /home/abc.txt
  • 请将/home/kkk目录下所有的文件和目录的所在组都修改成shaolin
  • chgrp -R shaolin /home/kkk

      

 

38_权限最佳实践

案例:警匪游戏

组:police , bandit

警察:jack, jerry

土匪:xh, xq

  1. 创建组
    1. grounpadd police
    2. grounpadd bandit
  1. 创建用户
  1. useradd -g police jack
  2. useradd -g police jerry
  3. useradd -g bandit xh
  4. useradd -g bandit xq

  3.修改用户密码

    1. passwd jack
    2. passwd jerry
    3. passwd xh
    4. passwd xq

   4.jack创建一个文件,自己可以读写,本组人可以读,其它组没人任何权限

    1. chmod 640 jack01.txt

   5.jack修改该文件,让其它组人可以读,本组人可以读写

    1. chmod o=r,g=rw jack01.txt

   6.xh投靠警察,看看是否可以读写。

    1. 先用root修改xh的组
      1. usermod -g police xh

      2.使用jack给他的家目录/home/jack的所在组一个rx的权限

         1.  chmod g=rx jack/

      3.xh需要重新注销在到jack目录就可以操作jack的文件

  • 指令:id 用户名:
  • 查看用户的uid、gid、组信息

39_任务调度基本说明

crond任务调度

crontab进行定时任务的设置。

  • 概述
  • 任务调度:是指系统在某个时间执行的特定的命令或程序。
  • 任务调度分类:系统工作。
  • 有些重要的工作必须周而复始地执行。如病毒扫描等个别用户工作:
  • 个别用户可能希望执行某些程序,比如对mysqI数据库的备份。
  • 基本语法
  • crontab [选项]常用选项
  • 常用选项
  • -e:编辑crontab定时任务
  • -l:查询crontab任务
  • -r:删除当前用户所有的crontab任务

 

快速入门

  • 步骤:
  • 设置任务调度文件:/etc/crontab
  • 设置个人任务调度。执行crontab -e命令。
  • 接着输入任务到调度文件
  • 如:*/1 * * * * Is -l /etc/ > /tmp/to.txt
  • 意思说每小时的每分钟执行ls -l /etc/ > /tmp/to.txt命令
  • 5个占位符的说明:
项目 含义 范围
第一个“*” 一小时当中的第几分钟 0~59
第二个“*” 一天当中的第几小时 0~23
第三个“*” 一个月当中的第几天 1~31
第四个“*” —年当中的第几月 1~12
第五个“*” 一周当中的星期几 0~7(0和7都代表星期日)

 

 

 

 

 

 

 

 

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

 

 

 

 

 

 

 

  • 特定时间执行任务案例
时间 含义
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分都会执行命令。
注意:星期几和几号最好不要同时出现,因为他们定义的都是天。非常容易让管理员混乱。

 

 

 

 

 

 

 

 

 

 

40_任务调度应用实例

  • 应用实例
  • 案例1:每隔1分钟,就将当前的日期信息,追加到/tmp/mydate文件中。
  • 先编写一个文件 /home/mytask1.sh
  • date >> /tmp/mydate
  • 给mytask1.sh一个可以执行权限
  • chmod 744 /home/mytask1.sh
  • crontab -e
  • */1 * * * * /home/mytask1.sh
  • 成功
  • 案例2:每隔1分钟,将当前日期和日历都追加到/home/mycal文件中。
  • 先编写一个文件 /home/mytask2.sh
  • date >> /home/mycal
  • cal >> /home/mycal
  • 给mytask2.sh一个可以执行权限
  • chmod 744 /home/mytask2.sh
  • crontab -e
  • */1 * * * * /home/mytask2.sh
  • 成功
  • 案例3:每天凌晨2:00将mysql数据库testdb,备份到文件中。
  • 先编写一个文件 /home/mytask3.sh
  • /usr/local/mysql/bin/mysqldump -u root -proot testdb > /tmp/mydb.bak
  • 给mytask3.sh一个可以执行权限
  • chmod 744 /home/mytask3.sh
  • crontab -e
  • 0 2 * * * /home/mytask3.sh
  • 成功
  • crond相关指令:
  • conrtab -r:终止任务调度。
  • crontab -l:列出当前有那些任务调度
  • service crond restart [重启任务调度]

 

41_磁盘分区介绍

分区基础知识

分区的方式:

  • MBR分区:
  1. 最多支持四个主分区
  2. 系统只能安装在主分区
  3. 扩展分区要占一个主分区
  4. MBR最大只支持2TB,但拥有最好的兼容性

 

gtp分区:

  1. 支持无限多个主分区(但操作系统可能限制,比如windows下最多128个分区)
  2. 最大支持18EB的大容量(1EB=1024 PB,1PB=1024TB)
  3. windows7 64位以后支持gtp

 

 

 

 

42_Linux分区

原理介绍

Linux来说无论有几个分区,分给哪一目录使用,它归根结底就只有一个根目录,一个独立且唯一的文件结构,Linux中每个分区都是用来组成整个文件系统的一部分

Linux采用了一种叫“载入”的处理方法,它的整个文件系统中包含了一整套的文件和目录,且将一个分区和一个目录联系起来。这时要载入的一个分区将使它的存储空间在一个目录下获得。

 

 

 

硬盘说明

  1. Linux硬盘分IDE硬盘和SCSI硬盘,目前基本上是SCSI硬盘。
  2. 对于IDE硬盘,驱动器标识符为“hdx",其中“hd"表明分区所在设备的类型,这里是指IDE硬盘了。”x“为盘号(a为基本盘,b为基本从属盘,c为辅助主盘,d为辅助从s属盘),“”代表分区,前四个分区用数字1到4表示,它们是主分区或扩展分区,从5开始就是逻辑分区。例,hda3表示为第一个IDE硬盘上的第兰个主分区或扩展分区,hdb2表示为第二个IDE硬盘上的第二个主分区或扩展分区

  3. 对于SCSI硬盘则标识为“sdx”,SCSI硬盘是用“sd“来表示分区所在设备的类型的,其余则和IDE硬盘的表示方法一样。

使用lsblk指令查看当前系统的分区情况

lsblk -f:查看系统的分区和挂载的情况

 

 

 

 

43_给Linux添加一块新硬盘

说明

下面我们以增加一块硬盘为例来熟悉下磁盘的相关指令和深入理解磁盘分区、挂载、卸载的概念。

 

 

 如何增加一块硬盘

  1. 虚拟机添加硬盘
  2. 分区 fdisk /dev/sdb
  3. 格式化 mkfs -t ext4 /dev/sdb1
  4. 挂载 先创建一个 /home/newdisk,挂载mount /dev/sdb1 /home/newdisk
  5. 设置可以自动挂载(永久挂载,当你重启系统,仍然可以挂载到/home/newdisk)
  1. vim /etc/fstab
  2. 添加内容 /dev/sdb1 /home/newdisk ext4 defaults 0 0
  3. reboot

具体的操作步骤整理

一、

在【虚拟机】菜单中,选择【设置】,然后设备列表里添加硬盘,然后一路【下一步】,中间只有选择磁盘大小的地方需要修改,至到完成。然后重启系统(才能识别)!

 

 

 

 二、

分区命令fdisk /dev/sdb

开始对/sdb分区

  • m 显示命令列表
  • p 显示磁盘分区同fdisk -l
  • n 新增分区
  • d 删除分区
  • w 写入并退出

说明:开始分区后输入n,新增分区,然后选择p,分区类型为主分区。两次回车默认剩余全部空间。最后输入w写入分区并退出,若不保存退出输入q。

 

 

 

三、

格式化磁盘

分区命令mkfs -t ext4 /dev/sdb1

其中 ext4是分区类型

 

四、

挂载:将一个分区与一个目录联系起来

  • mount 设备名称 挂载目录
  • 例如:mount /dev/sdb1 /newdisk
  • umount 设备名称 卸除目录
  • 例如:umount /dev/sdb1或者umount /newdisk
  • 用命令行挂载重启后会失效

五、

永久挂载:通过修改/etc/fstab实现挂载添加完成后执行mount -a即刻生效。

 

 

44_磁盘查询实用指令

查询系统整体磁盘使用情况

  • 基本语法
  • df -h
  • 应用实例
  • 查询系统整体磁盘使用情况

 

 

 

查询指定目录的磁盘占用情况

 

  • 基本语法
  • du -h /目录
  • 查询指定目录的磁盘占用情况,默认为当前目录-s指定目录占用大小汇总
  1. -h 带计量单位
  2. -a 含文件
  3. –max-depth=1 子目录深度
  4. -c 列出明细的同时,增加汇总值
  • 应用实例
  • 查询/opt目录的磁盘占用情况,深度为1
  • du -ach --max-depth=1 /opt

 

磁盘情况-工作实用指令

  • 统计/home文件夹下文件的个数
  • ls -l /home | grep “^-” | wc -l
  • 统计/home文件夹下目录的个数
  • ls -l /home | grep “^d” | wc -l
  • 统计/home文件夹下文件的个数,包括子文件夹里的
  • ls -lR /home | grep “^-” | wc -l
  • 统计文件夹下目录的个数,包括子文件夹里的
  • ls -lR /home | grep “^d” | wc -l

 

  • 以树状显示目录结构
  • tree
  • (没有就安装)yum install tree

 

45_网络配置原理和说明

 

查看虚拟网络编辑器

 

 

 

 

修改IP地址(修改虚拟网络的IP)

 

 

 

 

 查看网关

 

 

 

查看Windows环境中VMnet8网络配置(ipconfig指令)

 

 

 

 

ping测试主机之间网络连通性

 

  • 基本语法
  • ping 目的主机(功能描述:测试当前服务器是否可以连接目的主机)
  • 应用实例
  • 测试当前服务器是否可以连接百度
  • ping www.baidu.com

 

 

46_自动获取IP

Linux网络环境配置第一种方法:自动获取

第一种方法(自动获取):

说明:登陆后,通过界面的来设置自动获取IP

 

 

 

 

 

 

 

 

 特点:Linux启动后会自动获取IP,缺点是每次自动获取的ip地址可能不一样。因此,这个不适用于服务器,因为我们的服务器的IP需要固定的。

 

47_修改配置文件指定IP

Linux网络环境配置第二种方法:指定固定的IP

  • 说明

 

  • 直接修改配置文件来指定IP,并可以连接到外网(推荐),编辑
  • vi /etc/sysconfig/network-scripts/ifcfg-eth0
  • 要求:将ip地址配置的静态的,ip地址为192.168.184.130

 

 

 

 

  • 重启网络
  • service network restart
  • reboot
  • ifconfig指令:查看网络配置
  • ifcfg-eth0文件说明
#接口名(设备,网卡)
DEVICE=etho

#MAC地址
HWADDR=00:0C:2x:6x:Ox:xx

#网络类型(通常是Ethemet)
TYPE=Ethernet

#随机id
UUID=926a57ba-92c6-4231-bacb-f27e5e6a9f44

#系统启动的时候网络接口是否有效(yes/no)
ONBOOT=yes

# IP的配置方法[none|static|bootp|dhcp](引导时不使用协议|静态分配IPIBOOTP协议|DHCP协议)
BOOTPROTO=static

#IP地址
IPADDR=192.168.184.130

#网关
GATEWAY=192.168.184.2

#域名解析器
DNS1=192.168.184.2

48_进程管理 进程介绍和查询

进程基本介绍

  1. 在Linux中,每个执行的程序(代码)都称为一个进程。每一个进程都分配一个ID号
  2. 每一个进程,都会对应一个父进程,而这个父进程可以复制多个子进程。例如www服务器。
  3. 每个进程都可能以两种方式存在的。前台与后台,所谓前台进程就是用户目前的屏幕上可以进行操作的。后台进程则是实际在操作,但由于屏幕上无法着到的进程,通常使用后台方式执行。
  4. 一般系统的服务都是以后台进程的方式存在,而且都会常驻在系统中。直到关机才才结束。

查询系统执行的进程

PS命令是用来查看目前系统中,有哪些正在执行,以及它们执行的状况。可以不加任何参数。

PS显示的信息选项

 

 

 

  • ps -a:显示当前终端的所有进程信息
  • ps -u:以用户的格式显示进程信息
  • ps -x:显示后台进程运行的参数

 

 

 

PS详解

  • 指令: ps -aux | grep xxx
  • 指令说明:

  • System V展示风格
  • USER:用户名称
  • PID:进程号
  • %CPU:进程占用CPU的百分比
  • %MEM:进程占用物理内存的百分比
  • VSZ:进程占用的虚拟内存大小(单位:KB)
  • RSS:进程占用的物理内存大小(单位:KB)
  • T:终端名称,缩写
  • STAT:进程状态,其中:
  • S:睡眠,
  • s:表示该进程是会话的先导进程,
  • N:表示进程拥有比普通优先级更低的优先级,
  • R:正在运行,
  • D:短期等待,
  • Z:僵死进程,
  • T:被跟踪或者被停止
  • 等等
  • STARTED:进程的启动时间
  • TIME:CPU时间,即进程使用CPU的总时间
  • COMMAND:启动进程所用的命令和参数,如果过长会被截断显示

 

  • 案例
  • 比如我看看有没有sshd服务
  • ps -aux | grep sshd

应用实例

要求:以全格式显示当前所有的进程,查看进程的父进程。

  • ps -ef是以全格式显示当前所有的进程
  • -e:显示所有进程
  • -f:全格式
  • ps -ef|grep xxx
  • 是BSD风格
  • UID:用户ID
  • PID:进程ID
  • PPID:父进程ID
  • C:CPU用于计算执行优先级的因子。
  • 数值越大,表明进程是CPU密集型运算,执行优先级会降低
  • 数值越小,表明进程是I/O密集型运算,执行优先级会提高
  • STIME:进程启动的时间
  • TTY:完整的终端名称
  • TIME:CPU时间
  • CMD:启动进程所用的命令和参数

应用案例:查看sshd进程的父进程号是多少,应该怎样?

  • ps -aux | grep sshd

 

 

49_进程管理 终止进程

终止进程kill和killall

  • 介绍
  • 若是某个进程执行一半需要停止时,或是已消了很大的系统资源时,此时可以考虑停止该进程。使用kill命令来完成此项任务。
  • 基本语法
  • killall 进程名称(功能描述:通过进程名称杀死进程,也支持通配符,这在系统因负载过大而变得很慢时很有用)
  • 常用选项
  • -9:表示强迫进程立即停止
  • 最佳实践
  • 案例1:踢掉某个非法登录用户

             

 

 

  •  案例2:终止远程登录服务sshd,在适当时候再次重启sshd服务

                 

  • 案例3:终止多个gedit编辑器
  • killall gedit

 

 

 

  •  案例4:强制杀掉一个终端

     

 

 

 

查看进程树pstree

  • 基本语法
  • pstree [选项] 可以更加直观的来看进程信息
  • 常用选项
  • -p:显示进程的PID
  • -u:显示进程的所属用户
  • 应用实例
  • 案例1:请你树状的形式显示进程的pid
  • pstree -p
  • 案例2:请你树状的形式进程的用户id
  • pstree -u

 

50_进程管理 服务管理

  • 介绍
  • 服务(service)本质就是进程,但是是运行在后台的,通常都会监听某个端口,等待其它程序的请求,比如(mysql , sshd 防火墙等),因此我们又称为守护进程,是Linux中非常重要的知识点。

            

 

 

  •  指令
  • service 服务名 start [stop | restart | reload | status]
  • 在CentOS 7.0后不再使用service,而是systemctl
  • systemctl

 

  • 使用案例
  • 查看当前防火墙的状况,关闭防火墙和重启防火墙。

 

 

 

 

 

 

  • 细节讨论
  • 关闭或者启用防火墙后,立即生效。[telne t测试某个端口即可]
  • telnet [ip地址] [端口号]
  • 这种方式只是临时生效,当重启系统后,还是回归以前对服务的设置。chankan
  • 如果希望设置某个服务自启动或关闭永久生效,要使用chkconfig指令

 

  • 查看服务名
  • 使用setup->系统服务就可以看到。
  • /etc/init.d/ 服务名称
  • ls -l /etc/init.d

 

  • 服务的运行级别(runlevel):
  • 查看或者修改默认级别: vi /etc/inittab
  • Linux系统有7种运行级别(runlevel):(常用的是级别3和5)
  • 运行级别0:系统停机状态,系统默认运行级别不能设为0,否则不能正常启动
  • 运行级别1:单用户工作状态,root权限,用于系统维护,禁止远程登陆
  • 运行级别2:多用户状态(没有NFS),不支持网络
  • 运行级别3:完全的多用户状态(有NFS),登陆后进入控制台命令行模式
  • 运行级别4:系统未使用,保留
  • 运行级别5:X11控制台,登陆后进入图形GUI模式
  • 运行级别6:系统正常关闭并重启,默认运行级别不能设为6,否则不能正常启动

开机的流程说明:

 

 

  • chkconfig指令

 

  • 介绍
  • 通过chkconfig命令可以给各个运行级别设置自启动/关闭

 

  • 基本语法
  • 查看服务
  • chkconfig --list | grep 服务名
  • chkconfig 服务名 --list
  • chkconfig --level 5 服务名 on/off
  • 例如:请将sshd服务在运行级别为5的情况下,不要自启动
  • chkconfig --level 5 sshd off

 

  • 应用实例
  • 案例1:请显示当前系统所有服务的各个运行级别的运行状态
  • chkconfig --list
  • 案例2:请查看sshd服务的运行状态
  • service sshd status
  • 案例3:将sshd服务在运行级别5下设置为不自动启动,看看有什么效果?
  • chkconfig --level 5 sshd off
  • 案例4:当运行级别为5时,关闭防火墙。
  • chkconfig --level 5 iptables off
  • 案例5:在所有运行级别下,关闭防火墙
  • chkconfig iptables off
  • 案例6:在所有运行级别下,开启防火墙
  • chkconfig iptables on

 

  • 使用细节
  • chkconfig重新设置服务后自启动或关闭,需要重启机器reboot才能生效.

 

 

 

51_进程管理 监控服务

动态监控进程

  • 介绍
  • top与ps命令很相似。它们都用来显示正在执行的进程。top与ps最大的不同之处,在于top在执行一段时间可以更新正在运行的的进程。
  • 基本语法
  • top [选项]
  • 选项说明

  • 交互操作说明

 

 

 

 

 

  •  应用实例
  • 案例1:监视特定用户
  • top:输入此命令,按回车键,查看执行的进程。
  • u:然后输入“u“回车,再输入用户名,即可

              

 

 

  • 案例2:终止指定的进程
  • top:输入此命令,按回车键,查看执行的进程。

 

  •  k:然后输入“k”回车,再输入要结策的进程ID号

             

 

 

  •  案例3:指定系统状态更新的时间(每隔10秒自动更新,默认是3秒
  • top -d 10

 

监控网络状态

查看系统网络情况netstat

  • 基本语法
  • netstat[选项]
  • 选项说明
  • -an 按一定顺序排列输出
  • -p 显示哪个进程在调用
  • 应用案例
  • 查看系统所有的网络服务
  • netstat -anp | more
  • 请查看服务名为sshd 的服务的信息
  • netstat -anp | grep sshd

检测主机连接命令ping

 

  • ping是一种网络检测检测工具,它主要是用检测远程主机是否正常,或是两部主机间的介质是否为断、网线是否脱落或网卡故障。
  • 如:ping对方ip地址

 

52_RPM包管理

介绍

一种用于互联网下载包的打包及安装工具,它包含在某些Linux分发版中。它生成具有RPM扩展名的文件。RPM是RedHat Package Manager(RedHat软件包管理工具)的缩写,类似windows的setup.exe,这一文件格式名称虽然打上了RedHat的标志,但理念是通用的。

Linux的分发版本都有采用(suse,redhat,centos等等),可以算是公认的行业标准了。

 

rpm包的简单查询指令

查询已安装的rpm列表rpm -qa l grep xx

 

rpm包名基本格式

一个rpm包名:firefox-45.0.1-1.el6.centos.x86_64.rpm

  • 名称:firefox
  • 版本号:45.0.1-1
  • 适用操作系统:el6.centos.x86_64
    • 表示centos6.x的64位系统
    • 如果是i686、i386表示32位系统,noarch表示通用。

 

rpm包的其它查询指令

  • rpm-qa:查询所安装的所有rpm软件包
  • rpm-qa | more
  • rpm-qa | grep xxx [rpm -qa | grep firefox ]
  • rpm -q 软件包名:查询软件包是否安装
  • rpm -q firefox

 

  • rpm -qi 软件包名:查询软件包信息
  • rpm -qi firefox

 

  • rpm -ql 软件包名:查询软件包中的文件
  • rpm -ql firefox

 

  • rpm -qf 文件全路径名:查询文件所属的软件包
  • rpm -qf /etc/passwd
  • rpm -qf /root/install.log

卸载rpm包

  • 基本语法
  • rpm -e RPM包的名称
  • 应用案例
  • 删除firefox软件包
  • rpm -e firefox
  • 细节讨论
  • 如果其它软件包依赖于您要卸载的软件包,卸载时则会产生错误信息
  • 如:rpm -e foo removing these packages would break dependencies:foo is needed by bar-1.0-1
  • 如果我们就是要删除foo这个rpm包,可以增加参数–nodeps,就可以强制删除,但是一般不推荐这样做,因为依赖于该软件包的程序可能无法运行
  • 如:​rpm -e --nodeps foo

 

 

安装rpm包

  • 基本语法
  • rpm -ivh RPM包全路径名称
  • 参数说明
  • i=install
  • 安装 v=verbose提示
  • h=hash 进度条
  • 应用实例
  • 演示卸载和安装firefox浏览器
  • 先找到firefox的安装rpm包,你需要挂载上我们安装centos的iso文件,然后到/media下去找rpm找。
  • 虚拟机可以按照以下方式挂载iso

          

 

 

 

  • cp firefox-45.0.1-1.el6.centos,x86_64.rpm /opt/
  • rpm -ivh firefox-45.0.1-1.el6.centos.x86_64.rpm

 

53_YUM

  • 简介
  • yum是一个shell前端软件包管理器。基于RPM包管理,能够从指定的服务器自动下载RPM包并且安装,可以自动处理依赖性关系,并且一次安装所有依赖的软件包。
  • 基本指令
  • 查询yum服务器是否有需要安装的软件
  • yum list | grep xxx软件列表
  • 安装指定的yum包
  • yum install xxx 下载安装yum
  • 应用实例
  • 案例:请使用yum的方式来安装firefox
  • 先查看以下firefox rpm在yum服务器有没有
  • yum list | grep firefox
  • 安装 yum install firefox

 

JavaEE定制篇

54_JDK安装和配置

 

 

 如果需要在Linux下进行JavaEE的开发,我们需要安装如下软件

 

 

 安装步骤

  1. 先将软件通过xftp5上传到 /opt 下
  2. 解压缩到/opt
  3. 打开配置文件vim /etc/profile,在末尾添加以下环境变量
  1. JAVA_HOME=/opt/jdk1.7.0_79
  2. PATH=/opt/jdk1.7.0_79/bin:$PATH
  3. export JAVA_HOME PATH
  4. reboot,环境变量才能生效
  5. 在任何目录下就可以使用java和javac

 

测试是否安装成功

  • 编写一个简单的Hello.java输出"hello world!"

 

55_Tomcat安装和配置

  • 步骤

 

  1. 解压缩到/opt

  2. 启动tomcat ./bin/startup.sh

    1. 内网可访问
    2. 外网却访问不行(防火墙缘故)
  3. 开放端口8080 vim /etc/sysconfig/iptables

  4. 重启防火墙

测试是否安装成功

  • 在Windows、Linux下访问http://(本机IP地址):8080

 

56_Eclipse安装和配置

步骤

  1. 解压缩到/opt
  2. 启动eclipse,配置jre和server。启动可以如下:
    1. 创建一个快捷方式
    2. 进入eclipse解压后的文件夹,然后执行./eclipse即可
  3. 编写Hello world程序并测试成功
  4. 编写jsp页面,并测试成功!

 

57_MySQL安装和配置

编译安装MySQL 5.6.14

一、卸载旧版本

使用下面的命令检查是否安装有MySQL Server,有的话通过下面的命令来卸载掉

pm -qa | grep mysql

目前我们查询到的是这样的:

[root@lsp~]# rpm -ga | grep mysal
mysql-libs-5.1.73-7.el6.x86_64

如果查询到了,就删除吧

rpm -e mysql_libs //普通删除模式
rpm -e --nodeps mysql_libs //强力删除模式,如果使用上面命令删除时,提示有依赖的其它文件,则用该命令可以对其进行强力删除

二、编译安装MySQL

安装编译代码需要的包

yum -y install make gcc-c++ cmake bison-devel ncurses-devel

下载 MySQL 5.6.14(官网下载)

tar -xvf mysql-5.6.14.tar.gz
cd mysql-5.6.14

编译准备工作:

cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql
-DMYSQL_DATADIR=/usr/local/mysql/data-DSYSCONFDIR=/etc
-DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1
-DWTH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1
-DMYSQL_UNIX_ADDR=/var/lib/mysql/mysql.sock -DMYSQL_TCP_PORT=3306
-DENABLED_LOCAL_INFLE=1 -DWITH_PARTITION_STORAGE_ENGINE=1
-DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8
-DDEFAULT_COLLATION=utf8_general_ci

真正的编译:

make && make install

整个过程需要30分钟左右…漫长的等待

三、配置MySQL

设置权限

使用下面的命令查看是否有mysql用户及用户组

cat /etc/passwd 查看用户列表
cat /etc/group 查看用户组列表

如果没有就创建

groupadd mysql
useradd -g mysql mysql

修改/usr/local/mysql权限

chown -R mysql:mysql/usr/local/mysql

初始化配置,进不安装路径(在执行下面的指令),执行初始化配置脚本,创建系统自带的数据库和表

cd /usr/local/mysql

scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --user=mysql

注意:在启动MySQL服务时,会按照一定次序搜索my.cnf,先在/etc目录下找,找不到则会搜索"$basedir/my.cnf”,在本例中就是/usr/local/mysql/my.cnf,这是新版MySQL的配置文件的默认位置!

注意:在CentOS6.8 版操作系统的最小安装完成后,在/etc目录下会存在一个my.cnf,需要将此文件更名为其他的名字,如:/etc/my.cnf.bak,否则,该文件会干扰源码安装的MySQL的正确配置,造成无法启动。
修改名称防止干扰:mv /etc/my.cnf /etc/my.cnf.bak

 

四、启动并使用MySQL

添加服务,拷贝服务脚本到init.d目录,并设置开机启动

注意:在/usr/local/mysql下执行

cp support-files/mysql.server /etc/init.d/mysql
chkconfig mysql on
service mysql start --启动MySQL

执行下面的命令修改root密码

cd /usr/local/mysql/bin
./mysql -u root -p (注意初始密码为空格,直接回车) mysql> SET PASSWORD = PASSWORD('root');

 

五、添加MySQL环境变量

  • vim /etc/profile
  • PATH=/usr/local/mysql/bin:$PATH
  • source /etc/profile

这样在终端输入mysql就可启动mysql

 

 

大数据定制篇

58_Shell快速入门

为什么要学习Shell编程?

Linux运维工程师在进行服务器集群管理时,需要编写shell程序来进行服务器管理。

对于JavaEE和Python程序员来说,因工作的需要,你会编写一些Shell脚本进行程序或者是服务器的维护,比如编写一个定时备份数据库的脚本。

对于大数据程序员来说,需要编写Shell程序来管理集群。

Shell是什么?

Shell是一个命令行解释器,它为用户提供了一个向Linux内核发送请求以便运行程序的界面系统级程序,用户可以用Shell来启动、挂起、停止甚至是编写―些程序。

 

Shell脚本的执行方式

脚本格式要求

  1. 脚本以# ! /bin/bash开头
  2. 脚本需要有可执行权限

编写第一个shell脚本

  • 需求说明:创建一个shell脚本,输出hello world!
#!/bin/bash
echo "hello,world!"

脚本的常用执行方式

  • 方式1(输入脚本的绝对路径或相对路径)
  • 首先要赋予helloworld.sh脚本的+x权限
  • chmod 744 myShell.sh
  • 执行脚本
  • ./myShell.sh

 

  • 方式2(sh+脚本)
  • 说明:不用赋予脚本+x权限,直接执行即可。(不推荐)
  • sh myShell.sh

 

 

59_Shell变量

Shell的变量的介绍

  1. Linux Shell中的变量分为,系统变量和用户自定义变量。

  2. 系统变量:$HOME、$PWD、 $SHELL、$USER等等,比如: echo $HOME等等。

  3. 显示当前shell中所有变量:set

# !/bin/bash
echo "PATH=$PATH" #输出系统变量
echo "user=$USER"

Shell变量的定义

 

  • 基本语法
  • 定义变量:变量=值
  • 撤销变量:unset变量
  • 声明静态变量:readonly变量,注意:不能unset
  • 获取变量:$变量

 

  • 快速入门
  • 案例1:定义变量A
  • A=100
  • 案例2:撤销变量A
  • unset A
  • 案例3:声明静态的变量B=2,不能unset
  • readonly B=2
  • 如果unset B,会输出 unset: B: cannot unset: readonly variable
  • 案例4:可把变量提升为全局环境变量,可供其他shell程序使用

 

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

 

  • 将命令的返回值赋给变量
  • A= ` ls -la`反引号,运行里面的命令,并把结果返回给变量A
  • A=$(ls -la)等价于反引号

 

60_Shell环境变量

设置环境变量

  • 基本语法
  1. export 变量名=变量值(功能描述:将shell变量输出为环境变量)
  2. source 配置文件(功能描述:让修改后的配置信息立即生效)
  3. echo $变量名(功能描述:输出环境变量的值)
  • 快速入门

  

  1. 在/etc/profile文件中定义TOMCAT_HOME环境变量

 

  1. TOMCAT_HOME=/opt/tomcat
  2. export TOMCAT_HOME

 

    2.查看环境变量TOMCAT_HOME的值

  1. echo $TOMCAT_HOME

 

 3.在另外一个shell程序中使用TOMCAT_HOME

  1. echo $TOMCAT_HOME

 

  • 注意:在输出JAVA_HOME环境变量前,需要让其生效source /etc/profile

 

多行注释

:<<!
...
!

 

61_Shell位置参数变量

  • 介绍
  • 当我们执行一个shell脚本时,如果希望获取到命令行的参数信息,就可以使用到位置参数变量
  • 比如:./myshell.sh 100 200,这个就是一个执行shell的命令行,可以在myshel脚本中获取到参数信息
  • 基本语法
  • $n(功能描述:n为数字,$0代表命令本身,$1-$9代表第一到第九个参数,十个及以上的参数需要用大括号包含,如${10})
  • $*(功能描述:这个变量代表命令行中所有的参数,$*把所有的参数看成一个整体)
  • $@(功能描述:这个变量也代表命令行中所有的参数,不过$@把每个参数区分对待)
  • $#(功能描述:这个变量代表命令行中所有参数的个数)
  • 位置参数变量
  • 应用案例:编写一个shell脚本 positionPara.sh,在脚本中获取到命令行的各个参数信息。
#!/bin/bash
#获取到各个参数
echo "$0 $1 $2"
echo "$*"
echo "$@"
echo "参数个新=$#"

执行脚本

./positionPara.sh 30 60

输出结果

./positionPara.sh 30 60
30 60
30 60
参数个数=2

62_Shell预定义变量

  • 基本介绍
  • 就是shell设计者事先已经定义好的变量,可以直接在shell脚本中使用
  • 基本语法
  • $$(功能描述:当前进程的进程号(PID))
  • $!(功能描述:后台运行的最后一个进程的进程号(PID) )
  • $?(功能描述:最后一次执行的命令的返回状态。)
  • 如果这个变量的值为0,证明上一个命令正确执行;
  • 如果这个变量的值为非0(具体是哪个数,由命令自己来决定),则证明上一个命令执行不正确了。)
  • 应用实例
  • 在一个shell脚本中简单使用一下预定义变量
#!/bin/bash
echo “当前的进程号=$$"
#后台的方式运行myShell.sh
./myShell.sh &&
echo "最后的进程的号=$!"
echo "执行的值=$?"

shell脚本的&& 和||命令逻辑

 

  • && 运算符
  • 基础格式:commad1 && commad2
  • 表示左边commad1 命令执行成功后,&& 后面commad2 命令才会被执行。
  • 如果commad1 命令没被执行成功,&& 后面的commad2 命令不会被执行。
  • ||运算符
  • 基础格式:commad1 || commad2
  • 如果commad1 执行没成功,则执行||后面的commad2
  • 如果commad1执行成功,则不执行||后面的commad2

 

63_Shell运算符

  • 基本介绍
  • 学习如何在shell中进行各种运算操作。
  • 基本语法
  • $((运算式))”或“$[运算式]”
  • expr m +n(注意expr运算符间要有空格)
  • expr m - n
  • expr \*, /, %(乘,除,取余)

  • 应用实例
  • 案例1:计算(2 + 3) x 4的值
  • $(((2+3) *5))
  • $[(2+3) * 4] //推荐
  • 使用expr
  • TEMP=` expr 2 + 3`
  • RESULT3=`expr $TEMP \* 4`
  • 案例2:请求出命令行的两个参数的和
  • RESULT4=$[$1+$2]

 

 

64_Shell判断语句

  • 基本语法
  • [condition](注意condition前后要有空格)
  • #非空返回true,可使用$?验证(0为true,>1为false)
  • 应用实例
  • [abc] 返回true
  • [] 返回false
  • [condition] && echo OK || echo notok 条件满足,执行后面的语句
  • 判断语句 - 常用判断条件
  • 两个整数的比较
  • = 字符串比较
  • -lt 小于
  • -le 小于等于
  • -eq 等于
  • -gt 大于
  • -ge 大于等于
  • -ne 不等于
  • 按照文件权限进行判断
  • -r 有读的权限
  • -w 有写的权限
  • -x 有执行的权限
  • 按照文件类型进行判断
  • -f 文件存在并且是一个常规的文件
  • -e 文件存在
  • -d 文件存在并是一个目录
  • 应用实例
  • 案例1:“ok"是否等于"ok”
  • 案例2:23是否大于等于22
  • 案例2:/root/install.log目录中的文件是否存在

 

#!/bin/bash
#案例1:"ok"是否等于"ok"
if [ "ok100" = "ok" ]
then
    echo "equal"
fi
#案例2:23是否大于等于22
if [ 23 -gt 22 ]
then
    echo "大于"
fi
#案例3: /root/shell/aaa.txt目录中的文件是否存在
if [ -e /root/shell/aaa.txt ]
then
    echo "存在“
fi

65_Shell流程控制if

  • 基本语法
if [ 条件判断式 ]
    then 程序
fi

#或者

if [ 条件判断式 ]
    then 程序
elif [ 条件判断式 ]
    then 程序
fi
  • 注意事项
  • [ 条件判断式 ],中括号和条件判断式之间必须有空格
  • 推荐使用第二种方式
  • 应用实例
  • 请编写一个shell程序,如果输入的参数,大于等于60,则输出"及格了",如果小于60,则输出"不及格"。
# !/bin/bash
#案例:请编写一个shell程序,如果输入的参数,大于等于60,则输出“及格了",如果小于60,则输出“不及格"
if [ $1 -ge 60 ]
then
    echo "及格了”
elif [ $1 -lt 60 ]
then
    echo "不及格"
fi

66_Shell流程控制case

  • 基本语法
case $变量名 in
"值1")
如果变量的值等于值1,则执行程序1
;;
"值2")
如果变量的值等于值2,则执行程序2
;;
...省略其他分支...
*)
如果变量的值都不是以上的值,则执行此程序
;;
esac
  • 应用实例
  • 案例1:当命令行参数是1时,输出"周一",是2时,就输出"周二",其它情况输出“other"。
#!/bin/bash
#案例1:当命令行参数是1时,输出“周一",是2时,就输出"周二",其它情况输出“other"
case $1 in
"1")
echo "周一"
;;
"2")
echo "周二";
;;
*)
echo "other"
;;
esac

67_Shell流程控制for

  • 基本语法1
for 变量 in 值1 值2 值3...
do
程序
done
  • 应用实例
  • 案例1:打印命令行输入的参数 [这里可以看出 ∗ 和 *和 ∗和@的区别]
#! /bin/bash
#案例1 :打印命令行输入的参数
#使用$*
for i in "$*"
do
    echo "the num is $i"
done
echo "============================"
#使用$@
for j in "$@"
do
    echo "the num is $j"
done

输出结果

 

 

 

  • 基本语法2
for((初始值;循环控制条件;变量变化))
do
程序
done
  • 应用实例
  • 案例1:从1加到100的值输出显示
#!/bin/bash
#案例1 :从1加到100的值输出显示
#定义一个变量
SUM=0
for((i=1; i<=100; i++))
do
    SUM=$[$SUM+$i]
done
echo "sum=$SUM"

68_Shell流程控制while

  • 基本语法
while [ 条件判断式 ]
do
程序
done
  • 应用实例
  • 案例1:从命令行输入一个数n,统计从1+…+ n的值是多少?
#案例1:从命令行输入一个数n,统计从1 + ... + n 的值是多少

SUM=0
i=0
while[ $i -le $1 ]
do
    SUM=$[$SUM+$i]
    i=$[$i+1]
done
echo "sum= $SUM"

69_Shell读取控制台输入

  • 基本语法
  • read (选项) (参数)
  • 选项:
  • -p:指定读取值时的提示符;
  • -t:指定读取值时等待的时间(秒),如果没有在指定的时间内输入,就不再等待了。
  • 参数
  • 变量:指定读取值的变量名
  • 应用实例
  • 案例1:读取控制台输入一个num值
  • 案例2:读取控制台输入一个num值,在10秒内输入。
#!/bin/bash
#案例1:读取控制台输入一个num值
read -p "请输入一个数num1=" NUM1
echo "你输入的值是num1=$NUM1"

#案例2:读取控制台输入一个num值,在10秒内输入
read -t 10 -p "请输入一个数num2=" NUM2
echo "你输入的值是num2=$NUN2"

 

70_Shell系统函数简介

  • 函数介绍
  • shell编程和其它编程语言一样,有系统函数,也可以自定义函数。系统函数中,我们这里就介绍两个。
  • 系统函数
  • basename基本语法
  • basename [pathname/string] [suffix]
  • 功能:basename命令会删掉所有的前缀包括最后一个(’/’)字符,然后将字符串显示出来,常用于获取文件名
  • 选项:
  • suffix为后缀,如果suffix被指定了,basename会将pathname或string中的suffix去掉。
  • 应用实例
  • 案例1:请返回/home/aaa/test.txt 的"test.txt"部分
  • basename /home/aaa/test.txt
  • 输出:test.txt
  • basename /home/aaa/test.txt .txt
  • 输出:test
  • dirname基本语法
  • 功能:从给定的包含绝对路径的文件名中去除文件名(非目录的部分),然后返回剩下的路径(目录的部分),常用于返回路径部分
  • dirname 文件绝对路径(功能描述﹔)
  • 应用实例
  • 案例1:请返回/home/aaa/test.txt 的/home/aaa
  • dirname /home/aaa/test/txt
  • 输出/home/aaa

 

 

71_Shell自定义函数

  • 基本语法
  • 调用直接写函数名:funname [值]
[ function ] funname[()]{
    Action;
    [return int;]
}
  • 应用实例
  • 案例1:计算输入两个参数的和
# !/bin/bash
#案例1:计算输入两个参数的和(read) , getSum

function getSum(){
    SUM=$[$n1+$n2]
    echo "和是=$SUM"
}

read -p "请输入第一个数n1" n1
read -p "请输入第二个数n2" n2

#调用getSum
getSum $n1 $n2

 

72_Shell定时维护数据库

需求分析

  1. 1.每天凌晨2:10备份数据库atguiguDB到/data/backup/db
  2. 2.备份开始和备份结束能够给出相应的提示信息
  3. 3.备份后的文件要求以备份时间为文件名,并打包成.tar.gz的形式,比如:2018-03-12_230201.tar.gz
  4. 4.在备份的同时,检查是否有10天前备份的数据库文件,如果有就将其删除。

 

 

 

 脚本源码:

#!/bin/bash
#完成数据库的定时备份。#备份的路径
BACKUP=/data/backup/db#当前的时间作为文件名
DATETIME=$(date +%Y_%m_%d_%H%M%S)
#可以输出变量调试
echo ${DATETIME}
echo "=======开始备份======="
echo "=======备份的路径是$BACKUP/$DATETIME.tar.gz"

#主机
HOST=localhost

#用户名
DB_USER=root

#密码
DB_PWD=root

#备份数据库名
DATEBASE=atguiguDB

#创建备份的路径
#如果备份的路径文件夹存在,就使用,否则就创建
[ ! -d "$BACKUP/$DATETIME" ] && mkdir -p "$BACKUP/$DATETIME"

#执行mysql的备份数据库的指令
mysqldump -u${DB_USER} -p${DB_PMD} --host=$HOST $DATABASE | gzip > $BACKUP/$DATETIME/$DATETIME.sql.gz

#打包备份文件
cd $BACKUP
tar -zcvf $DATETIME.tar.gz $DATETIME

#删除临时目录
rm -rf $BACKUP/$DATETIME

#删除10天前的备份文件
find $BACKUP -mtime +10 -name "*.tar.gz" -exec rm -rf\;
echo "=====备份文件成功====="

设计定时任务

crontab -e

 

10 2 * * * /usr/sinb/mysql_db_backup.sh

 

71_Shell自定义函数

posted @ 2021-07-30 15:50  随★风  阅读(58)  评论(0编辑  收藏  举报