linux基础

今天简单说一下关于linux基础的知识,并不完全,都是一些比较常用的命令,可以进行简单的了解。
Linux 是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX UNIX 的多用户、多任务、支持 多线程和多CPU 的操作系统。 Linux 能运行主要的 UNIX 工具软件、应用程序和网络协议。它支持 32 位和 64位硬件。 Linux 继承了 Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

目录结构

/bin 二进制文件,系统常规命令
/boot 系统启动分区,系统启动时读取的文件
/dev 设备文件
/etc 大多数配置文件
/home 普通用户的家目录
/lib 32位函数库
/lib64 64位库
/media 手动临时挂载点
/mnt 手动临时挂载点
/opt 第三方软件安装位置
/proc 进程信息及硬件信息
/root 临时设备的默认挂载点
/sbin 系统管理命令
/srv 数据
/var 数据
/sys 内核相关信息
/tmp 临时文件
/usr 用户相关设定

系统命令行含义

示例:root@text1:~ #
root #用户名,root为超级用户
@ #分隔符
text1  #主机名称
~ #当前所在目录,默认用户目录为~,会随着目录切换而变化
# #表示当前用户是超级用户,普通用户为$

基础命令

关闭系统

#(1)立刻关机
shutdown -h now 或者 poweroff
#(2)两分钟后关机
shutdown -h 2
# 重启
reboot

关闭重启

#(1)立刻重启
shutdown -r now 或者 reboot
#(2)两分钟后重启
shutdown -r 2

帮助命令

ifconfig --help //查看 ifconfig 命令的用法

用户命令

# 创建用户
adduser hadoop
# 设置密码
passwd hadoop
# 进入Hadoop用户
su hadoop //切换为用户"hadoop",输入后回车需要输入该用户的密码
exit  //退出

目录操作

切换目录

要注意这里用'//'来做注释,不要跟前面的搞混了。

cd / //切换到根目录
cd /bin //切换到根目录下的bin目录
cd .. //切换到上一级目录
cd ~ //切换到home目录
cd - //切换到上次访问的目录
cd xx(文件夹名) //切换到本目录下的名为xx的文件目录
cd /xxx/xx/x //可以输入完整的路径,直接切换到目标目录

查看目录

ls //查看当前目录下的所有目录和文件
ls -a //查看当前目录下的所有目录和文件
ls -l //列表查看当前目录下的所有目录和文件(列表查看,显示更多信息)
ls /bin //查看指定目录下的所有目录和文件

创建目录

mkdir tools //在当前目录下创建一个名为tools的目录
mkdir /bin/tools //在指定目录下创建一个名为tools的目录

删除目录与文件

rm 文件名 //删除当前目录下的文件
rm -f 文件名 //删除当前目录的的文件
rm -rf 文件夹名 //删除当前目录下此名的目录
rm -rf * //将当前目录下的所有目录和文件全部删除
rm -rf /* //将根目录下的所有文件全部删除

修改目录

mv 当前目录名 新目录名 //修改目录名,同样适用与文件操作
mv /usr/tmp/tool /opt //将/usr/tmp目录下的tool目录剪切到 /opt目录下面
mv -r /usr/tmp/tool /opt //递归剪切目录中所有文件和文件夹

拷贝目录

cp /usr/tmp/tool /opt //将/usr/tmp目录下的tool目录复制到 /opt目录下面
cp -r /usr/tmp/tool /opt //复制/usr/tmp/tool目录中所有文件和文件夹  到opt目录下面

搜索目录

find /bin -name 'a*' //查找/bin目录下的所有以a开头的文件或者目录

查看当前目录

pwd //显示当前位置路径

文件操作

新增文件

touch a.txt //在当前目录下创建名为a的txt文件

删除文件

rm 文件名 //删除当前目录下的文件
rm -f 文件名 //删除当前目录的的文件

编辑文件

vi 文件名 //打开需要编辑的文件
进入后,操作界面有三种模式:命令模式(command mode)、插入模式(Insert mode)和底行模式(last line mode)
命令模式
刚进入文件就是命令模式,通过方向键控制光标位置,
使用命令"dd"删除当前整行
使用命令"/字段"进行查找
按"i"在光标所在字符前开始插入
按"a"在光标所在字符后开始插入
按"o"在光标所在行的下面另起一行插入
按":"进入底行模式
插入模式
此时可以对文件内容进行编辑,左下角会显示 "-- 插入 --""
按"ESC"进入底行模式
底行模式
退出编辑: :q
强制退出: :q!
保存并退出: :wq


保存文件:按"ESC" -> 输入":" -> 输入"wq",回车 //保存并退出编辑
取消操作:按"ESC" -> 输入":" -> 输入"q!",回车 //撤销本次修改并退出编辑

查看文件

cat a.txt //查看文件最后一屏内容
less a.txt //PgUp向上翻页,PgDn向下翻页,"q"退出查看
more a.txt //显示百分比,回车查看下一行,空格查看下一页,"q"退出查看
tail -100 a.txt //查看文件的后100行,"Ctrl+C"退出查看

文件权限

权限说明

文件权限简介:'r' 代表可读(4),'w' 代表可写(2),'x' 代表执行权限(1),括号内代表"8421
法"
##文件权限信息示例:-rwxrw-r--
-第一位:'-'就代表是文件,'d'代表是文件夹
-第一组三位:拥有者的权限
-第二组三位:拥有者所在的组,组员的权限
-第三组三位:代表的是其他用户的权限

文件权限

普通授权 chmod +x a.txt
8421 chmod 777 a.txt //1+2+4=7 "7" 说明授予所有权限

打包与解压

说明

zip、.rar //windows系统中压缩文件的扩展名
tar //Linux中打包文件的扩展名
gz //Linux中压缩文件的扩展名
tar.gz //Linux中打包并压缩文件的扩展名

打包文件

tar -zcvf a.tar file1 file2,... //多个文件压缩打包

解压文件

tar -zxvf a.tar //解包至当前目录
tar -zxvf a.tar -C /usr/... //指定解压的位置
unzip test.zip //解压*.zip文件
unzip -l test.zip //查看*.zip文件的内容

其他常用命令

whereis

whereis ls //将和ls文件相关的文件都查找出来

which

which bash //查看指令"bash"的绝对路径
//注意which指令会在环境变量$PATH设置的目录里查找符合条件的文件。

sudo

sudo -l //列出目前的权限
$ sudo -u hadoop vi ~www/index.html //以 hadoop用户身份编辑 home 目录下www目录
中的 index.html 文件

sudo命令以系统管理者的身份执行指令

grep

grep -i "the" demo_file //在文件中查找字符串(不区分大小写)
grep -A 3 -i "example" demo_text //输出成功匹配的行,以及该行之后的三行
grep -r "ramesh" * //在一个文件夹中递归查询包含指定字符串的文件

service

service ssh status //查看服务状态
service --status-all //查看所有服务状态
service ssh restart //重启服务

free

free -g //以G为单位输出内存的使用量,-g为GB,-m为MB,-k为KB,-b为字节
free -t //查看所有内存的汇总
free -h // 查看内存

top

top //显示当前系统中占用资源最多的一些进程(shift+m 按照内存大小查看)

df

df -h
显示文件系统的磁盘使用情况

mount

mount /dev/sdb1 /u01 //挂载一个文件系统,需要先创建一个目录,然后将这个文件系统挂载到这个目录上

uname

uname -a 显示一些重要的系统信息

yum

yum install vim //使用yum安装vim
yum update vim //更新vim
yum remove vim //卸载/删除vim

rpm

rpm -ivh httpd-2.2.3-22.0.1.el5.i386.rpm //使用rpm文件安装apache
rpm -uvh httpd-2.2.3-22.0.1.el5.i386.rpm //使用rpm更新apache

date

date -s "01/31/2010 23:59:53" ///设置系统时间

scp

scp /opt/data.txt 192.168.1.101:/opt/ //将本地opt目录下的data文件发送到
192.168.1.101服务器的opt目录下

系统管理

防火墙

service iptables status //查看iptables服务的状态
service iptables start //开启iptables服务
service iptables stop //停止iptables服务
service iptables restart //重启iptables服务
chkconfig iptables off //关闭iptables服务的开机自启动
chkconfig iptables on //开启iptables服务的开机自启动


systemctl status firewalld.service //查看防火墙状态
systemctl stop firewalld.service //关闭运行的防火墙
systemctl disable firewalld.service //永久禁止防火墙服务

修改主机名

hostnamectl set-hostname 主机名
bash //立即生效

查看网络

ifconfig
ip a

修改IP

修改网络配置文件,vi  /etc/sysconfig/network-scripts/ifcfg-ens33
主要修改以下配置:
TYPE=Ethernet //网络类型
BOOTPROTO=static //静态IP
DEVICE=ens00 //网卡名
IPADDR=192.168.1.100 //设置的IP
NETMASK=255.255.255.0 //子网掩码
GATEWAY=192.168.1.1 //网关
DNS=8.8.8.8 //DNS
ONBOOT=yes //系统启动时启动此设置

service network restart重启网卡

配置映射

vi /etc/hosts   //修改文件
192.168.1.101 node1
192.168.1.102 node2
192.168.1.103 node3
在文件最后添加映射地址
配置好以后保存退出,输入命令: ping node1 ,可见实际 ping 的是 192.168.1.101

查看进程

ps -ef //查看所有正在运行的进程
lsof -i:端口

结束进程

kill pid //杀死该pid的进程

查看链接

ping IP //查看与此IP地址的连接情况
netstat -an //查看当前系统端口

快速清屏 :  ctrl+l //清屏,往上翻可以查看历史操作
 

你可能感兴趣的:(linux)