1 linux 概述
1.1 linux 结构
1.1.1 linux的四部分
可以把Linux系统看作由四部分构成:内核、用户界面、文件结构和实用工具
/bin 普通用户的可执行文件,系统的任何用户都可以执行该目录中的命令
/boot 存放Linux操作系统启动时所需要的文件
/dev 系统中所有设备文件
/etc 系统中的配置文件
/home 普通用户的宿主目录,每个用户在该目下都有一个于用户名同名的目录。
/mnt 中的子目录用于系统中可移动设备的挂载点
/root 超级用户root的宿主目录
/sbin 系统中的管理命令,普通用户不能执行
/tmp 系统的临时目录
/usr 系统应用程序的相关文件
/var 系统中经常变化的文件如日志文件和用户邮件
/
/ \
/ \
etc home
/ /
/ /
profile xiaoming
/ \
配置系统 .bash_profile
环境变量 配置用户的环境变量
环境变量:配置.bashrc文件可以指定某些程序在用户登录的时候就自动启动
系统环境变量设置:在root目录下 Vi .bash_profile
修改PATH=$PATH:$HOME/bin :/安装目录/bin
需要退出(quit),重新登陆
当希望临时加入某个环境变量:用export PATH =$PATH : $HOME /bin:/root/test/t1
已定义好的环境变量:
SHELL:默认的shell
PATH:路径
USER:当前登录用户的用户名
显示变量内容:echo $PATH
echo $USER
echo $SHELL
也可以使用env命令显示环境变量
通配符:
* 代表多个字母或数字
? 一个
别名:
命令:alias显示系统当前定义的所有alias
alias cp ='cp-i'
alias ll='ls -l --color = tty'
2. linux 基本命令
2.0 重启
shutdown - h now 立刻关机
shutdown - r now 重启
reboot 重启
2.1 文件查看和连接命令
cat cat [选项]
more 显示文件内容,带分页
less 显示文件内容,带分页
grep 在文本中查询指定内容
| 管道命令[把上一个命令的结果给|后的命令处理]
grep "shunping" aaa.java
grep -n ...... 显示行数
grep -n "shunping" aaa.java > kkk.bak 重定向命令
ls -l > a.txt 列表的内容写入文件 a.txt(覆盖写)
ls -l >> a.txt 追加写到文件的末尾
find的使用:
在特定目录下搜索并显示指定名称的文件和目录,搜索一段时间内被存 取/变 更的文件或目录。
find /home -amin -10 十分钟内存取的文件和目录
find /home -atime -10 十小时
find /home -cmin -10 十分钟内更改过的
find /home -size +10k 大小为10k的
将目前目录及其子目录下所有延伸档名是 c 的档案列出来。
# find . -name "*.c"
将目前目录其其下子目录中所有一般档案列出
# find . -ftype f
将目前目录及其子目录下所有最近 20 分钟内更新过的档案列出
# find . -ctime -20
2.2命令的操作
more more [选项]
less less [选项]
clear 清除屏幕命令
history 查看历史命令记录
2.3目录相关命令
cd .. 可进入上一层目录
cd - 进入上一个进入的目录
cd ~ 可进入用户的home目录
pwd 显示当前在哪个路径
ls 列出文件和目录
ls -a 显示隐藏文件
ls -l 显示常列表格式
mkdir 建立目录
rmdir 删除空目录
touch 建立空文件
2.4文件权限、用户组
2.4.1文件操作
cp 复制命令 将档案 aaa 复制(已存在),并命名为 bbb:
cp aaa bbb
将所有的C语言程式拷贝至 Finished 子目录中:
cp *.c Finished
cp -r dir1 dir2 递归复制(复制子目录信息)
mv 移动文件和改文件 将档案 aaa 更名为 bbb:
mv aaa bbb
将所有的C语言程式移至 Finished 子目录中: mv -i *.c
rm 删除文件和目录
rm -rf * 删除所有内容(包括目录和文件)
如何修改文件的访问权限
chmod 777 along
范例 :将档案 file1.txt 设为所有人皆可读取:
chmod ugo+r file1.txt
将档案 file1.txt 设为所有人皆可读取:
chmod a+r file1.txt
将档案 file1.txt 与 file2.txt 设为该档案拥有者,与其所属同一个群体者可写入,但其他以外的人则不可写入:
chmod ug+w,o-w file1.txt file2.txt
将 ex1.py 设定为只有该档案拥有者可以执行:
chmod u+x ex1.py
将目前目录下的所有档案与子目录皆设为任何人可读取:
chmod -R a+r *
2.4.2用户组操作
su- 切换成系统管理员
su 用户之间的切换
logout 用户注销
useradd xiaoming 添加用户(root下)
passwd xiaoming 设置xiaoming的密码
userdel xiaoming 删除用户
userdel -r xiaoming删除用户及其主目录
每个用户必须属于某一个组,不能独立于组外。
每个文件有所有者、所在组、其它组的概念
*1,所有者:一般指创建者
用ls -ahl 命令可以查看文件的所有者
用chown 用户名 文件名 来修改文件的所有者
*2,文件所在组 ----用户所在的组
ls -ahl 可以看见文件的所有组
chgrp 组名 文件名 修改文件所在组
*3,其它组---除开文件的所有者和所在组的用户外,
系统其他用户都是文件的其他组
添加组 ---groupadd policeman
查看Linux中所有组 : vi /etc/group 查看该文件或cat /etc/group | more
创建用户并指定将该用户分配到哪个组
useradd -g 组名 用户名
查看Linux中所有用户信息:vi /etc/passwd 或者cat /etc/passwd
文件权限:-----分为三种:r-可读,用四表示
| | | w-可写,用2表示
-|rw-|r--|r-- x-可执行,用1表示
| | |
上图中由右向左:
第1部分:其它组的用户对该文件的权限
第2部分:文件所在组对该文件的权限
第3部分:文件的所有者对该文件的权限
第4部分:文件类型 ---普通文件(-),目录(d),链接(l)
-d
删除用户的命令为userdel,该命令的格式为:userdel <用户名>
修改用户属性
usermod –g<主组名> -G <组名> -d <用户主目录> -s <用户shell>
在添加用户时,可以指定将该用户添加到哪个组中,同样的用root的管理权限可以改变 某个用户所在的组:usermod -g 组名 用户名
可以用 usermod -d 目录名 用户名 改变该用户登录的初始目录
增加用户组
groupadd <新组名>
删除用户组
groupdel <组名>
修改组成员:直接编辑/etc/group文件,将用户名写到对应的组名的后面
whoami命令的功能在于显示用户自身的用户名。
who [选项]:该命令主要用于查看当前在线的用户情况
w命令 :用于显示登录到系统的用户情况
finger命令可用于查找和显示用户信息,并且在查找后显示指定账号的相关信息
chfn命令能够改变系统存储的用户信息
切换用户身份:su [用户名]
2.5 帮助命令
man
2.6 vi 编辑命令
vi有三种基本工作模式,分别是:命令模式(command mode)、插入模式(insert mode)和底行模式(last line mode)
进入vi:
命令“vi 文件名”
命令“vi”,在退出vi时再指定文件名
选项“+n”,表示希望在进入vi之后,光标处于文件中第n行上,
选项“+”表示希望在进入vi之后光标处于文件最末行。
保存文件:
1.在命令模式下,连按两次大写字母
2.在末行模式下:
:w vi保存当前编辑的文件,但并不退出vi,而是继续等待用户输入命令。 :w
:w!
在末行模式下,有四种方法可以退出vi返回到shell:
:q 系统退出vi返回到shell。在用此命令时,若编辑的文件没有被保存,则vi在窗口的最末行给出提示信息。
:q! vi放弃所作修改而直接退到shell下。
:wq 先保存文件,然后再退出vi返回到shell。
:x 该命令的功能与命令模式下的ZZ命令功能相同
0(数字0) 移到当前行的行首
$ 移到当前行的行尾
2.7 设备硬盘操作
挂载设备
查看设备:使用命令“fdisk –l”可以查看系统的存储设备
挂载设备 :首先使用mkdir命令建立挂载点目录,然后再使用mount命令挂载相关设备
mkfs [选项][-t <文件系统类型>] [设备名称] [区块数]
说明:把指定的设备格式为指定的文件系统。
查看磁盘使用情况
df [-参数] 比如, df-l
查看某个目录是在哪个分区
df [目录全路径]
查看Linux系统分区具体情况
fdish -l
2.8 网络配置
配置网络接口可以使用三种不同的工具来完成:
使用网络接口配置程序netconfig
使用图形配置工具
使用终端命令ifconfig
监控网络状态信息:
显示网络统计信息的命令netstat
此命令用来显示整个系统目前的网络情况。例如目前的连接、数据包传递数据 、或路由表的内容。如 netstat -an netstat -anp|more (查看网络端口的使用的情况)
显示数据包经过历程命令:traceroute
route 查看路由表
**********************************************
1.追踪路由 :tracert 目标ip/域名
2.测试两个ip是否畅通:ping 目标IP
3.window下查看IP情况:ipconfig
4.Linux/unix下查看IP情况:ifconfig
5.linux 网络环境配置:
第一种:
(1) 用root身份登陆,运行setup命令进入到text mode setup utility
对网络进行配置,这里可以进行ip、子网掩码、默认网管、dns的设置
(2) 这时网卡的配置没有立即生效,运行
/etc/rc.d/init.d/network restart命令我们刚才作的配置生效。
第二种:
(1)ifconfig eth0 x.x.x.x对网卡进行设置
(2)infconfig eth0 network x.x.x.x对子网掩码设置
对广播地址和dns使用默认的
注意:这样配置网络会立即生效,但是是临时生效
第三种:
(1) 修改/etc/sysconfig/network-scripts/ifcfg-eth0
这个文件的各个属性可以修改,包括ip,子网掩码、广播地址、默认网关
(2)这是网卡的配置没有生效
运行/etc/rc.d/init.d/network restart 命令我们刚才做的设置才生效
Linux中的所有设备都是文件,这种方法是最底层的方法,永久性修改
VMware下Linux和window ping
(1) windows下ipconfig查看VM网卡IP
(2) 配置Linux的IP使两者处于同一个子网的 即可以ping通
ifconfig <设备名>
例如:
ifconfig eth0 192.168.15.11 netmask 255.255.255.0
在网络配置界面中,通过“激活”或者“解除”按钮可以启动或者禁用网络接口,
网络控制程序network
/etc/rc.d/init.d/network start|stop|restart
命令ifconfig :
ifconfig <设备名> [up|down]
命令ifup/ifdown
ifup eth0
ifdown eth0
配置文件名 |
功能 |
/etc/sysconfig/network |
最基本的网络信息,系统启动时读取该文件 |
/etc/sysconfig/network-scripts/* |
此目录下的文件是系统启动时用来初始化网络的一些信息,例如:第一块以太网卡对应的文件为ifcfg-eth0 |
/etc/host.conf |
域名解析的控制文件 |
/etc/hosts |
域名或主机名与IP地址的映射文件 |
/etc/resolv.conf |
域名服务器设置文件 |
/etc/protocols |
定义使用的网络互联协议及协议号 |
/etc/services |
设定主机的不同端口的网络服务 |
2.9 安装软件:
获取最新版本的Apache源代码
将源代码解压缩
./configure –- prefix=/home/myapache
执行编译命令:make
执行安装命令:make install
账号和用户管理
用户和组的配置信息保存在以下三个文件中:
/etc/passwd
/etc/shadow
/etc/etc/group
2.10 更改文件所有者命令chown
chown [选项] user[:group]
更改文件访问权限命令chmod
chmod [选项]
mode:[ugoa][[+-=][rwxX]...][,…],
mode也可以用数字来表示权限:
chmod abc file
a,b,c各为一个数字,分别表示User、Group、及Other的权限。权限是关于可读(r)、可写(w)、可执行(r)三个属性设置值的和,其中r=4,w=2,x=1,
例如:
若要rwx属性,则4+2+1=7;
若要rw-属性,则4+2=6;
若要r-x属性,则4+1=7
2.11 进程管理
Linux操作系统包括三种不同类型的进程,每种进程都有自己的特点和属性:
交互进程:由shell启动的进程。
批处理进程:这种进程和终端没有联系,是一个进程序列。
守护进程:在后台持续运行的进程。
前台启动:一般地,用户键入一个命令,就已经启动了一个前台的进程。
后台启动 :对于非常耗时进程,可以然进程在后台运行。从后台启动进程其实就是在命令结尾加上一个“&”号
每个进程,都会对应一个父进程,而这个父进程可以复制多个子进程
每个进程都可能以两种方式存在:后台或前台
进程就是正在执行的程序
显示系统执行的进程:ps命令,可以不加任何参数
1. ps -a :显示当前终端的所有进程信息
2:ps -u :以用户的格式显示进程信息
3. ps -x :显示后台进程运行的参数
ps -aux
终止进程:kill/killall
终止某个进程:kill 进程号 如:kill 6251
kill -q 5222 :因为某些进程会捕捉某些信息,如果直接不能结束进程,可以使用“ -q”传送信息
动态监控进程:top
top和ps类似,top在执行一段时间可以更新正在进行的进程
1.监视特定用户
top:输入此命令,按回车键,查看执行的进程
u:然后输入“u” 回车,在输入用户名即可
2.终止指定的进程
top:
k: 输入k回车,再输入要结束的进程ID
3.top -d 10 :指定系统更新进程的时间为10秒
按小q退出
2.12任务调度命令
任务调度指系统在某个时间执行的特定的命令和程序
任务调度分类:
1.系统工作:有些重要的工作必须周而复始的执行,如病毒扫描.....
2.个别用户工作:个别用户可能希望执行某些程序
置任务调度文件:/etc/crontab
设置个人任务调度:执行crontab -e命令
接着输入任务到调度文件
如:5**** ls -l /etc/ > /tmp/to.txt
意思是说每小时的第五分钟执行ls -l /etc/ > /tmp/to.txt
任务调度的使用:
1.设置任务 crontab -e
2.每隔一定时间去执行 data > /home/mydata1
希望每天凌晨2:00执行 date >> /home/mydate
02*** date >> /home/mydate
调度文件的规则:
字段名称 说明 范围
分钟 每小时第几分钟 0~59
小时 每日的第几个小时 0~23
日期 每月的第几天 1~31
日历 每年的第几个月 1~12
星期 每周的第几天 0~6
3.怎么样调度多个任务?
a.在crontab -e 中直接写
b.可以把所有的任务写入一个可执行文件(shell编程)
例子: vi mytask.sh
date >> /home/mydate
cp /home/mydate /root
chmod 744 mytask.sh
crontab -e
***** /root/mytask.sh
终止任务调度: crontab -r :终止任务调度
crontab -l :列出当前有哪些任务调度
2.13 at命令
在shell提示符下输入”at 时间”,然后按回车键。这时在下一行shell会等待用户继续输入要执行的命令。每一行输入一个命令,所有命令都输入完毕后按Ctrl+d键结束。
将各个命令写入shell脚本中,然后使用下面格式设置在指定时间执行shell脚本中的命令:
at 时间 –f脚本文件。
2.14 batch命令
crone命令在系统启动时由一个shell脚本自动启动,进入后台。
cron启动后搜索/var/spool/cron目录,寻找以/etc/passwd文件中的用户名命名的crontab文件,被找到的这种文件将载入内存。
如果没有crontab文件,就转入“休眠”状态,释放系统资源。
cron每分钟“醒”过来一次,查看当前是否有需要运行的命令。
如果发现某个用户设置了crontab文件,它将以该用户的身份去运行文件中指定的命令。命令执行结束后,任何输出都将作为邮件发送给crontab的所有者,或者/etc/crontab文件中MAILTO环境变量中指定的用户。
内存查看命令free
磁盘空间用量查看命令df
2.15设置系统日期:
1.date命令。可以直接输入date 来查看系统时间
2.利用date命令来更改系统时间
date MMDDHHMCCYY.SS:指定月月日日时时分分年年年年.秒秒
3.查看日历:cal 3 2002 :查看2001年3月的日历
4.查看年历:cal 2008
2.16:软件安装
1.linux JDK的安装
a.把**.iso 文件挂载在虚拟机上做好配置
mount /mnt/cdrom
unmount /mnt/cdrom
b.把安装文件拷贝到 /home
cp 文件 /home
c.cd /home
d.安装
./**.bin
e.看看文件 /etc/profile[环境配置文件]
f.配置刚才自己安装的JDK
2.eclipse
a.安装文件拷贝到 /home
b.安装
tar -zxvf **.tar.gz
c.启动eclipse[进入图形界面]
startx ./eclipse
./eclipse & 后台方式运行
2.17:shell
作为命令语言互动式地解释和执行用户输入的命令只是shell功能的一个方面
另外shell还可以进行程序设计,他提供了定义变量和参数的手段以及丰富的程序控制结构。使用shell类似于DOS中的批处理文件称为shell script
shell有很多,常用的有3种:/bin/sh /bin/csh /bin/ksh
查看shell种类 :ls -l /bin/*sh
1.查看目前使用的是哪种shell
env [该命令可以显示当前操作系统的环境变量]
2.shell的修改:
直接输入:chsh -s 输入新的shell 如:/bin/csh
2.18:RPM管理
介绍:一种用于互联网下载包的打包及安装工具,它包含在某些Linux分发版中。它生成 具有.RPM扩展名的文件。
RPM是RedHat Package Manager(RedHat软件包管理工具)的缩写
RPM包的名称格式:apache-1.3.23-11.i386.rpm
**RPM 常用命令
rpm -qa:查询所安装的所有rpm软件包
rpm -qa | more
rpm -pa | grep x
rpm -q 软件包名 (查询软件包是否安装)
rpm -q foo
rpm -qi 软件包名:查询软件包信息
rpm -ql file
rpm -ql 软件包名 :查询软件包中的文件
rpm -ql file
rpm -qf文件全路径名:查询文件所属的软件包
rpm -qf /etc/passwd
rpm -qp包文件名:查询包的信息、对这个软件包的介绍
rpm -qp jdk-1-5_linux -i586.rpm
安装rpm包:
rpm -i RPM包路径名称:安装包到当前系统
i = install
rpm -ivh RPM包全路径名称:安装包到当前系统有提示信息
参数说明:i = install 安装
v = verbase 提示
h = hash 进度条
删除rpm包:rpm -e jdk
如果其它软件包依赖于您要卸载的软件包,卸载时则会产生错误的信息
如果忽略这个错误信息继续卸载,使用 --nodeps命令行选项
升级rpm包:
rpm -u RPM包全路径包