1. 查看当前目录下有哪些文件和目录
> ls //list
> ls -al //all list 显示当前目录中全部的子目录及文件的详细信息(以列表形式显示) 会显示隐藏文件
> ls -l //list显示当前目录一般文件的详细信息(以列表形式显示)
> ls -a //显示当前目录全部文件信息,只有文件的名字
> ls 目录 //罗列指定目录的文件信息
> ll //以列表形式列出当前目录文件的详细内容(不会显示隐藏文件)
ls -li # -i参数显示文件的inode节点信息
2. 查看我当前在哪个目录
>pwd
3. 显示当前用户信息
>who am i //显示用户名 和 其登录系统的时间信息
>whoami //只显示当前登录系统的用户名信息
4. 从普通用户切换到root用户
> su - //提示输入密码
5. 从root用户切换到普通用户
> su shuhua //从root切回普通用户
6. 从桌面窗口切换为“命令行窗口”(通过超级管理员切换)
> init 3
> init 5 //从“命令行”切换回“桌面”
7. 目录切换
> cd 具体目录
8. 输出文件的信息,全部内容直接都输出
>cat 文件
9. 创建目录指令
> mkdir 目录
> mkdir -p 目录1/目录2/目录3 //递归创建目录
10. 修改目录的名字
> mv 目录1 目录2 //把"目录1"的名字改为"目录2"的名字
> mv 目录/目录a 目录/目录b //把“目录a”改成"目录b"
11. 移动操作
> mv 文件 目录 //移动文件到指定的目录
> mv 目录 目录 //移动目录到指定目录(包括多级目录)
12. mv指令什么时候是移动,什么时候是该名字
mv 一参 二参
二参 是不存在的,就是改名字
二参 是存在的目录,就是移动
mv com.txt red.txt
red.txt是存在的文件,com.txt也是存在的文件
首先明确,不可以移动操作
不能
【能】把名字由com.txt改为red.txt
mv guangzhou hello.txt
guangzhou 是存在的目录
hello.txt 是存在的文件
首先明确不能移动
是否可以把guangzhou的名字改为hello.txt
【不能】把名字由“guangzhou”改为"hello.txt"
能
13. 删除目录
> rmdir 目录 //删除单个目录(没有子级目录)
> rm -rf 文件名字 //force强制 recursive 递归删除
> rm -rf / //kill your self [root用户可以删除更多的文件]
> rm -rf shanghai/beijing //这是删除shanghai下边的beijing目录,不会删除shanghai
14. 复制
>cp copy
>cp 目录 地址 -R //复制目录需要加上固定参数-R,目录会进行递归复制
>cp 文件 目录/不存在名字 //文件在被复制到指定目录的同时被“改名字”
>cp 文件 新文件名字 //复制同时并起新名字
15. 查看文件内容
> more 文件 //从文件内容第一行开始显示,有显示内容查看%百分比
//敲回车,会逐行查看后边的内容,到最后会释放光标
> less 文件 //逐行显示文件内容,通过“上、下、左、右”可以查看文档的各部分内容
//允许向前查看,没有百分比显示
//通过"q"键释放光标
> head -n 文件 //查看文件前n行内容
> tail -n 文件 //查看文件尾部n行内容
> wc 文件 //计算文件内容行数、段落
16. 创建新文件
> touch 文件名 //创建文件
17. 给文件添加内容
> echo 内容 > 文件 //把指定内容输入到“文件”里边
> echo 内容 >> 文件 //把内容追加到文件里边
18. 重定向内容到一个文件
> cat 文件1 > 文件2 //把文件1的内容重定向到文件2里边,文件2没有则会自动创建
> cat 文件1 >> 文件2 //追加重定向
19.增加用户 /etc/passwd存放系统用户信息(组编号、家目录)
> useradd 用户名
> useradd -g 编号 用户名 //增加用户的同时设置“组编号”
> useradd -d 目录名 用户名 //增加用户同时设置“家目录”,目录没有会自动创建
> useradd -g 编号 -d 家目录 用户名 //同时设置组编号和家目录地址
> useradd -g 组编号 用户 //常用操作
20. 创建组 (可以设置组本身编号)
> groupadd 组名 //常用操作
> groupadd -g 编号 组名 //可以设置组编号,下一个组的编号要从最大的自增
21. 修改用户信息(组编号、家目录地址、用户名)
> usermod -g 组编号 用户名 //修改用户的组编号
> usermod -d 家目录 用户名 //修改用户的家目录,passwd文件有修改,实际并没有这个目录(手动创建)
> usermod -u 编号 用户名 //修改用户本身的编号
> usermod -l 新名字 旧用户名 //修改用户的名字
22. 修改组 (组编号、组名)
> groupmod -g 组编号 组名 //修改组编号
> groupmod -n 新组名 旧组名 //修改组名字
23. 删除用户(用户信息、家目录地址)
> userdel 用户
> userdel -r 用户 //删除用户同时,其“家目录”地址也会被删除
24. 删除组
> groupdel 组名 //一个组下边有具体用户,该组不允许删除
6.添加组成员
使用gpasswd命令向指定组添加成员用户:
gpasswd-a user group_name
此操作由组管理员进行。(usermod也可以;)
7.删除组成员
使用gpasswd命令从指定组中删除成员用户:
gpasswd-d user group_name
25. 查看一个指令在使用的时候有何种参数可以设置
> useradd --help 命令 --help
26. 给一个用户设置密码(可以让其登录系统)
> passwd 用户名 //密码根据提示输入两遍
27. 查看命令具体参数设置
> man 命令 //前后反复查看命令的使用参数
28. 给文件进行权限设置[相对方式]
> chmod u+x 文件
> chmod g+x 文件 //给同组用户设置执行权限
> chmod o+x 文件 //给其他组用户设置执行权限
> chmod o+w,o+x 文件 //同时给文件设置可写、可执行全选
> chmod u-r 文件 //取消主人的可读权限
> chmod g-w,g-x 文件 //取消同组用户写、执行权限
> chmod o-r,o-x 文件 //取消其他组用户读、执行权限
> chmod g+rx,o+wx 文件 //给文件同组用户设置“读、执行”权限,其他组用户有“写、执行权限”
> chmod u-rwx,g-rw //取消具体用户的权限
29. 数字[绝对方式]设置文件权限
读、写、可执行
二进制代码表示计算机的信息
1-------------1
10-------------2
100-------------4
例如:读:1 写:2 执行3
如果文件权限是读写执行都有就是数字6
如果文件只有读的权限就是数字1
3 不知道是“读写” 还是 “执行权限”,歧义产生
正确的用法是:读4 写2 执行1
1:执行
2:写
3:写、执行
4:读
5:读、执行
6:读、写
7:读、写、执行
> chmod 777 文件 //主人、同组用户、其他组用户权限是满的
> chmod 001 文件 //主人、同组用户都没有权限,其他组用户有可执行权限
ppink.txt 主人有写、执行 同组用户有读 其他组用户有读、执行
> chmod 345 ppink.txt
30. 给目录递归设置权限
> chmod 755 目录 -R //-R参数可以递归目录进行权限设置
31. 文件权限使用
-w- 文件只有可写权限[不可以看到原内容,可以写,覆盖写,强行保存]
r-- 文件只有可读权限[可以看到原内容,可以写,不会覆盖,强行保存]
--x 文件有可执行权限[不可以看到原内容,可以写,覆盖写,强行保存]
32. 目录权限
r-- 目录有可读权限[可以阅读里边的文件,不允许进入]
--x 目录有执行权限[不能阅读,不允许写,允许进入目录]
-w- 目录有些权限[不能阅读,不能增加或减少文件,不能进入目录]
rw- 有读、写权限[可以阅读,不能进入目录]
rwx 读、写、可执行[可以阅读,可以增加减少文件、可以进入]
一个目录如何进行写操作:给目录增加文件或减少文件就是写
33. 同组用户对文件权限操作
r-- 操作只读文件[可以阅读,可以写,强行保存,文件的主人和组已经更改]
-w- 写权限 [不能读,可以强行覆盖写,文件的主人和组有更改]
--x 是否可以进入目录
[一个目录有可执行权限,说明用户可以切换进该目录]
34. 文件或目录的各种权限对超级管理员root没有影响
35. 在指定文件里边查找我们l 需要的内容
> grep 内容 文件
36. 查看“任务管理器”
> top
37. 查看内存信息
> free -m //以M兆为单位显示内存大小使用情况
38. 查看文件或目录占用大小的情况
> du -sh 目标 //统计目标文件及目录大小
39. 文件查找
find 目录 选项 选项值
> find ./ -name abc.txt //在当前目录查找名字为abc.txt的这个文件
> find / -name xxx //在根目录查找文件
> find ./ -size 大小 //根据文件的大小来查找
单位:
10 512字节默认
100c 1字节单位
100k 1024字节单位
> find ./ -size +100c //查找文件大小大于100字节的
> find ./ -size -100c //查找大小小于100字节的文件
> find ./ -size 4 //查找大小等于2048字节的文件
> find ./ -size 2k //查找大小等于2048字节的文件
> find ./ -maxdepth 1 //查找文件目录最深是2层
> find ./ -mindepth 1 //查找文件通过最浅层次进行查找
> find ./ -type f //通过类型查找,查找文件类型
> find ./ -type d //通过类型查找,查找目录类型
> find ./ -user 用户名 //查找文件主人为XX的文件
> find ./ -uid 用户编号 //查找文件主人编号为XX的文件
> find ./ -nouser //查找没有主人的文件
文件创建的时候,是某个用户创建的
有的一些文件创建好后,被用户发布到网络上边
我们把网络的文件下载本地,放到我们自己的系统里边
创建这个文件的用户,在我自己的系统里边并没有
例如,创建这个文件的用户编号是710(用户名:runfa)
> find ./ -perm 权限764 //根据文件的权限进行查找
> find ./ -name 'bao*' //进行模糊查找,名字前缀是bao的文件
2.
locate命令
locate命令用于查找文件,它比find命令的搜索速度快,它需要一个数据库(/var/lib/locate/locate.db),这个数据库由每天的例行工作(crontab)程序来更新。当我们建立好这个数据库后,就可以方便地来搜寻所需文件了。
即先运行:updatedb手动更新数据库
例如:查找相关字issue
$ locate issue
/etc/issue
/etc/issue.net
/usr/man/man5/issue.5
/usr/man/man5/issue.net.5
假如我想要在系统中查找一个名为 .html 的文件,那么可以这样执行命令:locate .html
40. 设置软连接
> ln -s 源文件 链接文件
> ln -s /home/shuhua/shanghai/passwd /var/passwd
41. 查看文件索引号码
> ls -li
42. 制作任务调度指令
> crontab -e //编辑任务调度指令
> crontab -l //查看任务调度指令设置情况
在17:38来执行具体任务指令
分钟 小时 日期 月份 星期 具体命令
38 17 * * * /home/shuhua/shanghai/newout.sh
每2个30执行一次 分钟必须定义1个数值
分钟 小时 日期 月份 星期 具体命令
30 */2 * * * /home/shuhua/shanghai/newout.sh
每2两分钟执行一次
分钟 小时 日期 月份 星期 具体命令
*/2 * * * * /home/shuhua/shanghai/newout.sh
0代表周日
43. 设置系统时间
> date -s "2013-08-13 17:39:40";
> date //查看系统时间
> date +%Y%m%d 20130813
44. 给文件设置主人
> change owner
> chown 主人 文件
45. 给文件设置组
> change group
> chgrp 组 文件
> chown .组 文件
46. 同时给文件设置主人和组
> chown 主人.组 文件
> chown 主人.组 目录 -R //递归给目录设置主人和组的信息,二级目录和三级目录等等都会设置
47. 实现设备挂载、卸载
> mount /dev/cdrom /home/shuhua/rom //把光驱挂载到rom的目录下边
> mount /dev/hda1 /home/shuhua/upan //挂载u盘
> mount /dev/sda3 /home/shuhua/pan3 //挂载硬盘
> umount 设备 或者 挂载点
> umount /dev/cdrom
> umount /home/shuhua/rom
48. rpm指令安装软件
> rpm -ivh 软件文件名(vsftpd-2.0.5-16.el5_4.1.i386.rpm) //安装软件
> rpm -e 软件名(vsftpd) //卸载软件
> rpm -q 软件名 //query检查是否安装该软件
> rpm -qa //查看系统全部安装软件情况
> rpm -qa | grep ftp //在全部安装软件里边,通过模糊方式查找是否有ftp这个软件
> rpm -u 文件名 //对软件升级
49. 让vsftpd软件运行
> service vsftpd start
50. 服务器重新启动
> reboot 重新启动
> shutdown 关机
> poweroff 关机
51 df(lh) 已经挂载的分区df
df -hT磁盘使用情况
52 打包压缩
a) tar -cf 包名 要打包的文件列表 打包
b) tar -xf 包名 解包
c) -c 打包 f 指定包名 z 打包成gz格式的
d) -x 解包 f 指定包名 v 显示详细信息
e) 打包压缩:tar -zcf 包名.tar.gz 要打包压缩的文件列表
f) 打包压缩:tar -jcf 包名.tar.bz2 要打包压缩的文件列表
g) 解压缩:tar -jxf 包名.tar.bz2
h) 解压缩:tar - zxf 包名.tar.gz
tar -zxf 包名.tar.gz -C 解压目录 解压到指定目录
53 date 查看系统日期时间
设置系统时间:
例如:将系统日期设定成2009年11月3日的命令
命令 : date -s 11/03/2009
将系统时间设定成下午5点55分55秒的命令
命令 : date -s 17:55:55
54.
20) 设置开机是否自动运行
a) chkconfig --level "name" 查看程序是否启动
b) 设置某个程序的启动级别 chkconfig --level 3 httpd off/on 级别为3时启动或关闭
21) chkconfig --add 【name】添加系统启动
22) chkconfig --del [name]删除
23) chkconfig --list httpd 查看启动了某些 程序
55
Linux Jobs等前后台运行命令详解,停止后台程序:
Shell支持作用控制,有以下命令:
1. command & 让进程在后台运行
ctrl + z
可以将一个正在前台执行的命令放到后台,并且暂停
2. jobs 查看后台运行的进程
3. fg %n 让后台运行的进程n到前台来,再Ctrl+c即可终止该程序.
4. bg %n 将一个在后台暂停的命令,变成继续执行
PS:”n”为jobs -l查看到的进程编号.
56
a) Ps aux 查看进程
b) Ps aux | grep httpd 查看单个进程
e) Kill 进程号 结束进程
f) Kill -9 立即执行结束进程
g) Netstat -tnl 查看端口号
h) Netstat -tnl | grep 3306
56 service iptables save 把防火墙规则保存至/etc/iptables文件中
service iptables start/stop/restart
例子:
1.设置默认规则(当规则列表中所有规则不匹配时使用默认规则)
//默认进入接收或者丢弃
iptables -P INPUT ACCEPT/DROP
2. -A 添加一条规则 -I 在指定条数前插入一条规则 如省略指定条数,则插入在第一条 D 删除指定条数 -L 查看防火墙规则 -F清空所有规则
iptables -A|-I|-D INPUT|OUTPUT|FORWARD -p 协议 -s 原地址 --sport 原端口号 -d 目标地址 --dport 目标端口 -j 动作(ACCEPT|DROP)
3 iptables -A INPUT -p tcp --dport 80 -J ACCEPT
57 zip unzip
zip 参数 压缩文件名路径.zip 要压缩的文件
zip -r 压缩文件名路径.zip 要压缩的的目录
zip -r /wang.zip wang 对王目录进行压缩并压缩到根目录
unzip fantg.zip -d ./wang 把fantg.zip文件压缩到根目录下王目录
59
.yum命令工具使用举例
yum update 升级系统
yum install ~ 安装指定软件包
yum update ~ 升级指定软件包
yum remove ~ 卸载指定软件
1.使用YUM查找软件包 命令:yum search ~
2.列出所有可安装的软件包 命令:yum list
3列出所有可更新的软件包 命令:yum list updates
4.列出所有已安装的软件包 命令:yum list installed
60
源码安装
./configure 配置
make 编译 make clean 清除编译文件 make clean && make && make install
make install 编译安装