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
移动:
$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文件中添加变量【对所有用户生效(永久的)】
监控进程
查看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
作者:Rest探路者
出处:http://www.cnblogs.com/Java-Starter/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意请保留此段声明,请在文章页面明显位置给出原文连接
Github:https://github.com/cjy513203427