linxu学习笔记――基本命令

which ls

设置alias 放在~/.bashrc

修改path vi /etc/profile,source /etc/profile

ctrl u 向前删除

ctrl k 向后删除

ctrl d 退出 logout exit

ctrl z 暂停 fg 恢复

ctrl c 取消,中断

ctrl s 屏幕静止、锁定,后台继续运作,只是屏幕不显示

ctrl q 屏幕恢复、解锁

ctrl l 清屏

ctrl a 行首

ctrl e 行尾

mkdir -p

rmdir -p

cp -r 复制目录

cat -A 查看txt

mv 没有r

less j k 、ctrl+b f、g G、/ n N、?

chmod -R 权限继承

chmod u= g= o= 其中不要带有-,系统认为减号

chown user:group :或 .

!ls 最近的一条ls命令

!301 history的id

chown -R 权限继承

chattr + - a不能删除rm和更改vi,mv 只能追加echo "11">>1.txt

chattr + - i保护,什么都不能

lsattr -R

lsattr -d

chmod u+s S 对普通用户有限制,有root无效,注意o权限

!$ 上一条命令最后一个

G 扩展组usermod useradd 该组有用户的话,也可以删除

gid最大一个往后排

usermod -L 锁定用户无法登录,-U解锁,可用useradd所有参数 u g G s d

mkpasswd yum install -y expect -l 12 -s 0 -c 4 -C 4 -d 4

echo "gce@1234" | passwd --sdtin aming 明文

echo -e "123456\n123456" | passwd aming -e识别\n为换行,不加-e不识别,新密码123456

su - -c "mkdir /tmp/dir123" aming

visudo

root           ALL=(ALL)                     ALL

aming          192.168.1.0/24=(root)       NOPASSWD: /bin/ls,command

用户名&组名     来源            角色          命令,绝对路径,逗号分隔,设置不需要密码

sudo ls /root/ 需密码,也可以不输入密码

sudo -l 查看拥有哪些权限

inode 属性(大小,路径,权限),inode分配完就算分区有空间,也无法创建文件

du -sh文件占用磁盘空间的大小、块的大小和ls -lh文件本身大小,显示大小不同,因分区块4K

du -sb和ls -lb显示大小相同

cat /etc/filesystems

mke2fs -t/T ext4 -b 2048 -m 1 -L aming /dev/sdb1     比mkfs.ext4参数多

                块大小 保留 标签

df -T 查看分区类型

umount -l 强制卸载

/etc/rc.local 自动挂载命令

blkid uuid label ext4

defaults= rw,suid,dev,exec,auto,nouser,async

0 备份log

1 不备份log,意外断电可恢复资料

1 修复,只能根分区

2 修复,优先级低一点

0 不修复,不重要或者分区太大,否则会影响启动速度

mount -a 加载fstab中所有挂载

yum install -y vim-enhanced

vim +10 !$  光标在第10行



一般模式

j k 下上 h k左右 2j下2行

ctrl f 下翻页 crtl b上翻页 pageup pagedown

gg 首行 G行尾 100G

$行尾 0 行首(含行首的空白字符) ^行首(非空白)

x 先后删除 X 向前删除 4x 剪切

dd 删除整行,剪切 3dd

p 向下粘贴 P 向上粘贴

u 撤销,最多撤销50次 ctrl r 反撤销

yy 复制整行 3yy

v 可视模式 左右 上下 选择 与x p合用


编辑模式

i 插入

esc 退出

I 光标在行首

a 光标在后面

A 光标在行尾

o 光标下一行

O 光标上一行


命令模式

:wq!

:set nu 显示行号

:set nonu 取消行号

/keyword 查找,高亮,n下找 N上找

?keyword 查找,高亮,n上找 N下找

:1,$s/A/B/g 没有g,只替换每行的第一个,$所有行

:%s/A/B/g  %=1,$ 整个文件

///脱义符号\,识别/

#///#///#    @///@///@ 不会产生歧义

:nohl 取消高亮


gzip file 压缩后源文件删除,只能压缩文件,只留下file.gz 红色 -1 -9 级别越高,速度越慢,比率越大,默认6

gzip file.gz 解压后源文件删除

bzip2 file 压缩后源文件消失,只留下file.bz2 红色,默认9

bzip2 -d file.bz2 解压后源文件删除

bzcat和zcat xzcat查看压缩内容

gzip和bzip 都不能压缩目录

xz gzip bzip用法差不多


yum install -y xz gzip bzip2 zip unzip


zip file.zip file 源文件存在,可以压缩文件和目录

zip -r file.zip file1 file2 同时压缩多个目录

unzip file.zip 


tar --exclude file3 --exclude file4 -cvf file.tar file1 file2 dir1 源文件存在

tar -tf file.tar 查看

tar -xvf file.tar 解包

tar -C -xvf file.tar 指定解包路径


tar支持gzip bzip2 xz

tar -zcvf 1.tar.gz 111 22 源文件存在

tar -C /tmp/ -zxvf 1.tar.gz 源文件存在,直接覆盖

tar -tf 1.tar.gz


tar -jcvf 1.tar.bz2 111 222

tar -tf

tar -jxvf


tar -Jcvf 1.tar.xz 111 222

tar -tJf 查看

tar -Jxvf


rpm -ivh 全名

rpm -ivh --nodeps 全名,不依赖,少用

rpm -ivh --force 全名,强制安装

rpm -e 包名

依赖的时候,同时安装或卸载

rpm -Uvh 全名,升级


rpm -q 包名

rpm -qa 查询所有已安装

rpm -qa 包名 查询包的全名

rpm -qa | grep vim 例外,可以查keyword

rpm -qa | grep 'vim*'

rpm -qi 包名,详细信息

rpm -ql 包名,安装了哪些文件

rpm -qf 绝对路径,文件属于哪个包

rpm -qf `which vim`


yum list yum源 /etc/yum.repos.d/CentOS-Base.repo

yum list | grep vim  @符号属于已安装过的

yum search 'vim'


yum remove 包名 不推荐加y,防止依赖删除

yum update 包名 不推荐升级

yum upgrade 包名


yum groupinstall "包名" 安装套件

yum grouplist | grep -i chinese

yum groupremove "包名"


yum install -y yum-plugin-downloadonly 下载插件

yum install vte --downloadonly --downloaddir=/tmp/  下载rpm未安装过的rpm包

yum reinstall vte --downloadonly --downloaddir=/tmp/  下载已安装的rpm包


源码包安装

yum install -y wget

/usr/local/src

wget http

tar

cd

cat install

cat readme

./configure --help 参看配置参数,模块

./configure --prefix=/usr/local/apache2 指定安装路径

echo $? 返回码 0代表OK

make 编译,把源码变成语言

make install 翻译成系统识别的文件

ls /usr/local/apache2 查看生成目录


rm -rf /usr/local/apache2 卸载,重新安装,最好删除压缩目录,重新解压


history

cat ~/.bash_history 用户操作命令历史,用户不同,历史不同,默认1000条

echo $HISTSIZE

!! 上一条命令

!$ 上一条命令最后一个参数

!n 运行第n条命令

!c 最近一次以c开头的命令


? 任意一个字符


jobs 查看ctrl z的命令

fg 优先调用+号,前台

bg 后台


env 查看系统变量

set 查看系统变量,包含自定义变量,更详细

自定义变量 a=1;b=2,只在当前shell生效

变量名不能数字开头,可以含有_,可以开头_,不推荐大写,避免用命令,关键字,系统变量大写

c='ls /tmp/',*#也需要用单引号

d=`which vim` 命令使用反引号,引用命令的结果

e="$a"8 变量用双引号

export a=1 全局申明,在其他bash,shell中生效

unset e 取消变量


vim /etc/profile 全局配置

source /etc/profile 申明,会加载/etc/profile.d/下的所有*.sh,自定义环境变量不推荐直接修改profile


vim /etc/bashrc PS1 UMASK 全局配置

echo $PS1 w:绝对路径 


vim ~/.bash_profile 用户配置文件 会调用.bashrc

vim ~/.bashrc 用户配置文件alias 用户登录、打开新shell时执行


[0-9a-zA-Z]


cut -d: -f 3,4 /etc/passwd 分割,显示第三、四段

cut -c 1-10 /etc/passwd 显示第一个到十个字符


sort 默认asic排序

sort -t: -k3 -nr /etc/passwd n按数字 3,5 3到5,r倒序,字母比数字小,-u 去重


wc -l 行数

wc -w word数量,空白分隔

wc -m 字符数量,含换行符,空格


uniq 必须相邻的行才能去重

uniq -c 重复次数

sor file | unqic -c


tee 重定向

echo "123456" | tee 1.txt 会显示结果 与 > 的区别


tr 替换

echo "abcd" | tr 'a-z' 'A-Z' 一一对应 ‘ab’ 'AB'


split 切割

split -b 50m 1.txt 按大小 默认单位b,可以省略 (x)aa xab

split -l 100 1.txt 按行


&& 并且 成功-执行 不成功-不执行

|| 或者 成功-不执行 不成功-执行

;      (不)成功-执行


grep --color 'root' /etc/passwd 高亮

echo "alias cg='grep --clort'" >> ~/.bashrc 

-n 显示行数

-c 计数几行

-v 不包含keyword

-A 2 多显示下两行

-B 2 多显示上两行

-C 2 多显示上下两行

-r 'root' /etc/* 目录下搜索关键字,含文件目录名字,内容

-rh 不显示最前面目录路径

cg '[0-9]' 1.txt

cg '[a-zA-Z]' 1.txt

cg -v '[a-zA-Z]' 1.txt 不包含

cg '^[a-z]' 1.txt 以字母开头

cg '[^0-9]' 1.txt 不包含纯的数字,不包含空行

cg '^[^0-9]' 1.txt 不以数字开头的行,不包含空行

cg '^$' 1.txt 显示空行

cg 'r.o' 1.txt 任意一个字符,包含空格,特殊符号

cg 'r*o' 1.txt 0个或多个前面的字符 o也符合

cg 'r.*o' 1.txt r开头o结果都算,中间不管什么,任意个字符

cg 'r\?o' 1.txt 脱义字符  ==cg -E 'r?o'  0个或1个前面的字符

grep -E ==egrep 


egrep 'r+o' 1.txt 1个或多个前面的字符







 


































你可能感兴趣的:(profile,alias,source)