Linux中最全shell命令&常用注意事项

在编辑linux脚本中不断的会用到复杂的脚本编辑,写文章记录。

Linux命令大全(手册) – 真正好用的Linux命令在线查询网站

目录

推荐书籍:

Linux常用命令

Linux 常用命令

在linux shell脚本中root切换到普通用户执行脚本

Linux—shell中$(( ))、$( )、``与${ }的区别

linux建立和彻底删除用户

linux脚本判断用户是否存在

linux shell中"2>&1"含义

linux shell中交互命令提示确认(Y / N,YES / NO)

linux通过scale 和bc命令设置结果的位数

Linux防火墙对所有IP地址开放8080端口

linux查看硬盘挂载

linux的硬链接和软连接

Shell中常用的date时间命令

Linux定时任务Crontab命令详解

Linux中max_user_processes和open_file的修改

Linux 设置开机自启动脚本命令

设置Linux自动发送邮件

linux脚本监控系统性能CPU、内存和java进程情况

linux下批量kill多个进程


推荐书籍:

《Linux就该这么学》,电子版下载地址:

《Linux就该这么学》 - 必读的Linux系统与红帽RHCE认证免费自学书籍

Linux常用命令

Linux 常用命令

在linux shell脚本中root切换到普通用户执行脚本

有时候脚本中遇到root用户执行sh文件,但是需要其他用户的权限,可以用以下命令 

#!/bin/bash
su - pentaho <

root用户执行脚本,可以看到还是在root用户的环境变量下,但是执行目录是切换的普通用户 

 

其中需要注意的是

1. 只要你的<<之后的字符和结束的对应上就可以啦,可以都是EOF,也可以都是!

Linux中最全shell命令&常用注意事项_第1张图片

2. 第二个标志符EOF需要顶格写,不然会报错 

Linux—shell中$(( ))、$( )、``与${ }的区别

参考文章:Linux—shell中$(( ))、$( )、``与${ }的区别 - chengd - 博客园

在shell命令中$( )与` `(反引号)都是用来作命令替换的,所以新手记得区分“”引号和反引号是不同的,例如:

linux建立和彻底删除用户

新建用户:useradd user1

删除用户的命令是:userdel  user1

但是userdel  user1只是删除这个用户,用户的主目录还是保留的,想要删除用户主目录可以手动删除:rm -rf /home/user1
也可以执行命令:

userdel -r user1

linux脚本判断用户是否存在

#create user  postgres
#read -p "please input a username:" username
username=postgres
if id -u $username >/dev/null 2>&1; then
	echo "user $username exists"
else	echo "user does not exist"
	useradd $username
fi

linux shell中"2>&1"含义

为何2>&1要写在后面?

参考文章:Linux脚本开头#!/bin/bash和#!/bin/sh是什么意思以及区别 - EasonJim - 博客园

useradd user1 >/dev/null 2>&1

我们可以理解为,左边是标准输出,现在标准输出直接输入到 /dev/null 中,而2>&1是将标准错误重定向到标准输出,所以当程序产生错误的时候,相当于错误流向左边,而左边依旧是输入到/dev/null中。

linux shell中交互命令提示确认(Y / N,YES / NO)

在linux脚本中,编写一键安装pentaho、postgresql数据库的脚本,在交互命令输入路径的时候,需要提示用户路径是否正确,

输入yes则继续下一步

输入no,则重新输入

输入其他字符,则提示输入无效,并重新输入

输入exit,则退出安装脚本 

#/bin/bash
while true
do 
read -p "Please input Pentaho server installation path:" PENTAHO_PATH

read -r -p "Are You Sure the Path? [Y/n]" YESNO

case $YESNO in
        [yY][eE][sS]|[yY])
            echo "the  Pentaho server install path is:" $PENTAHO_PATH
			break  
			;;
        [nN][oO]|[nN])
            echo "Please input again!"
            ;;
		[eE][xX][iI][tT])
			echo "exit!"
			exit 1
			;;
        *)
            echo "Invalid input ..."
            ;;
esac
done

linux通过scale 和bc命令设置结果的位数

例如:

echo "scale=4; 1.2323293128 / 1.1" | bc -l
1.1202

 注意事项:

scale只对除法、取余、乘幂有效,比如乘法就无效,保留的小数也不是四舍五入

echo "scale=4; 1.2323293128 * 1.1" | bc -l
1.3555622440

 可以变通的是,乘法的时候除以1:

echo "scale=4; (1.2323293128 * 1.1) / 1" | bc -l
1.3555

Linux防火墙对所有IP地址开放8080端口

 查看、打开、关闭防火墙命令:

systemctl status firewalld
systemctl stop firewalld
systemctl start firewalld

开启8080端口访问:

firewall-cmd --zone=public --add-port=8080/tcp --permanent;
  • zone=public:表示作用域为公共的;
  • add-port=8080/tcp:添加tcp协议的端口8080;
  • permanent:永久生效,如果没有此参数,则只能维持当前服务生命周期内,重新启动后失效;

 开启8080端口后需要重启:

systemctl restart firewalld

输入命令重新载入配置 

 firewall-cmd --reload

linux查看硬盘挂载

查看过去的文章:

Linux查看硬盘挂载

linux的硬链接和软连接

查看过去的文章: 

linux的硬链接和软连接

Shell中常用的date时间命令

查看过去的文章:  

Shell中常用的date时间命令

Linux定时任务Crontab命令详解

查看过去的文章:   

Linux定时任务Crontab命令详解

Linux中max_user_processes和open_file的修改

查看过去的文章:   

Linux中max_user_processes和open_file的修改

Linux 设置开机自启动脚本命令

查看过去的文章: 

Linux 设置开机自启动脚本命令

设置Linux自动发送邮件

文章:

设置Linux自动发送邮件

linux脚本监控系统性能CPU、内存和java进程情况

文章:

linux脚本监控系统性能CPU、内存和java进程情况

linux下批量kill多个进程

ps -ef|grep nginx|grep -v grep|cut -c 9-15|xargs kill -9

或者ps -ef | grep pentaho-server| grep -v grep| awk '{print $2}'|xargs kill -9

管道符"|"用来隔开两个命令,管道符左边命令的输出会作为管道符右边命令的输入。下面说说用管道符联接起来的几个命令:

"ps - ef"是linux 里查看所有进程的命令。这时检索出的进程将作为下一条命令"grep mcfcm_st"的输入。

"grep nginx"的输出结果是,所有含有关键字"nginx"的进程

"grep -v grep"是在列出的进程中去除含有关键字"grep"的进程。

"cut -c 9-15"是截取输入行的第9个字符到第15个字符,而这正好是进程号PID。

awk '{print $2}'效果和"cut -c 9-15"是一样的,都是返回查询出来的进程号

"xargs kill -9"中的xargs命令是用来把前面命令的输出结果(PID)作为"kill -9"命令的参数,并执行该令。

"kill -9"会强行杀掉指定进程,这样就成功清除了oracle的所有远程连接进程。其它类似的任务,只需要修改"grep nginx"中的关键字部分就可以了。

echo中是否加引号

约定俗成的是,echo hello my name is wang,这句话中有空格的就会加双引号。

""双引号:有空白的字符、变量就会使用双引号

反斜杠(\):使反斜杠后面的一个变量变为单纯的字符。

单引号(' '):转义其中所有的变量为单纯的字符串。

双引号(" "):保留其中的变量属性,不进行转义处理。

反引号(` `):把其中的命令执行后返回结果。

目录和文件权限的备份

例在备份/home目录上的ACL权限时,可使用-R递归参数,这样不仅能够把目录本身的权限进行备份,还能将里面的文件权限也自动备份。

需要注意,getfacl在备份目录权限时不能使用绝对路径的形式,因此我们需要先切换到最上层根目录,然后再进行操作。

getfacl -R home > backup.acl

ACL权限的恢复也很简单,使用的是--restore参数。由于在备份时已经指定是对/home目录进行操作,所以不需要写对应的目录名称,它能够自动找到要恢复的对象:
setfacl --restore backup.acl

这里恢复的是备份的目录和文件权限,对于备份之后产生的新文件是权限是不会改变的。

linux用户权限 

一共分为普通权限、特殊权限(suid/sgid/sbit)和隐藏权限(chattr/lsattr)以及文件访问控制列表(getfacl/setfacl)

Linux增加swap空间的设置

linux增加swap交换空间 - 简书

如何过滤掉find显示的大量Permission denied

结论:find / -name xxx 2>/dev/null
这个操作最方便,直接把错误输出丢弃
之前尝试直接用find / -name xxx | grep -v的功能,但是这个对标准输出有效,对错误输出无效。要用grep的话可以这样写:
find / -name xxx 2>&1 | grep -v “denied”
 

shell执行oracle脚本

sqlplus命令行的执行结果

Linux中最全shell命令&常用注意事项_第2张图片

 通过shell的截取字符串方法结果:

#!/bin/sh
ORACLE_SID=IOM
code=`
sqlplus / as sysdba@IOM <> /home/oracle/code.txt
echo `date +%F_%T` >> /home/oracle/code.txt
echo $code >> /home/oracle/code.txt

l_code=${code#*SQL>}
echo ${l_code%SQL>*}

awk的应用:

awk简介和使用方法

你可能感兴趣的:(Linux基础知识,linux,服务器,bash)