Linux常用命令

 Vi对文件进行读写

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

1) 命令行模式command mode)

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

2) 插入模式(Insert mode)

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

不过一般我们在使用时把vi简化成两个模式,就是将底行模式(last line mode)也算入命令行模式command mode)。

2、vi的基本操作 
a) 进入vi

在系统提示符号输入vi及文件名称后,就进入vi全屏幕编辑画面:

$ vi myfile

不过有一点要特别注意,就是您进入vi之后,是处于「命令行模式(command mode)」,您要切换到「插入模式(Insert mode)」才能够输入文字。初次使用vi的人都会想先用上下左右键移动光标,结果电脑一直哔哔叫,把自己气个半死,所以进入vi后,先不要乱动,转换到「插入模式(Insert mode)」再说吧!

b) 切换至插入模式(Insert mode)编辑文件

在「命令行模式(command mode)」下按一下字母「i」就可以进入「插入模式(Insert mode)」,这时候你就可以开始输入文字了。

c) Insert 的切换

您目前处于「插入模式(Insert mode)」,您就只能一直输入文字,如果您发现输错了字!想用光标键往回移动,将该字删除,就要先按一下「ESC」键转到「命令行模式(command mode)」再删除文字。

d) 退出vi及保存文件

在「命令行模式(command mode)」下,按一下「:」冒号键进入「Last line mode」,例如:

w filename (输入 「w filename」将文章以指定的文件名filename保存)

wq (输入「wq」,存盘并退出vi)

q! (输入q!, 不存盘强制退出vi)

3、命令行模式(command mode)功能键 
1). 插入模式

按「i」切换进入插入模式「insert mode」,按“i”进入插入模式后是从光标当前位置开始输入文件;

按「a」进入插入模式后,是从目前光标所在位置的下一个位置开始输入文字;

按「o」进入插入模式后,是插入新的一行,从行首开始输入文字。

2). 从插入模式切换为命令行模式

按「ESC」键。

3). 移动光标

vi可以直接用键盘上的光标来上下左右移动,但正规的vi是用小写英文字母「h」、「j」、「k」、「l」,分别控制光标左、下、上、右移一格。

按「ctrl」+「b」:屏幕往“上”移动一页。

按「ctrl」+「f」:屏幕往“下”移动一页。

按「ctrl」+「u」:屏幕往“上”移动半页。

按「ctrl」+「d」:屏幕往“下”移动半页。

按数字「0」:移到文章的开头。

按「G」:移动到文章的最后。

按「$」:移动到光标所在行的“行尾”。

按「^」:移动到光标所在行的“行首”

按「w」:光标跳到下个字的开头

按「e」:光标跳到下个字的字尾

按「b」:光标回到上个字的开头

按「#l」:光标移到该行的第#个位置,如:5l,56l。

4). 删除文字

「x」:每按一次,删除光标所在位置的“后面”一个字符。

「#x」:例如,「6x」表示删除光标所在位置的“后面”6个字符。

「X」:大写的X,每按一次,删除光标所在位置的“前面”一个字符。

「#X」:例如,「20X」表示删除光标所在位置的“前面”20个字符。

「dd」:删除光标所在行。

「#dd」:从光标所在行开始删除#行

5). 复制

「yw」:将光标所在之处到字尾的字符复制到缓冲区中。

「#yw」:复制#个字到缓冲区

「yy」:复制光标所在行到缓冲区。

「#yy」:例如,「6yy」表示拷贝从光标所在的该行“往下数”6行文字。

「p」:将缓冲区内的字符贴到光标所在位置。注意:所有与“y”有关的复制命令都必须与“p”配合才能完成复制与粘贴功能。

6). 替换

「r」:替换光标所在处的字符。

「R」:替换光标所到之处的字符,直到按下「ESC」键为止。

7). 恢复/撤消/还原上一次操作

「u」:如果误执行一个命令,可以马上按下「u」,撤消上一个操作。按多次“u”可以执行多次撤消。

8). 更改

「cw」:更改光标所在处的字到字尾处

「c#w」:例如,「c3w」表示更改3个字

9). 跳至指定的行

「ctrl」+「g」列出光标所在行的行号。

「#G」:例如,「15G」,表示移动光标至文章的第15行行首。

10)  . 查找字符

「/关键字」:先按「/」键,再输入您想寻找的字符,如果第一次找的关键字不是您想要的,可以一直按「n」会往后寻找到您要的关键字为止。

「?关键字」:先按「?」键,再输入您想寻找的字符,如果第一次找的关键字不是您想要的,可以一直按「n」会往前寻找到您要的关键字为止。

创建文件

1. 命令格式

  mkdir [选项] 目录名

2. 命令选项

  -m=mode

    为目录指定访问权限,与chmod类似。

  -p  如果目录已经存在,则不会有错误提示。若父目录不存在,将会创建父目录。该选项常用于创建级联目录。

  -v  为每个目录显示提示信息。

查找文件

find ./ -name filename    区分大小写

find ./ -iname filename    不区分大小写

find ./ -name "filename*"   匹配以filename开头

删除文件

rm命令

-f      --force          略过不存在的文件,不显示任何信息

-r    --recursive    同时删除该目录下的所有目录层

复制和移动

复制:

mu文件夹下面名为mu二进制文件复制到mu1文件夹里面,具体命令为:
cp /mu/mu  /mu1
 
将mu文件夹中的文件 mu2和mu3 同时复制到mu1文件夹里面,那么公式为:
cp /mu/mu2 /mu/mu3  /mu1
 
复制文件到另一个目录后重命名文件,如将文件mu复制到mu1文件夹里面并重命名为 twotest 命令为:
cp /mu/mu  /mu1/twotest

 

移动:

将文件mu移动到one目录下面

$mv /mu/mu /one

 

卸载软件

rpm -qa | grep softwarename    查询该软件是否存在

rpm -e softwarename --nodeps

解压源码包

tar命令

-C:解压路径

tar -zxvf hadoop-2.6.5.tar.gz -C /usr/local/hadoop-2.6.5/

返回上级目录

cd ..                  返回上一级目录

cd ../..               返回上两级目录

cd或cd ~           返回home目录,例如:当前用户是root,就返回root目录

cd - 目录名       返回指定目录

cd /      返回根目录

查看进程信息

输入命令

# ps  -ef | grep processname

返回结果包含进程信息

root      2662     1  0 07:12 ?        00:00:00 nginx: master process /usr/sbin/nginx

nginx错误日志位置

/var/log/nginx/error.log

修改权限

1.chgrp

示例:
  chgrp staff /u            将 /u 的属组更改为"staff"。
  chgrp -hR staff /u    将 /u 及其子目录下所有文件的属组更改为"staff"。

2.chown

示例:
  chown root /u        将 /u 的属主更改为"root"。
  chown root:staff /u    和上面类似,但同时也将其属组更改为"staff"。
  chown -hR root /u    将 /u 及其子目录下所有文件的属主更改为"root"。

3.chmod

linux系统文件夹644、755、777权限设置详解 ,左至右,第一位数字代表文件所有者的权限,第二位数字代表同组用户的权限,第三位数字代表其他用户的权限。

而具体的权限是由数字来表示的,读取的权限等于4,用r表示;写入的权限等于2,用w表示;执行的权限等于1,用x表示;

通过4、2、1的组合,得到以下几种权限:0(没有权限);4(读取权限);5(4+1 | 读取+执行);6(4+2 | 读取+写入);7(4+2+1 | 读取+写入+执行)

以755为例:

第一位7等于4+2+1,rwx,所有者具有读取、写入、执行权限;

第二位5等于4+1+0,r-x,同组用户具有读取、执行权限但没有写入权限;

第三位5,同上,也是r-x,其他用户具有读取、执行权限但没有写入权限。

下面列出常用的linux文件权限:

444 r–r–r–
600 rw——-
644 rw-r–r–
666 rw-rw-rw-
700 rwx——
744 rwxr–r–
755 rwxr-xr-x
777 rwxrwxrwx

linux下rwx权限数字解释
chmod也可以用数字来表示权限如 chmod 777 file
语法为:chmod abc file
其中a,b,c各为一个数字,分别表示User、Group、及Other的权限。
r=4,w=2,x=1
若要rwx属性则4+2+1=7;
若要rw-属性则4+2=6;
若要rx属性则4+1=5。
范例:
chmod a=rwx file

chmod 777 file
效果相同
chmod ug=rwx,o=x file

chmod 771 file
效果相同
若用chmod 4755 filename可使此程序具有root的权限

查看Ubuntu版本和显卡型号

cat /etc/issue 查看ubuntu版本

lspci |grep VGA 查看集成显卡型号

lspci|grep -i amd 查看amd显卡驱动型号
lspci|grep -i nvidia 查看Nvidia显卡驱动型号

环境变量设置

1. 在/etc/profile文件中添加变量【对所有用户生效(永久的)】

2. 在用户目录下的.bash_profile文件中增加变量【对单一用户生效(永久的)】
3. 直接运行export命令定义变量【只对当前shell(BASH)有效(临时的)】
"source /etc/profile"使环境变量生效

监控进程

查看88端口:netstat -lnp|grep 88  

查看进程详细信息:ps 1777

查看是否启动成功:ps -ef | grep redis  

可以看到redis监听端口:netstat -tnlp | grep redis

修改静态ip

[root@CentOS7Two ~]# vi /etc/sysconfig/network-scripts/ifcfg-eno16777736 

原来是

TYPE="Ethernet"
BOOTPROTO="dhcp"
DEFROUTE="yes"
PEERDNS="yes"
PEERROUTES="yes"
IPV4_FAILURE_FATAL="no"
IPV6INIT="yes"
IPV6_AUTOCONF="yes"
IPV6_DEFROUTE="yes"
IPV6_PEERDNS="yes"
IPV6_PEERROUTES="yes"
IPV6_FAILURE_FATAL="no"
NAME="eno16777736"
UUID="157c8fb5-23b3-414c-8519-25bef9b20a54"
DEVICE="eno16777736"
ONBOOT="yes"

修改成

TYPE="Ethernet"
#BOOTPROTO="dhcp"
DEFROUTE="yes"
PEERDNS="yes"
PEERROUTES="yes"
IPV4_FAILURE_FATAL="no"
IPV6INIT="yes"
IPV6_AUTOCONF="yes"
IPV6_DEFROUTE="yes"
IPV6_PEERDNS="yes"
IPV6_PEERROUTES="yes"
IPV6_FAILURE_FATAL="no"
NAME="eno16777736"
UUID="157c8fb5-23b3-414c-8519-25bef9b20a54"
DEVICE="eno16777736"
#ONBOOT="yes"

#static assignment
NM_CONTROLLED=no
ONBOOT=yes #auto start
BOOTPROTO=static #static ip
IPADDR=192.168.1.122 #local ip
NETMASK=255.255.255.0 #submask
GATEWAY=192.168.1.1 #default gateway

然后重启服务即可

service network restart

不能上网解决

sudo nano resolv.conf

nameserver 8.8.8.8
nameserver 8.8.4.4 

VMWare扩充磁盘容量

https://blog.csdn.net/hampton_chen/article/details/81370170

使用Anaconda

运行anaconda前先激活环境

source ~/anaconda3/bin/activate

图形界面和命令界面切换

从图形界面进入命令界面

systemctl isolate multi-user.target

从命令界面进入图形界面

systemctl start graphical.target
posted @ 2018-06-28 18:03  Rest探路者  阅读(407)  评论(0编辑  收藏  举报
levels of contents