当前位置:首页 > 技术分享 > 正文内容

Linux操作指南

admin1年前 (2023-12-09)技术分享1237
   
 


Linux简介

Linux是一种自由和开放源码的操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、台式计算机。

   
 


【Linux起源】

Linux出现于1991年,是由芬兰赫尔辛基大学学生Linus Torvalds和后来加入的众多爱好者共同开发完成


【Linux特点】

多用户,多任务,丰富的网络功能,可靠的系统安全,良好的可移植性,具有标准兼容性,良好的用户界面,出色的速度性能

  • 开源

CentOS

主流:目前的Linux操作系统主要应用于生产环境,主流企业级Linux系统仍旧是RedHat或者CentOS


  • 免费

RedHat 和CentOS差别不大,基于Red Hat Linux 提供的可自由使用源代码的企业CentOS是一个级Linux发行版本


  • 更新方便:

CentOS独有的yum命令支持在线升级,可以即时更新系统,不像RedHat 那样需要花钱购买支持服务!


Linux用户介绍

Linux用户通常分为两类:

   


管理员用户(root)

$ 普通用户(类似Windows上的普通用户)

Linux登陆系统后,默认当前所在目录为用户主目录,类似Windows登陆系统后,默认的所在目录为桌面

管理员(root)登陆系统后默认目录为/root\

普通用户登陆系统后默认目录为/home/username,username为用户名。


文件类型

在Linux中,使用命令查看文件,首字母会标记该文件的文件类型,一般有以下几种类型:

   


  • – : 普通文件

  • d: 目录文件

  • b:块文件

  • c:字符文件

  • l:符号链接文件

  • p:管道文件pipe

  • s:套字节文件socket

   


Linux文件 属主 和 属组:

  • 在 Linux 系统中,用户是按组分类的,一个用户属于一个或多个组。

  • 文件拥有者以外的用户又可以分为 文件拥有者的同组用户 和 其他用户 。

  • 因此,Linux 系统按文件拥有者、文件拥有者同组用户和其他用户来规定了不同的文件访问权限。

bin 文件是一个目录文件,属主和属组都为 root,属主有可读、可写、可执行的权限;与属主同组的其他用户有可读和可执行的权限;其他用户也有可读和可执行的权限。


文件系统结构总结:

  • Linux的目录中只有一个根目录 “ / ”

  • Linux的各个目录存放的内容是规划好的,不要乱放文件。

  • Linux是以文件的形式管理设备的,因此Linux系统中一切皆为文件。

  • Linux的各个文件目录下存放什么内容,需要有一个准确的认识。


Linux目录结构

   
 


   


与 Windows 操作系统不同的是,Linux 目录结构都是规划好的,文件不能随意放置,比如常用的指令存于 /bin 目录,配置文件、配置环境存于 /etc 目录等等。

   


├── bin -> usr/bin # 用于存放二进制命令

├── boot # 内核及引导系统程序所在的目录

├── dev # 所有设备文件的目录(如磁盘、光驱等)

├── etc # 配置文件默认路径、服务启动命令存放目录

├── home # 用户家目录,root用户为/root

├── lib -> usr/lib # 32位库文件存放目录

├── lib64 -> usr/lib64 # 64位库文件存放目录

├── media # 媒体文件存放目录

├── mnt # 临时挂载设备目录

├── opt # 自定义软件安装存放目录

├── proc # 进程及内核信息存放目录

├── root # Root用户家目录

├── run # 系统运行时产生临时文件,存放目录

├── sbin -> usr/sbin # 系统管理命令存放目录

├── srv # 服务启动之后需要访问的数据目录

├── sys # 系统使用目录

├── tmp # 临时文件目录

├── usr # 系统命令和帮助文件目录

└── var # 存放内容易变的文件的目录


【特别指出目录下的一些特殊功能】

(1)/etc目录

这个目录主要放置的一些配置文件,比如我们使用yum安装的mysql,redis,PHP,nginx的配置文件都会在etc这个目录下

这个目录也是有几个重要的配置文件的

   
 


   
 



(2)/usr目录

这个目录主要存放一些应用程序,这里边最常用的一个目录就是local这个目录了,加入我们在使用编译方式安装软件时就会把软件默认安装在local这个目录下

   
 


(3)/var目录

这个目录就是主要存储日志信息,在进行一下资料查询时,有一部分的资料说明,我们使用的web目录也应该放置在var这个目录下, 所以你们平时把web目录都在那个目录下存放着,咱们评论区见

var目录下,就这个log这个目录是咱们最经常使用的,因为这个里边保存着我们平时产生的日志文件

   
 


(4)/dev目录

这个目录在我开发的过程当中是没有使用到的,这个目录就是主要是系统的所有设备文件

   
 


(5)/proc目录

此目录是一个虚拟目录,目录中所有信息都是内存的映射,通过这个虚拟的内存映射目录,可以和内核内部数据结构进行交互,获取有关进程的有用信息,同时也可以在系统运行中修改内核参数。与其他目录不同,/proc存在于内存中,而不是硬盘上。

   
 


(6)其他目录/boot目录:

该目录存放的是启动Linux时的一些核心文件,具体包含一些镜像文件和链接文件,因此这个目录非常重要,如果遭到破坏,系统将无法启动。


Linux中的绝对路径与相对路径关系

用户目录

也可将所谓的路径(path)定义为绝对路径(absolute)与相对路径(relative)。 这两种文件名/路径的写法依据是这样的:

绝对路径:

由根目录(/)开始写起的文件名或目录名称, 例如 /home/dmtsai/.bashrc;

相对路径:

相对于目前路径的文件名写法。 例如 ./home/dmtsai 或

http://www.cnblogs.com/home/dmtsai/ 等等。反正开头不是 / 就属于相对路径的写法

你在 /home 底下,要回到上一层 (../) 之后,才能继续往 /var 来移动的,特别注意这两个特殊的目录:

. :代表当前的目录,也可以使用 ./ 来表示;

.. :代表上一层目录,也可以 ../ 来代表。

根目录下的.和…都表示当前目录

文件的颜色

含义

蓝色

目录

绿色

可执行文件

红色

压缩文件

浅蓝色

链接文件

灰色

其他文件


Linux 操作系统运行级别

Linux 中共有七个运行级别:使用命令 init 级别 进行切换,举例:init 选项【0~6】

  • 0:关机

  • 1:单用户(该模式便于找回丢失的密码)

  • 2:多用户状态无网络服务(基本不用)

  • 3:多用户状态有网络服务(用得最多)

  • 4:系统未使用的保留给用户

  • 5:图形界面(在虚拟机中的演示操作就是此级别)

  • 6:系统重启


指定运行级别

CentOS 7 之前,是在 /etc/inittab 文件中修改系统的运行级别,

CentOS 7 之后 multi-user.target 等价于级别3,graphical.target 等价于级别5。

我们可以使用命令 systemctl get-default 查看当前运行级别;命令 systemctl set-default 级别 设置默认级别。


命令行基本操作

Linux命令格式:command [-options] [parameter1] …

说明:

  • command :命令名,相应功能的英文单词或单词的缩写

  • [-options] :选项,可以用来对命令进行控制,也可以省略

  • parameter :传给命令的参数,可以是 零个、一个 或者 多个


常用Linux命令的基本实用

  • Linux 刚面世时并没有图形界面,所有的操作全靠命令完成,如磁盘操作、文件存取、目录操作、进程管理、文件权限 设定等

  • 在职场中,大量的 服务器维护工作 都是在 远程 通过 SSH 客户端 来完成的,并没有图形界面,所有的维护工作都需要通过命令来完成

  • 在职场中,作为后端程序员,必须要或多或少地掌握一些 Linux 常用的终端命令

  • Linux 发行版本的命令大概有 200 多个,但是常用的命令只有 10 多个而已


【小技巧1】:

ctrl + shift + = 放大终端窗口的字体显示

ctrl + - 缩小终端窗口的字体显示


【自动补全】:

在敲出 文件 / 目录 / 命令 的前几个字母之后,按下 tab 键

如果输入的没有歧义,系统会自动补全

如果还存在其他 文件 / 目录 / 命令 ,再按一下 tab 键,系统会提示可能存在的命令


【小技巧2】:

按 上 / 下 光标键可以在曾经使用过的命令之间来回切换

如果想要退出选择,并且不想执行当前选中的命令,可以按 ctrl + c


   
 


一、基本命令

Linux命令格式:

command [-options] [parameter1] …

command: 命令名;

[-options]:选项,可用来对命令进行控制,也可以省略,

[ ]代表可选

parameter1 …:传给命令的参数:可以是零个一个或多个


登录与注销

1) sudo useradd lilei //添加用户 (不能被立即使用,需设置密码 sudo passwd lilei)

2) sudo adduser lilei //添加用户

3) login //登录或切换用户

4) logout //注销用户(命令行) exit(shell-退出控制台)

5) shutdown -h 10 //10分钟后自动关机 shutdown -c //取消

6) halt(root用户) //关闭所有进程后自动关机

7) poweroff //同上

8) shutdown -r 10 //十分钟后自动重启

9) init 6 //重启 (0-停机,1-单用户,2-多用户,3-完全多用户,4-图形化,5-安全模式,6-重启)

10) reboot //重启


   
 


help

一般是linux命令自带的帮助信息

如:ls --help


man(manual)

man是linux提供的一个手册,包含了绝大部分的命令、函数使用说明

该手册分成很多章节(section),使用man时可以指定不同的章节来浏览。

例:man ls ; man 2 printf

man中各个section意义如下:

Standard commands(标准命令)

System calls(系统调用,如open,write)

Library functions(库函数,如printf,fopen)

Special devices(设备文件的说明,/dev下各种设备)

File formats(文件格式,如passwd)

Games and toys(游戏和娱乐)

Miscellaneous(杂项、惯例与协定等,例如Linux档案系统、网络协定、ASCII 码;environ全局变量)

Administrative Commands(管理员命令,如ifconfig)

man是按照手册的章节号的顺序进行搜索的。


man设置了如下的功能键:

功能键

功能

空格键

显示手册页的下一屏

Enter键

一次滚动手册页的一行

b

回滚一屏

f

前滚一屏

q

退出man命令

h

列出所有功能键

/word

搜索word字符串


   
 


注意:实际上,我们不用指定第几个章节也用查看,如,man ls


history游览历史

当系统执行过一些命令后,可按上下键翻看以前的命令,history将执行过的命令列举出来

history保留了最近执行的命令记录,默认可以保留1000。

历史清单从0开始编号到最大值。

常见用法:

history N 显示最近N条命令

history -c 清除所有的历史记录

history -w xxx.txt 保存历史记录到文本xxx.txt


命令行中的ctrl组合键

Ctrl+c 结束正在运行的程序

Ctrl+d 结束输入或退出shell

Ctrl+s 暂停屏幕输出【锁住终端】

Ctrl+q 恢复屏幕输出【解锁终端】

Ctrl+l 清屏,【是字母L的小写】等同于Clear

当前光标到行首:ctrl+a

当前光标到行尾:ctrl+e

删除当前光标到行首:ctrl+u

删除当前光标到行尾:ctrl+k

Ctrl+y 在光标处粘贴剪切的内容

Ctrl+r 查找历史命令【输入关键字,就能调出以前执行过的命令】

Ctrl+t 调换光标所在处于其之前字符位置,并把光标移到下个字符

Ctrl+x+u 撤销操作

Ctrl+z 转入后台运行


1.1 关机和重启

关机

shutdown -h now 立刻关机

shutdown -h 5 5分钟后关机

poweroff 立刻关机

重启

shutdown -r now 立刻重启

shutdown -r 5 5分钟后重启

reboot 立刻重启


1.2 帮助命令

--help命令

shutdown --help:

ifconfig --help:查看网卡信息

man命令(命令说明书)

man shutdown

注意:man shutdown打开命令说明书之后,使用按键q退出


二、目录操作命令

2.1 目录切换 cd

cd # 切换到用户目录

cd ~ # 切换到用户主目录

cd - # 切换到上一个工作目录

cd ./ # 就是指的当前目录

cd .. # 切换到上级目录

cd ../ # 切换到上级目录(与上一个一样)

cd ../.. # 切换到上两级目录


2.2 目录查看 ls [-al]

ls # 列出当前目录可见文件

ls -l # 列出当前目录可见文件详细信息

ls -la # 列出所有文件(包括隐藏)的详细信息

ls -lh # 列出详细信息并以可读大小显示文件大小

ls -lt # 按时间列出文件和文件夹详细信息

ls -ltr # 按修改时间列出文件和文件夹详细信息

ls --color=auto # 列出文件并标记颜色分类


   


ls支持通配符:

* 文件代表文件名中所有字符

ls te* 查找以te开头的文件

ls *html 查找结尾为html的文件

? 代表文件名中任意一个字符

ls ?.c 只找第一个字符任意,后缀为.c的文件

ls a.? 只找只有3个字符,前2个字符为a.,最后一个字符任意的文件

[] [”和“]”将字符组括起来,表示可以匹配字符组中的任意一个。“-”用于表示字符范围。

[abc] 匹配a、b、c中的任意一个

[a-f] 匹配从a到f范围内的任意一个字符

ls [a-f]* 找到从a到f范围内的任意一个字符开头的文件

ls a-f 查找文件名为a-f的文件,当“-”处于方括号之外时失去通配符的作用

\ 如果要使用通配符作为普通字符使用,可以在其前面加上转义字符。“?”和“*”处于方括号内时不用使用转义字符就失去通配符的作用。

ls \*a 查找文件名为*a的文件


文件访问权限

用户能够控制一个给定的文件或目录的访问程度,一个文件或目录可能有读、写及执行权限:

读权限(r) :对于文件,具有读取文件内容的权限;对于目录,具有浏览目录的权限。

写权限(w) :对于文件,具有修改文件内容的权限;对于目录,具有删除、移动目录内文件的权限。

可执行权限(x): 对于文件,具有执行文件的权限;对于目录,该用户具有进入目录的权限。

通常,Unix/Linux系统只允许文件的属主(所有者)或超级用户改变文件的读写权限。

示例:

   
 


第1个字母代表文件的类型:

  • “d” 代表文件夹

  • “-” 代表普通文件

  • “c” 代表硬件设备

  • “b” 代表硬件设备

  • “s”表示管道文件

  • “l” 代表软链接文件。

后9个字母分别代表三组权限:文件所有者、用户组、其他用户拥有的权限。


2.3 目录操作【增,删,改,查】

2.3.1 创建目录【增】 mkdir

命令:mkdir 目录

mkdir aaa 在当前目录下创建一个名为aaa的目录

mkdir /usr/aaa 在指定目录下创建一个名为aaa的目录


2.3.2 删除目录或文件【删】rm

命令:rm [-rf] 目录

删除文件:

rm 文件 删除当前目录下的文件

rm -f 文件 删除当前目录的的文件(不询问)

删除目录:

rm -r aaa 递归删除当前目录下的aaa目录

rm -rf aaa 递归删除当前目录下的aaa目录(不询问)

全部删除:

rm -rf * 将当前目录下的所有目录和文件全部删除

rm -rf /* 【自杀命令!慎用!慎用!慎用!】将根目录下的所有文件全部删除

[注意]:rm不仅可以删除目录,也可以删除其他文件或压缩包,为了方便大家的记忆,无论删除任何目录或文件,都直接使用 rm -rf 目录/文件/压缩包


2.3.3 目录修改【改】mv 和 cp

一、重命名目录

命令:mv 当前目录 新目录

例如:mv aaa bbb 将目录aaa改为bbb

注意:mv的语法不仅可以对目录进行重命名而且也可以对各种文件,压缩包等进行 重命名的操作

二、剪切目录

命令:mv 目录名称 目录的新位置

示例:将/usr/tmp目录下的aaa目录剪切到 /usr目录下面 mv /usr/tmp/aaa /usr

注意:mv语法不仅可以对目录进行剪切操作,对文件和压缩包等都可执行剪切操作

三、拷贝目录

命令:cp -r 目录名称 目录拷贝的目标位置 -r代表递归

示例:将/usr/tmp目录下的aaa目录复制到 /usr目录下面 cp /usr/tmp/aaa /usr

注意:cp命令不仅可以拷贝目录还可以拷贝文件,压缩包等,拷贝文件和压缩包时不 用写-r递归


2.3.4 搜索目录【查】find

命令:find 目录 参数 文件名称

示例:find /usr/tmp -name 'a*' 查找/usr/tmp目录下的所有以a开头的目录或文件


三、文件操作命令

3.1 文件操作【增,删,改,查】

命令:touch 文件名

示例:在当前目录创建一个名为aa.txt的文件 touch aa.txt


3.1.1 新建文件【增】touch

命令:touch 文件名

示例:在当前目录创建一个名为aa.txt的文件 touch aa.txt


3.1.2 删除文件 【删】 rm

命令:rm -rf 文件名


3.1.3 修改文件【改】 vi或vim

【vi编辑器的3种模式】

基本上vi可以分为三种状态,分别是命令模式(command mode)、插入模式(Insert mode)和底行模式(last line mode),各模式的功能区分如下:

1) 命令行模式command mode)

控制屏幕光标的移动,字符、字或行的删除,查找,移动复制某区段及进入Insert mode下,或者到 last line mode。

命令行模式下的常用命令:

【1】控制光标移动:↑,↓,j

【2】删除当前行:dd

【3】查找:/字符

【4】进入编辑模式:i o a

【5】进入底行模式::


2) 编辑模式(Insert mode)

只有在Insert mode下,才可以做文字输入,按「ESC」键可回到命令行模式。

编辑模式下常用命令:

【1】ESC 退出编辑模式到命令行模式;


3) 底行模式(last line mode)

将文件保存或退出vi,也可以设置编辑环境,如寻找字符串、列出行号……等。

底行模式下常用命令:

【1】退出编辑: :q

【2】强制退出: :q!

【3】保存并退出: :wq


打开文件

命令:vi 文件名

示例:打开当前目录下的aa.txt文件 vi aa.txt 或者 vim aa.txt

注意:使用vi编辑器打开文件后,并不能编辑,因为此时处于命令模式,点击键盘i/a/o进入编辑模式。


编辑文件

使用vi编辑器打开文件后点击按键:i ,a或者o即可进入编辑模式。

i:在光标所在字符前开始插入

a:在光标所在字符后开始插入

o:在光标所在行的下面另起一新行插入

保存或者取消编辑


保存文件:

第一步:ESC 进入命令行模式

第二步:: 进入底行模式

第三步:wq 保存并退出编辑


取消编辑:

第一步:ESC 进入命令行模式

第二步:: 进入底行模式

第三步:q! 撤销本次修改并退出编辑


3.1.4 文件的查看【查】

文件的查看命令:cat/more/less/tail

cat:看最后一屏

示例:使用cat查看/etc/sudo.conf文件,只能显示最后一屏内容

cat sudo.conf

more:百分比显示

示例:使用more查看/etc/sudo.conf文件,可以显示百分比,回车可以向下一行,空格可以向下一页,q可以退出查看

more sudo.conf

less:翻页查看

示例:使用less查看/etc/sudo.conf文件,可以使用键盘上的PgUp和PgDn向上 和向下翻页,q结束查看

less sudo.conf

tail:指定行数或者动态查看

示例:使用tail -10 查看/etc/sudo.conf文件的后10行,Ctrl+C结束

tail -10 sudo.conf


3.2 权限修改

rwx:r代表可读,w代表可写,x代表该文件是一个可执行文件,如果rwx任意位置变为-则代表不可读或不可写或不可执行文件。

   
 


第1个字母代表文件的类型:

  • “d” 代表文件夹

  • “-” 代表普通文件

  • “c” 代表硬件字符设备

  • “b” 代表硬件块设备

  • “s”表示管道文件

  • “l” 代表软链接文件。

后9个字母分别代表三组权限:文件所有者、用户组、其他用户拥有的权限。


四、压缩文件操作

4.1 打包和压缩

Windows的压缩文件的扩展名 .zip/.rar

linux中的打包文件:aa.tar

linux中的压缩文件:bb.gz

linux中打包并压缩的文件:.tar.gz

Linux中的打包文件一般是以.tar结尾的,压缩的命令一般是以.gz结尾的。

而一般情况下打包和压缩是一起进行的,打包并压缩后的文件的后缀名一般.tar.gz。

命令:tar -zcvf 打包压缩后的文件名 要打包的文件

其中:z:调用gzip压缩命令进行压缩

c:打包文件

v:显示运行过程

f:指定文件名


4.2 解压

命令:tar [-zxvf] 压缩文件

其中:x:代表解压

示例:将/usr/tmp 下的ab.tar解压到当前目录下

   


示例:将/usr/tmp 下的ab.tar解压到根目录/usr下

tar -xvf ab.tar -C /usr------C代表指定解压的位置

   



五、查找命令

5.1 grep

grep命令是一种强大的文本搜索工具

使用实例:

ps -ef | grep sshd 查找指定ssh服务进程

ps -ef | grep sshd | grep -v grep 查找指定服务进程,排除gerp身

ps -ef | grep sshd -c 查找指定进程个数


5.2 find

find命令在目录结构中搜索文件,并对搜索结果执行指定的操作。

find 默认搜索当前目录及其子目录,并且不过滤任何结果(也就是返回所有文件),将它们全都显示在屏幕上。

使用实例:

find . -name "*.log" -ls 在当前目录查找以.log结尾的文件,并显示详细信息。

find /root/ -perm 600 查找/root/目录下权限为600的文件

find . -type f -name "*.log" 查找当目录,以.log结尾的普通文件

find . -type d | sort 查找当前所有目录并排序

find . -size +100M 查找当前目录大于100M的文件


5.3 locate

locate 让使用者可以很快速的搜寻某个路径。默认每天自动更新一次,所以使用locate 命令查不到最新变动过的文件。为了避免这种情况,可以在使用locate之前,先使用updatedb命令,手动更新数据库。如果数据库中没有查询的数据,则会报出locate: can not stat () `

/var/lib/mlocate/mlocate.db': No such file or directory该错误!updatedb即可!

yum -y install mlocate 如果是精简版CentOS系统需要安装locate命令

使用实例:

updatedb

locate /etc/sh 搜索etc目录下所有以sh开头的文件

locate pwd 查找和pwd相关的所有文件


5.4 whereis

whereis命令是定位可执行文件、源代码文件、帮助文件在文件系统中的位置。这些文件的属性应属于原始代码,二进制文件,或是帮助文件。

使用实例:whereis ls 将和ls文件相关的文件都查找出来


5.5 which

which命令的作用是在PATH变量指定的路径中,搜索某个系统命令的位置,并且返回第一个搜索结果。

使用实例:

which pwd 查找pwd命令所在路径

which java 查找path中java的路径


六、su、sudo

6.1 su

su用于用户之间的切换。但是切换前的用户依然保持登录状态。如果是root 向普通或虚拟用户切换不需要密码,反之普通用户切换到其它任何用户都需要密码验证。

su test:切换到test用户,但是路径还是/root目录

su - test : 切换到test用户,路径变成了/home/test

su : 切换到root用户,但是路径还是原来的路径

su - : 切换到root用户,并且路径是/root


su不足:如果某个用户需要使用root权限、则必须要把root密码告诉此用户。

退出返回之前的用户:exit


6.2 sudo

sudo是为所有想使用root权限的普通用户设计的。可以让普通用户具有临时使用root权限的权利。只需输入自己账户的密码即可。

进入sudo配置文件命令:vi /etc/sudoer或者visudo

案例:

允许hadoop用户以root身份执行各种应用命令,需要输入hadoop用户的密码。

hadoop ALL=(ALL) ALL

案例:

只允许hadoop用户以root身份执行ls 、cat命令,并且执行时候免输入密码。

配置文件中:

hadoop ALL=NOPASSWD: /bin/ls, /bin/cat


七、系统服务

service iptables status --查看iptables服务的状态

service iptables start --开启iptables服务

service iptables stop --停止iptables服务

service iptables restart --重启iptables服务

chkconfig iptables off --关闭iptables服务的开机自启动

chkconfig iptables on --开启iptables服务的开机自启动


八、网络管理

8.1 主机名配置

[root@node1 ~]# vi /etc/sysconfig/network

NETWORKING=yes

HOSTNAME=node1


8.2 IP 地址配置

[root@node1 ~]# vi /etc/sysconfig/network-scripts/ifcfg-eth0


8.3 域名映射

/etc/hosts文件用于在通过主机名进行访问时做ip地址解析之用。所以,你想访问一个什么样的主机名,就需要把这个主机名和它对应的ip地址。

[root@node1 ~]# vi /etc/hosts

#### 在最后加上

192.168.52.201 node1

192.168.52.202 node2

192.168.52.203 node3


九、定时任务指令crontab 配置

crontab是Unix和Linux用于设置定时任务的指令。通过crontab命令,可以在固定间隔时间,执行指定的系统指令或shell脚本。时间间隔的单位可以是分钟、小时、日、月、周及以上的任意组合。

crontab安装:yum install crontabs

服务操作说明:

service crond start ## 启动服务

service crond stop ## 关闭服务

service crond restart ## 重启服务

crontab [-u user] file

crontab [-u user] [ -e | -l | -r ]

9.1 命令格式

crontab [-u user] file

crontab [-u user] [ -e | -l | -r ]

参数说明:

-u user:用来设定某个用户的crontab服务

file:file是命令文件的名字,表示将file做为crontab的任务列表文件

并载入crontab。

-e:编辑某个用户的crontab文件内容。如果不指定用户,则表示编辑当前

用户的crontab文件。

-l:显示某个用户的crontab文件内容。如果不指定用户,则表示显示当前

用户的crontab文件内容。

-r:删除定时任务配置,从/var/spool/cron目录中删除某个用户的crontab

文件,如果不指定用户,则默认删除当前用户的crontab文件。

命令示例:

crontab file [-u user] ## 用指定的文件替代目前的crontab

crontab -l [-u user] ## 列出用户目前的crontab

crontab -e [-u user] ## 编辑用户目前的crontab


9.2 配置说明、实例

命令:* * * * * command

解释:分 时 日 月 周 命令

第1列表示分钟1~59 每分钟用*或者 */1表示

第2列表示小时0~23(0表示0点)

第3列表示日期1~31

第4列表示月份1~12

第5列标识号星期0~6(0表示星期天)

第6列要运行的命令

配置实例:

先打开定时任务所在的文件:

crontab -e


每分钟执行一次date命令

*/1 * * * * date >> /root/date.txt

每晚的21:30重启apache。

30 21 * * * service httpd restart


每月1、10、22日的4 : 45重启apache。

45 4 1,10,22 * * service httpd restart


每周六、周日的1 : 10重启apache。

10 1 * * 6,0 service httpd restart


每天18 : 00至23 : 00之间每隔30分钟重启apache。

0,30 18-23 * * * service httpd restart

晚上11点到早上7点之间,每隔一小时重启apache

* 23-7/1 * * * service httpd restart


十、其他命令

10.1 查看当前目录:pwd

命令:pwd 查看当前目录路径

10.2 查看进程:ps -ef

命令:ps -ef 查看所有正在运行的进程

10.3 结束进程:kill

命令:kill pid 或者 kill -9 pid(强制杀死进程) pid:进程号

10.4 网络通信命令:

ifconfig:查看网卡信息

命令:ifconfig 或 ifconfig | more

ping:查看与某台机器的连接情况

命令:ping ip

netstat -an:查看当前系统端口

命令:netstat -an

搜索指定端口

命令:netstat -an | grep 8080


10.5 配置网络

命令:setup

10.6 重启网络

命令:service network restart

10.7 切换用户

命令:su - 用户名

10.8 关闭防火墙

命令:chkconfig iptables off

或者:

iptables -L;

iptables -F;

service iptables stop

10.9 修改文件权限

命令:chmod 777

10.10 清屏

命令:ctrl + l / clear

10.11 vi模式下快捷键

esc后:

保存并退出快捷键:shift+z+z

光标跳到最后一行快捷键:shift+g

删除一行:dd

复制一行内容:y+y

粘贴复制的内容:p


十一、Linux项目部署

11.1 安装jdk1.8

先卸载open-jdk

java -version

rpm -qa | grep java

rpm -e --nodeps java-1.7.0-openjdk-1.7.0.45-2.4.3.3.el6.x86_64

rpm -e --nodeps java-1.6.0-openjdk-1.6.0.0-1.66.1.13.0.el6.x86_64

开始安装:

mkdir /usr/local/src/java

rz 上传jdk tar包

tar -zxvf jdk-8u181-linux-x64.tar.gz

yum install glibc.i686

配置环境变量:

vi /etc/profile

在末尾行添加

#set java environment

JAVA_HOME=/usr/local/src/jdk8/jdk1.8.0_181

CLASSPATH=.:$JAVA_HOME/lib.tools.jar

PATH=$JAVA_HOME/bin:$PATH

export JAVA_HOME CLASSPATH PATH


保存退出

source /etc/profile 使更改的配置立即生效

java -version 查看JDK版本信息,如果显示出1.8证明成功

11.2 安装MySQL5.6

11.2.1 上传MySQL5.6的tar包

创建目录:mkdir /usr/local/src/mysql5.6

上传:

MySQL-5.6.34-1.rhel5.x86_64.rpm-bundle.tar 到上面的目录中

11.2.2 安装

第一步:解压

命令:tar -xvf

MySQL-5.6.34-1.rhel5.x86_64.rpm-bundle.tar

第二步:检测是否已经安装了mysql

命令:rpm -qa | grep mysql

如果已经安装了,将其卸载,如:

rpm -e --nodeps mysql-libs-5.1.71-1.el6.x86_64

第三步:安装MySQL的服务端

命令:rpm -ivh

MySQL-server-5.6.34-1.rhel5.x86_64.rpm

第四步:安装MySQL的客户端

命令:rpm -ivh

MySQL-client-5.6.34-1.rhel5.x86_64.rpm

第五步:查看MySQL服务运行状态

命令:service mysql status

第六步:启动MySQL服务

命令:service mysql start

第七步:使用root账号登录mysql

在安装mysql server时有句提示:

   
 


注意:这个密码是不安全的,所有需要修改初始密码。

  1. 使用密码登录mysql账号:mysql -uroot -p

  2. 修改root密码:SET PASSWORD = PASSWORD('root');

11.2.3 开机自动启动设置

加入到系统服务:

chkconfig --add mysql

自动启动:

chkconfig mysql on

查询列表:

chkconfig

说明:都没关闭(off)时是没有自动启动。

11.2.4 开启远程访问

登录:

mysql -uroot –proot

设置远程访问(使用root密码):

grant all privileges on *.* to 'root' @'%' identified by 'root';

flush privileges;

退出mysql,在centos环境下打开3306防火墙

/sbin/iptables -I INPUT -p tcp --dport 3306 -j ACCEPT

/etc/rc.d/init.d/iptables save

/etc/init.d/iptables status


11.3 安装tomcat部署项目

准备工作:将web项目打成war包,改名为ROOT.war

11.3.1 创建ucenter用户

一般情况下,发布应用程序都不是使用root用户的,需要创建一个普通用户来发布程序;

创建ucenter用户:

useradd -d /ucenter ucenter

设置密码:

passwd ucenter (密码 ucenter)

切换用户:

su - ucenter


11.3.2 安装Tomcat

tomcat只要解压就可以使用。

1、创建web目录

mkdir /ucenter/web

2、上传

apache-tomcat-7.0.57.tar.gz

3、解压:tar -xvf

apache-tomcat-7.0.57.tar.gz

4、重命名:mv apache-tomcat-7.0.57 itcast-usermanage

5、启动tomcat:

cd itcast-usermanage/bin/

./startup.sh 或者 sh startup.sh

6、查看日志:

tail -f ../logs/catalina.out

7、查看效果

http://192.168.0.160:8080/

发现无法访问:

   
 


8、防火墙打开 8080 端口

/sbin/iptables -I INPUT -p tcp --dport 8080 -j ACCEPT

/etc/rc.d/init.d/iptables save

9、安装成功

   
 


11.3.3 部署用户管理项目

1、上传usermanage.sql和ROOT.war到/ucenter/web

2、执行数据库脚本

cat user_manager.sql | mysql -uroot -p123456

3、部署web程序

3.1 删除webapps下的所有文件

cd /ucenter/web/usermanage/webapps

rm -rf *

3.2 拷贝ROOT.war到webapps

cp /ucenter/web/ROOT.war .

3.3 重新启动tomcat

cd ../bin/

sh startup.sh && tail -f ../logs/catalina.out

3.4 启动浏览器测试

注意事项:Centos环境下部署项目中文乱码问题解决方案

今天在一台新的CentOS机器上使用c3p0连接池操作mysql数据库出现中文乱码问题,具体表现为:查询时无中文乱码问题,写数据时中文乱码,查看了机器上数据库字符集也是UTF8,应该不会出现中文乱码才对,最后在c3p0配置文件中 jdbcUrl后加上:?useUnicode=true&characterEncoding=UTF8 中文就不会乱码了。

【C3P0配置文件】

<?xml version="1.0" encoding="UTF-8"?>

<c3p0-config>

<default-config>

<property name="driverClass">com.mysql.jdbc.Driver</property>

<property name="jdbcUrl">jdbc:mysql://localhost:3306/user_manager_yun6?useUnicode=true&characterEncoding=UTF8 </property>

<property name="user">root</property>

<property name="password">root</property>

<property name="acquireIncrement">2</property>

<property name="initialPoolSize">5</property>

<property name="minPoolSize">1</property>

<property name="maxPoolSize">5</property>

</default-config>

</c3p0-config>


11.4 Linux下使用FastDFS

相关的安装包我打包到云盘上了,链接:

https://pan.baidu.com/s/13NDYYil4mgLhkb5CYsc2Ww 提取码:66tn

单节点FastDFS

整个安装过程非常复杂,很容易出错,建议进行多次备份。

我们这里不打算安装多台虚拟机,因此会把tracker和storage都安装在一起。


11.4.1 安装gcc

GCC用来对C语言代码进行编译运行,使用yum命令安装:yum -y install gcc

后面会用到解压命令(unzip),所以这里可以用yum把unzip 也装一下:

yum install -y unzip zip


11.4.2 安装libevent

yum -y install libevent


11.4.3 安装libfastcommon-master

解压刚刚上传的libfastcommon-master.zip

unzip libfastcommon-master.zip

进入解压完成的目录

cd libfastcommon-master

编译并且安装:

./make.sh

./make.sh install


11.4.4 安装fastdfs

tar -zxvf FastDFS_v5.08.tar.gz

cd FastDFS

./make.sh

./make.sh install

如果安装成功,会看到/etc/init.d/下看到提供的脚本文件:ll /etc/init.d/ | grep fdfs

   


  • fdfs_trackerd 是tracker启动脚本

  • fdfs_storaged 是storage启动脚本

能够在 /etc/fdfs/ 目录下看到默认的配置文件模板:ll /etc/fdfs/

   


  • tarcker.conf.sample 是tracker的配置文件模板

  • storage.conf.sample 是storage的配置文件模板

  • client.conf.sample 是客户端的配置文件模板

# 修改的内容如下:base_path=/项目名/tracker # 存储日志和数据的根目录

3)新建目录:mkdir -p /项目名/tracker

注意:关闭防火墙:chkconfig iptables off

4)启动和停止service fdfs_trackerd start # 启动fdfs_trackerd服务,停止用stop

检查FastDFS Tracker Server是否启动成功:ps -ef | grep fdfs_trackerd

设置tracker服务开机启动:chkconfig fdfs_trackerd on


11.4.5 配置并启动tracker服务

1)首先将模板文件复制cp

/etc/fdfs/tracker.conf.sample /etc/fdfs/tracker.conf

2)修改复制后的配置文件:vim /etc/fdfs/tracker.conf


11.4.6 配置并启动storage服务

1)首先将模板文件复制成 cp

/etc/fdfs/storage.conf.sample /etc/fdfs/storage.conf

2)修改复制后的配置文件:vim /etc/fdfs/storage.conf

# 修改的内容如下:

base_path=/项目名/storage # 数据和日志文件存储根目录

store_path0=/项目名/storage # 第一个存储目录

tracker_server=192.168.56.101:22122 # tracker服务器IP和端口

3)新建目录:mkdir -p /项目名/storage

注意关闭防火墙: chkconfig iptables off

4)启动和停止service fdfs_storaged start # 启动fdfs_storaged服务,停止用stop

设置storage服务开机启动:chkconfig fdfs_storaged on

ps -ef | grep fdfs

   
 


11.5 安装fastdfs-nginx-module

11.5.1 解压

tar -zxvf fastdfs-nginx-module_v1.16.tar.gz

11.5.2 修改config

1)进入src目录cd fastdfs-nginx-module/src/

2)编辑configvim config

使用以下底行命令::%s+/usr/local/+/usr/+g

将所有的/usr/local替换为 /usr,这个才是正确的目录:

   
 



11.5.3 配置nginx与FastDFS关联配置文件

复制 fastdfs-nginx-module 源码中的配置文件到/etc/fdfs 目录, 并修改

cp /usr/local/项目名

/fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs/

vi /etc/fdfs/mod_fastdfs.conf

修改以下配置:

connect_timeout=10 # 客户端访问文件连接超时时长(单位:秒)

tracker_server=192.168.56.101:22122 # tracker服务IP和端口

url_have_group_name=true # 访问链接前缀加上组名

store_path0=/leyou/storage # 文件存储路径

复制 FastDFS 的部分配置文件到/etc/fdfs 目录

cd /usr/local/项目名/FastDFS/conf/

cp http.conf mime.types /etc/fdfs/


11.6 安装Nginx的插件

11.6.1 如果没有安装过nginx

1、安装nginx的依赖库

yum -y install gcc pcre pcre-devel zlib zlib-devel openssl openssl-devel

2、解压安装包

tar -zxvf nginx-1.10.0.tar.gz

3、配置nginx安装包,并指定fastdfs-nginx-model

cd nginx-1.10.0

./configure --prefix=/opt/nginx --sbin-path=/usr/bin/nginx --add-module=/usr/local/leyou/fastdfs-nginx-module/src

注意:在执行./configure配置nginx参数的时候,需要将fastdfs-nginx-moudle源码作为模块编译进去。

4、编译并安装make && make install


11.6.2 如果已经安装过nginx

1、 进入nginx目录:cd /usr/local/项目名/nginx-1.10.0/

2、 配置FastDFS 模块

./configure --prefix=/opt/nginx --sbin-path=/usr/bin/nginx --add-module=/usr/local/项目名/fastdfs-nginx-module/src

注意:这次配置时,要添加fastdfs-nginx-moudle模块

3、编译,注意,这次不要安装(install)make

4、替换nginx二进制文件:

备份:mv /usr/bin/nginx /usr/bin/nginx-bak

用新编译的nginx启动文件替代原来的:cp objs/nginx /usr/bin/


11.6.3 启动nginx

配置nginx整合fastdfs-module模块

我们需要修改nginx配置文件,在

/opt/nginx/config/nginx.conf文件中:

vim /opt/nginx/conf/nginx.conf

将文件中,原来的server 80{ ...} 部分代码替换为如下代码:

server {

listen 80;

server_name image.项目名.com;

# 监听域名中带有group的,交给FastDFS模块处理

location ~/group([0-9])/ {

ngx_fastdfs_module;

}

location / {

root html;

index index.html index.htm;

}

error_page 500 502 503 504 /50x.html;

location = /50x.html {

root html;

}

}

启动nginx:

nginx # 启动nginx


nginx -s stop # 停止nginx


nginx -s reload # 重新载入配置文件

# 可通过ps -ef | grep nginx查看nginx是否已启动成功

   
 



11.6.4 设置nginx开机启动

创建一个开机启动的脚本:vim /etc/init.d/nginx

添加以下内容:

#!/bin/sh

#

# nginx - this script starts and stops the nginx daemon

#

# chkconfig: - 85 15

# description: NGINX is an HTTP(S) server, HTTP(S) reverse \

# proxy and IMAP/POP3 proxy server

# processname: nginx

# config: /etc/nginx/nginx.conf

# config: /etc/sysconfig/nginx

# pidfile: /var/run/nginx.pid


# Source function library.

. /etc/rc.d/init.d/functions


# Source networking configuration.

. /etc/sysconfig/network


# Check that networking is up.

[ "$NETWORKING" = "no" ] && exit 0


nginx="/usr/bin/nginx"

prog=$(basename $nginx)


NGINX_CONF_FILE="/opt/nginx/conf/nginx.conf"


[ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx


lockfile=/var/lock/subsys/nginx


make_dirs() {

# make required directories

user=`$nginx -V 2>&1 | grep "configure arguments:.*--user=" | sed 's/[^*]*--user=\([^ ]*\).*/\1/g' -`

if [ -n "$user" ]; then

if [ -z "`grep $user /etc/passwd`" ]; then

useradd -M -s /bin/nologin $user

fi

options=`$nginx -V 2>&1 | grep 'configure arguments:'`

for opt in $options; do

if [ `echo $opt | grep '.*-temp-path'` ]; then

value=`echo $opt | cut -d "=" -f 2`

if [ ! -d "$value" ]; then

# echo "creating" $value

mkdir -p $value && chown -R $user $value

fi

fi

done

fi

}


start() {

[ -x $nginx ] || exit 5

[ -f $NGINX_CONF_FILE ] || exit 6

make_dirs

echo -n $"Starting $prog: "

daemon $nginx -c $NGINX_CONF_FILE

retval=$?

echo

[ $retval -eq 0 ] && touch $lockfile

return $retval

}


stop() {

echo -n $"Stopping $prog: "

killproc $prog -QUIT

retval=$?

echo

[ $retval -eq 0 ] && rm -f $lockfile

return $retval

}


restart() {

configtest || return $?

stop

sleep 1

start

}


reload() {

configtest || return $?

echo -n $"Reloading $prog: "

killproc $nginx -HUP

RETVAL=$?

echo

}


force_reload() {

restart

}


configtest() {

$nginx -t -c $NGINX_CONF_FILE

}


rh_status() {

status $prog

}


rh_status_q() {

rh_status >/dev/null 2>&1

}


case "$1" in

start)

rh_status_q && exit 0

$1

;;

stop)

rh_status_q || exit 0

$1

;;

restart|configtest)

$1

;;

reload)

rh_status_q || exit 7

$1

;;

force-reload)

force_reload

;;

status)

rh_status

;;

condrestart|try-restart)

rh_status_q || exit 0

;;

*)

echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}"

exit 2

esac

修改文件权限,并加入服务列表

# 修改权限

chmod 777 /etc/init.d/nginx

# 添加到服务列表

chkconfig --add /etc/init.d/nginx

设置开机启动chkconfig nginx on


11.7 安装Elasticsearch

需要虚拟机JDK1.8及以上

11.7.1 新建一个用户leyou

出于安全考虑,elasticsearch默认不允许以root账号运行。

创建用户:useradd leyou

设置密码:su - leyou

切换用户:su - leyou


11.7.2 上传安装包,并解压

我们将安装包上传到:/home/leyou目录

解压缩:tar -zxvf

elasticsearch-6.2.4.tar.gz

我们把目录重命名:mv elasticsearch-6.3.0/ elasticsearch

   
 


进入,查看目录结构:

   



11.7.3 修改配置

我们进入config目录:cd config

需要修改的配置文件有两个:

   


1、jvm.options

Elasticsearch基于Lucene的,而Lucene底层是java实现,因此我们需要配置jvm参数。

编辑jvm.options:vim jvm.options

默认配置如下:

-Xms1g

-Xmx1g

内存占用太多了,我们调小一些:

-Xms512m

-Xmx512m

2、elasticsearch.yml

vim elasticsearch.yml

修改数据和日志目录:

path.data:

/home/leyou/elasticsearch/data # 数据目录位置

path.logs:

/home/leyou/elasticsearch/logs # 日志目录位置


我们把data和logs目录修改指向了elasticsearch的安装目录。但是这两个目录并不存在,因此我们需要创建出来。

进入elasticsearch的根目录,然后创建:

mkdir data

mkdir logs

   


修改绑定的ip:

network.host: 0.0.0.0 # 绑定到0.0.0.0,允许任何ip来访问

默认只允许本机访问,修改为0.0.0.0后则可以远程访问

11.7.4 运行

进入elasticsearch/bin目录,可以看到下面的执行文件:

   
 


然后输入命令:./elasticsearch

或者后台运行:./elasticsearch -d


扫描二维码推送至手机访问。

版权声明:本文由信安苑发布,如需转载请注明出处。

本文链接:http://www.cmznet.cn/?id=19

分享给朋友:

“Linux操作指南” 的相关文章

Linux系统的计划任务操作指南

Linux系统的计划任务操作指南

写完这一章,Linux的学习笔记整理就先告一段落了。因为日常使用的命令几乎都整理完了,当然Linux的命令不可能只有这些内容,但常用的基本都有了。如果熟悉了这几个章节的笔记,可以说对 Linux 算是个入门汉了。后面的更深度的学习,我也还在学习当中,知识有限,估计做不到给大家什么意见了。cron 任...

Linux的防火墙设置指南

Linux的防火墙设置指南

在上节的笔记中,大家还记得那条防火墙的设置命令么?为什么要使用防火墙呢?Linux 系统中,安全的第一道防线就是它。跟 Windows中防火墙一样,都是要设置端口的开放与关闭。那除了增加的命令之外,还有没有其它的操作呢?是如何实现的?那我们本节进行简单地讲解一下与防火墙有关的笔记内容。防火墙的配置,...

收集到最全的交换机知识点

收集到最全的交换机知识点

今天想带你温顾一番交换机的基础知识,顺便说说,如何选择交换机,分享一波交换机选型要点,实现最优选。01交换机制式当前的交换机主要分为盒式和框式。    盒式交换机样例图    框式交换机样例图01 盒式交换机盒式交换机皆可以理解成一个铁盒子...

企业内的最实用的工作方法

企业内的最实用的工作方法

在职场中,判断一个人工作能力的强弱,可以从六个方面来看:1)接到任务:绝不盲目接受工作2)遇到困难:自带方案请示工作3)工作动力:自我驱动,主动干活4)工作过程:擅用工具,事半功倍5)时间分配:聪明的时间管理大师6)向上关系:擅长经营领导(1)接到任务:绝不盲目接受工作职场是一个注重效率至上的地方。...

windows 下如何查看已连接过的无线密码

windows 下如何查看已连接过的无线密码

一、显示无线密码1、自动连接上无线网络2、打开 DOS3、使用命令 netsh wlan show profiles name=无线 SSID key=clear(明文)   ...

这是我看到过最好的工作方法与思路!学习一下吧

这是我看到过最好的工作方法与思路!学习一下吧

作者:谢春霖来源:知乎著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。☆ 我先来举一个栗子 :假设,你是一家创业公司的CEO。最近,你发现公司的业绩,一路下滑,你打算找业务部主管王小锤聊一下,看看到底发生了什么,下一步该如何应对。于是,你把他叫到了办公室,一脸严肃的问到:小锤,最...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。