Linux 常用命令

日常操作命令
查看当前所在的工作目录:pwd
查看当前系统的时间:date
查看当前在线的用户:who
查看最近的登录历史记录:last
文件系统操作

查看目录信息

ls /:查看根目录下的子节点(文件夹和文件)信息
ls -al:-a 是显示隐藏文件 -l 是以更加详细的列表形式显示

切换目录

cd /home

创建文件夹

mkdir aaa  相对路径的写法
mkdir -p aaa/bbb/ccc 创建连续的文件夹
mkdir /data 绝对路径的写法

删除文件夹

rmdir  可以删除当前空目录
rm -r aaa 可以把 aaa 整个文件夹及其子节点全部删除
rm -rf aaa 强制删除 aaa

修改文件夹名称

mv aaa abc

创建文件

touch somefile:创建一个名为 somefile 的文件
echo "this is file" > somefile:利用重定向 ">" 的功能,将一条指令的输出结果**写入**到一个文件夹中,会覆盖原文件内容
echo "this is add filecontext" >> somefile 将一条指令的输出结果**追加**到一个文件中,**不会覆盖**原文件内容
cat somefile 打印 somefile 的内容

利用 vi 文本编辑器来编辑生成文件

vi somefile:编辑此文件
1、首先会进入“一般模式”,此模式只接受各种快捷键,不能编辑文件内容
2、按 i 键,就会从一般模式进入编辑模式,此模式下,敲入的都是文件内容
3、编辑完成之后,按 Esc 键退出编辑模式,回到一般模式;
4、再按:,进入“底行命令模式”,输入 wq 命令,回车即可。

一般模式下的快捷键

a:在光标后一位开始插入
A:在该行的最后插入
I:在该行的最前面插入
gg:直接跳到文件的首行
G:直接跳到文件的末行
dd:删除行,如果  5dd   ,则一次性删除光标后的5行
yy:复制当前行,  复制多行,则  3yy,则复制当前行附近的3行
p:粘贴
v:进入字符选择模式,选择完成后,按 y 复制,按 p 粘贴
ctrl+v:进入块选择模式,选择完成后,按 y 复制,按 p 粘贴
shift+v:进入行选择模式,选择完成后,按 y 复制,按 p 粘贴

低行命令模式中
查找并替换

:%s/sad/888 查找文件内容中所有的 sad,替换成 888
:/you 查找文件中出现的 you,并定位到第一个找到的地方,按 n 可以定位到**下一个**匹配位置(按 N 定位到上一个)
文件权限的操作

查看文件权限

d:标识节点类型(d:文件夹  -:文件  l:链接)
r:可读  w:可写  x:可执行(文件夹可否进入)

例如:drwxr-xr-x
第一组 rwx:表示这个文件的拥有者对它的权限:可读可写可执行
第二组 r-x:表示这个文件的所属组对它的权限:可读,不可写,可执行
第二组 r-x:表示这个文件的其他用户(相对于上面两类用户)对它的权限:可读,不可写,可执行

修改文件权限

chmod g-rw haha.dat:表示将 haha.dat 对所属组的 rw 权限取消
chmod o-rw haha.dat:表示将 haha.dat 对其他人的 rw 权限取消
chmod u+x haha.dat:表示将 haha.dat 对所属用户的权限增加 x

也可以用数字的方式来修改权限

drwxr-xr-x (二进制表示:111 101 101)
chmod 664 haha.dat:就会修改成 rw-rw-r--(110 110 100)

如果要将一个文件夹的所有内容权限统一修改,则可以 -R 参数

chmod -R 770 aaa/
改变指定目录以及其子目录下的所有文件的拥有者和群组
chown angela:angela aaa/    <只有 root 能执行> 

目录没有执行权限的时候普通用户不能进入;

文件只有读写权限的时候普通用户是可以删除的(删除文件不是修改它,是操作父及目录),只要父级目录有执行和修改的权限

基本的用户管理

添加用户

useradd  angela
要修改密码才能登陆 
passwd angela  按提示输入密码即可

为用户配置sudo权限

root 用户权限编辑 vi /etc/sudoers 文件
在文件的如下位置,为hadoop添加一行即可
root    ALL=(ALL)       ALL     
hadoop  ALL=(ALL)       ALL

然后,一般用户就可以用 sudo 来执行系统级别的指令

sudo useradd huangxiaoming
系统管理操作
查看主机名
hostname
修改主机名(重启后无效)
hostname hadoop
修改主机名(重启后永久生效)
vi /ect/sysconfig/network
修改IP(重启后无效)
ifconfig eth0 192.168.12.22
修改IP(重启后永久生效)
vi /etc/sysconfig/network-scripts/ifcfg-eth0
mount 挂载外部存储设备到文件系统中
mkdir /mnt/cdrom  创建一个目录,用来挂载
mount -t iso9660 -o ro /dev/cdrom /mnt/cdrom/   
将设备/dev/cdrom挂载到挂载点:/mnt/cdrom中
umount /mnt/cdrom 解除挂载
统计文件或文件夹的大小
du -sh /mnt/cdrom/Packages
du -sh *  查看当前目录下所有文件夹的大小
df -h 查看磁盘的空间
关机
halt
重启
reboot

服务器之间的 SSH 登录
服务器 hadoop01 登录服务器 hadoop02,hadoop01 上操作

ssh 192.168.81.62(hadoop02 的服务器 IP 地址)

配置服务器之间的免密 SSH 登录
假如 hadoop01 要登陆 hadoop02
在 hadoop01 上操作:

首先生成密钥对
ssh-keygen (提示时,直接回车即可)
再将 hadoop01  自己的公钥拷贝并追加到 hadoop02 的授权列表文件 authorized_keys 中
ssh-copy-id 192.168.81.62(hadoop02 的 IP 地址)

服务器之间文件传输

-- 将 filename.log 文件以 root 身份传输到 192.168.81.62 服务器下的 home 文件夹下。
scp filename.log [email protected]:/home/

一次性完成打包&&压缩的操作

产生压缩包:
tar -zcvf my.tar.gz aaa/
解压压缩包:
tar -zxvf my.tar.gz 

端口开启以及防火墙

开启 80 端口

firewall-cmd --zone=public --add-port=80/tcp --permanent

–zone # 作用域

–add-port=80/tcp # 添加端口,格式为:端口/通讯协议

–permanent # 永久生效,没有此参数重启后失效

firewall-cmd --reload # 重启 firewall
systemctl stop firewalld.service # 停止 firewall(建议内网时,关闭防火墙)
systemctl disable firewalld.service #禁止firewall开机启动

你可能感兴趣的:(Linux 常用命令)