还剩12页未读,继续阅读
本资源只提供10页预览,全部文档请下载后查看!喜欢就下载吧,查找使用更方便
文本内容:
网康培训文档可以阅读此文档的人员文档__lujizhou30011/netentsec创建时间2008/02/24培训对象6-知识拓展培训培训分类9-Linux技术文档主题--2-Linux菜鸟必须知道的命令文档正文相关附件使用Linux系统构建网站案例--|回首页|2005年索引|--Linux系统菜鸟入门学习系列之系统FAQ必学的Linux系统安全命令--Tag linux虽然Linux和WindowsNT/2000系统一样是一个多用户的系统,但是它们之间有不少重要的差别对于很多习惯了Windows系统的管理员来讲,如何保证Linux操作系统安全、可靠将会面临许多新的挑战本文将重点介绍Linux系统安全的命令passwd
1.作用passwd命令原来修改账户的登陆密码,使用权限是所有用户
2.格式passwd[选项]账户名称
3.主要参数-l锁定已经命名的账户名称,只有具备超级用户权限的使用者方可使用-u解开账户锁定状态,只有具备超级用户权限的使用者方可使用-x--maximum=DAYS最大密码使用时间(天),只有具备超级用户权限的使用者方可使用-n--minimum=DAYS最小密码使用时间(天),只有具备超级用户权限的使用者方可使用-d删除使用者的密码只有具备超级用户权限的使用者方可使用-S检查指定使用者的密码认证种类只有具备超级用户权限的使用者方可使用
4.应用实例$passwdChangingpasswordforusercao.ChangingpasswordforcaocurrentUNIXpassword:NewUNIXpassword:RetypenewUNIXpassword:passwd:allauthenticationtokensupdatedsuccessfully.从上面可以看到,使用passwd命令需要输入旧的密码,然后再输入两次新密码su
1.作用u的作用是变更为其它使用者的身份,超级用户除外,需要键入该使用者的密码
2.格式u[选项]...[-][USER[ARG]...]
3.主要参数-f,--fast不必读启动文件(如csh.cshrc等),仅用于csh或tcsh两种Shell-l,--login加了这个参数之后,就好像是重新登陆为该使用者一样,大部分环境变量(例如HOME、SHELL和USER等)都是以该使用者(USER)为主,并且工作目录也会改变如果没有指定USER,缺省情况是root-m,-p,--preserve-environment执行su时不改变环境变数-ccommand变更账号为USER的使用者,并执行指令(command)后再变回原来使用者USER欲变更的使用者账号,ARG传入新的Shell参数
4.应用实例变更账号为超级用户,并在执行df命令后还原使用者su-cdfrootumask
1.作用umask设置用户文件和目录的文件创建缺省屏蔽值,若将此命令放入profile文件,就可控制该用户后续所建文件的存取许可它告诉系统在创建文件时不给谁存取许可使用权限是所有用户
2.格式umask[-p][-S][mode]
3.参数-S确定当前的umask设置-p修改umask设置[mode]修改数值
4.说明传统Unix的umask值是022,这样就可以防止同属于该组的其它用户及别的组的用户修改该用户的文件既然每个用户都拥有并属于一个自己的私有组,那么这种“组保护模式”就不在需要了严密的权限设定构成了Linux安全的基础,在权限上犯错误是致命的需要注意的是,umask命令用来设置进程所创建的文件的读写权限,最保险的值是0077,即关闭创建文件的进程以外的所有进程的读写权限,表示为-rw-------在~/.bash_profile中,加上一行命令umask0077可以保证每次启动Shell后进程的umask权限都可以被正确设定
5.应用实例umask-Su=rwxg=rxo=rxumask-p177umask-Su=rwg=o=BR上述5行命令,首先显示当前状态,然后把umask值改为177,结果只有文件所有者具有读写文件的权限,其它用户不能访问该文件这显然是一种非常安全的设置chgrp
1.作用chgrp表示修改一个或多个文件或目录所属的组使用权限是超级用户
2.格式chgrp[选项]...组文件...或chgrp[选项]...--reference=参考文件文件...将每个文件的所属组设定为组
3.参数-c--changes像--verbose,但只在有更改时才显示结果--dereference会影响符号链接所指示的对象,而非符号链接本身-h--no-dereference会影响符号链接本身,而非符号链接所指示的目的地当系统支持更改符号链接的所有者,此选项才有效-f--silent--quiet去除大部分的错误信息--reference=参考文件使用参考文件的所属组,而非指定的组-R--recursive递归处理所有的文件及子目录-v--verbose处理任何文件都会显示信息
4.应用说明该命令改变指定指定文件所属的用户组其中group可以是用户组ID,也可以是/etc/group文件中用户组的组名文件名是以空格分开的要改变属组的文件列表,支持通配符如果用户不是该文件的属主或超级用户,则不能改变该文件的组
5.应用实例改变/opt/local/book/及其子目录下的所有文件的属组为book,命令如下$chgrp-Rbook/opt/local/bookchmod
1.作用chmod命令是非常重要的,用于改变文件或目录的访问权限,用户可以用它控制文件或目录的访问权限,使用权限是超级用户
2.格式chmod命令有两种用法一种是包含字母和操作符表达式的字符设定法(相对权限设定);另一种是包含数字的数字设定法(绝对权限设定)
(1)字符设定法chmod[who][+|-|=][mode]文件名◆操作对象who可以是下述字母中的任一个或它们的组合u表示用户,即文件或目录的所有者g表示同组用户,即与文件属主有相同组ID的所有用户o表示其它用户a表示所有用户,它是系统默认值◆操作符号+添加某个权限-取消某个权限=赋予给定权限,并取消其它所有权限(如果有的话)◆设置mode的权限可用下述字母的任意组合r可读w可写x可执行X只有目标文件对某些用户是可执行的或该目标文件是目录时才追加x属性文件执行时把进程的属主或组ID置为该文件的文件属主方式“u+s”设置文件的用户ID位,“g+s”设置组ID位t保存程序的文本到交换设备上u与文件属主拥有一样的权限g与和文件属主同组的用户拥有一样的权限o与其它用户拥有一样的权限文件名以空格分开的要改变权限的文件列表,支持通配符一个命令行中可以给出多个权限方式,其间用逗号隔开
(2)数字设定法数字设定法的一般形式为chmod[mode]文件名数字属性的格式应为3个0到7的八进制数,其顺序是ugo文件名,以空格分开的要改变权限的文件列表,支持通配符数字表示的权限的含义如下0001为所有者的执行权限;0002为所有者的写权限;0004为所有者的读权限;0010为组的执行权限;0020为组的写权限;0040为组的读权限;0100为其他人的执行权限;0200为其他人的写权限;0400为其他人的读权限;1000为粘贴位置位;2000表示假如这个文件是可执行文件,则为组ID为位置位,否则其中文件锁定位置位;4000表示假如这个文件是可执行文件,则为用户ID为位置位
3.实例如果一个系统管理员写了一个表格tem让所有用户填写,那么必须授权用户对这个文件有读写权限,可以使用命令#chmod666tem上面代码中,这个666数字是如何计算出来的呢?0002为所有者的写权限,0004为所有者的读权限,0020为组的写权限,0040为组的读权限,0200为其他人的写权限,0400为其他人的读权限,这6个数字相加就是666(注以上数字都是八进制数),结果见图1所示图1用chmod数字方法设定文件权限从图1可以看出,tem文件的权限是-rw-rw-rw-,即用户对这个文件有读写权限如果用字符权限设定使用下面命令#chmoda=wxtemchown
1.作用更改一个或多个文件或目录的属主和属组使用权限是超级用户
2.格式chown[选项]用户或组文件
3.主要参数--dereference受影响的是符号链接所指示的对象,而非符号链接本身-h--no-dereference会影响符号链接本身,而非符号链接所指示的目的地当系统支持更改符号链接的所有者,此选项才有效--from=目前所有者:目前组只当每个文件的所有者和组符合选项所指定的,才会更改所有者和组其中一个可以省略,这已省略的属性就不需要符合原有的属性-f--silent--quiet去除大部分的错误信息-R--recursive递归处理所有的文件及子目录-v--verbose处理任何文件都会显示信息
4.说明chown将指定文件的拥有者改为指定的用户或组,用户可以是用户名或用户ID;组可以是组名或组ID;文件是以空格分开的要改变权限的文件列表,支持通配符系统管理员经常使用chown命令,在将文件拷贝到另一个用户的目录下以后,让用户拥有使用该文件的权限
5.应用实例
1.把文件shiyan.c的所有者改为wan$chownwanshiyan.c
2.把目录/hi及其下的所有文件和子目录的属主改成wan,属组改成users$chown-Rwan.users/hichattr
1.作用修改ext2和ext3文件系统属性attribute,使用权限超级用户
2.格式chattr[-RV][-+=AacDdijsSu][-vversion]文件或目录
3.主要参数-R递归处理所有的文件及子目录-V详细显示修改内容,并打印输出-失效属性+激活属性=指定属性A Atime,告诉系统不要修改对这个文件的最后访问时间S Sync,一旦应用程序对这个文件执行了写操作,使系统立刻把修改的结果写到磁盘a AppendOnly,系统只允许在这个文件之后追加数据,不允许任何进程覆盖或截断这个文件如果目录具有这个属性,系统将只允许在这个目录下建立和修改文件,而不允许删除任何文件i Immutable,系统不允许对这个文件进行任何的修改如果目录具有这个属性,那么任何的进程只能修改目录之下的文件,不允许建立和删除文件D检查压缩文件中的错误d Nodump,在进行文件系统备份时,dump程序将忽略这个文件C Compress,系统以透明的方式压缩这个文件从这个文件读取时,返回的是解压之后的数据;而向这个文件中写入数据时,数据首先被压缩之后才写入磁盘SecureDelete,让系统在删除这个文件时,使用0填充文件所在的区域u Undelete,当一个应用程序请求删除这个文件,系统会保留其数据块以便以后能够恢复删除这个文件
4.说明chattr命令的作用很大,其中一些功能是由Linux内核版本来支持的,如果Linux内核版本低于
2.2,那么许多功能不能实现同样-D检查压缩文件中的错误的功能,需要
2.
5.19以上内核才能支持另外,通过chattr命令修改属性能够提高系统的安全性,但是它并不适合所有的目录chattr命令不能保护/、/dev、/tmp、/var目录
5.应用实例
1.恢复/root目录即子目录的所有文件#chattr-R+u/root
2.用chattr命令防止系统中某个关键文件被修改在Linux下,有些配置文件passwdfatab是不允许任何人修改的,为了防止被误删除或修改,可以设定该文件的“不可修改位immutable”,命令如下#chattr+i/etc/fstabsudo
1.作用udo是一种以限制配置文件中的命令为基础,在有限时间内给用户使用,并且记录到日志中的命令,权限是所有用户
2.格式sudo[-bhHpV][-sshell][-u用户][指令]sudo[-klv]
3.主要参数-b在后台执行命令-h显示帮助-H将HOME环境变量设为新身份的HOME环境变量-k结束密码的有效期,即下次将需要输入密码-l列出当前用户可以使用的命令-p改变询问密码的提示符号-sshell执行指定的Shell-u用户以指定的用户为新身份,不使用时默认为root-v延长密码有效期5分钟
4.说明udo命令的配置在/etc/sudoers文件中当用户使用sudo时,需要输入口令以验证使用者身份随后的一段时间内可以使用定义好的命令,当使用配置文件中没有的命令时,将会有报警的记录sudo是系统管理员用来允许某些用户以root身份运行部分/全部系统命令的程序一个明显的用途是增强了站点的安全性,如果需要每天以超级用户的身份做一些日常工作,经常执行一些固定的几个只有超级用户身份才能执行的命令,那么用sudo是非常适合的ps
1.作用显示瞬间进程process的动态,使用权限是所有使用者
2.格式[options][--help]
3.主要参数的参数非常多此出仅列出几个常用的参数-A列出所有的进程-l显示长列表-m显示内存信息-w显示加宽可以显示较多的信息-e显示所有进程a显示终端上的所有进程包括其它用户的进程-au显示较详细的信息-aux显示所有包含其它使用者的进程
4.说明要对进程进行监测和控制,首先要了解当前进程的情况,也就是需要查看当前进程ps命令就是最基本、也是非常强大的进程查看命令使用该命令可以确定有哪些进程正在运行、运行的状态、进程是否结束、进程有没有僵尸、哪些进程占用了过多的资源等图2给出了ps-aux命令详解大部分信息都可以通过执行该命令得到最常用的三个参数是u、a、x下面就结合这三个参数详细说明ps命令的作用psaux图2ps-aux命令详解图2第2行代码中,USER表示进程拥有者;PID表示进程标示符;%CPU表示占用的CPU使用率;%MEM占用的物理内存使用率;VSZ表示占用的虚拟内存大小;RSS为进程占用的物理内存值;TTY为终端的次要装置号码STAT表示进程的状态,其中D为不可中断的静止(I/O动作);R正在执行中;S静止状态;T暂停执行;Z不存在,但暂时无法消除;W没有足够的内存分页可分配;高优先序的进程;N低优先序的进程;L有内存分页分配并锁在内存体内实时系统或I/OSTART为进程开始时间TIME为执行的时间COMMAND是所执行的指令
4.应用实例在进行系统维护时,经常会出现内存使用量惊人,而又不知道是哪一个进程占用了大量进程的情况除了可以使用top命令查看内存使用情况之外,还可以使用下面的命令aux|sort+5nwho
1.作用who显示系统中有哪些用户登陆系统,显示的资料包含了使用者ID、使用的登陆终端、上线时间、呆滞时间、CPU占用,以及做了些什么使用权限为所有用户
2.格式who-[husfV][user]
3.主要参数-h不要显示标题列-u不要显示使用者的动作/工作-s使用简短的格式来显示-f不要显示使用者的上线位置-V显示程序版本
4.说明该命令主要用于查看当前在线上的用户情况如果用户想和其它用户建立即时通信,比如使用talk命令,那么首先要确定的就是该用户确实在线上不然talk进程就无法建立起来又如,系统管理员希望监视每个登录的用户此时此刻的所作所为,也要使用who命令who命令应用起来非常简单,可以比较准确地掌握用户的情况所以使用非常广泛动手练习
1.使用Linux命令检测系统入侵者安装过MandrakeLinux和RedHatLinux的用户都会知道,Linux系统会内置三种不同级别(标准、高、更高)的防火墙,当进行了Linux服务器的安装和一些基本的设置后,服务器应该说是比较安全的,但是也会有黑客通过各种方法利用系统管理员的疏忽侵入系统如何快速查找黑客非常重要一般来说,可以使用命令查询黑客是否入侵,见表1表1查询黑客入侵现象的命令对应表举例说明,如果黑客嗅探网络,那么它必须使网卡接口处于混杂模式,使用下面命令进行查询#ifconfig-aeth0Linkencap:EthernetHWaddr00:00:E8:A0:25:86inetaddr:
192.
168.
1.7Bcast:
192.
168.
1.255Mask:
255.
255.
255.0UPBROADCASTRUNNINGPROMISCUOUSMTU:1500Metric:
1......从这个命令的输出中,可以看到上面讲到的这些概念第一行的00:00:E8:A0:25:86是mac地址,第二行的
192.
168.
1.7是IP地址,第四行讲的是接收数据状态,这时正在被黑客嗅探一般而言,网卡有几种接收数据帧的状态,如Broadcast、Multicast、Promiscuous等Broadcast是指接收所有类型为广播报文的数据帧;Multicast是指接收特定的组播报文;Promiscuous则是通常说的混杂模式,是指对报文中的目的硬件地址不加任何检查、全部接收的工作模式
2.限制su命令的滥用我们知道,超级用户在Linux中有最大的权利,几乎所有黑客都想得到这个目标Linux可以增加对切换到超级用户的限制使用PAM(PluggableAuthenticationModules)可以禁止除在wheel组以外的任何人su成root,修改/etc/pam.d/su文件,除去屏蔽标识#使用/usr/sbin/usermodG10bjecadm将bjecadm这个账号加入gid为10的组,就是wheel组命令如下/etc/pam.d/su#使用密码验证#authsufficient/lib/security/pam_wheel.sodebug#限制只有wheel组用户才可以切换到root#authrequired/lib/security/pam_wheel.souse_uidchmod-G10bjecadm另外,每当用户试图使用su命令进入系统用户时命令将在/usr/adm/sulog文件中写一条信息若该文件记录了大量试图用su进入root的无效操作信息则表明了可能有人企图破译root口令Linux命令有着强大的功能对于Linux系统管理员来说,往往只需要通过各种安全命令技巧,组合构成安全防线从计算机安全的角度看,世界上没有绝对安全的计算机系统,Linux系统也不例外。