第十讲linux网络服务_第1页
第十讲linux网络服务_第2页
第十讲linux网络服务_第3页
第十讲linux网络服务_第4页
第十讲linux网络服务_第5页
已阅读5页,还剩33页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

.,第十讲,网络安全管理,Linux专题讲座,.,主要内容,了解Linux网络安全管理的基本原理掌握使用TCPWrappers管理网络服务掌握SSH服务器的配置和管理掌握SSH客户端工具的使用方法,.,TCPWrappers的基本概念,TCPWrappers的功能TCPWrappers是大多数Linux发行版本中都默认提供的功能TCPWrappers的主要执行文件是“tcpd”tcpd程序可以将其他的网络服务程序“包裹”起来,从而进行集中的访问控制设置RHEL4系统中缺省安装了TCPWrappers#rpm-qtcp_wrapperstcp_wrappers-7.6-37.2,.,TCPWrappers的设置文件,TCPWrappers使用两个设置文件“hosts.allow”和“hosts.deny”两个文件的用于保存TCPWrappers基于主机地址的访问控制策略#ls/etc/hosts.*/etc/hosts.allow/etc/hosts.deny“hosts.allow”文件用于保存允许访问的策略“hosts.deny”文件用于保存拒绝访问的策略“hosts.allow”和“hosts.deny”文件中保存的设置是即时生效的,.,TCPWrappers的工作原理,tcpd,.,TCPWrappers的工作原理,xinetd,服务器守护进程,传统方式,客户端,xinetd方式,停止服务器守护进程,注册服务器到xinetd服务,启动xinetd服务监听所有已注册的服务器的端口,xinetd接收到对某个端口的连接请求,xinetd启动注册的服务器程序,接受和处理这个连接,xinetd服务器继续监听其它连接请求,.,TCPWrappers的配置方法,语法daemon_list:client_list:shell_command访问控制列表的访问,tcpd,hosts.allow,接受访问,hosts.deny,接受访问,拒绝访问,有匹配项,有匹配项,无匹配项,无匹配项,.,TCPWrappers的配置方法,设置文件的格式“hosts.allow”和“hosts.deny”文件中具有相同格式的配置记录:动作文件中每行为一个设置记录“服务程序列表”字段的表示ALL代表所有的服务程序单个服务的名称,例如in.telnetd代表telnet服务器程序,vsftpd代表vsftpd服务器程序多个服务程序名称可以组成列表,中间用逗号分隔,例如“in.telnetd,vsftpd”,.,TCPWrappers的配置方法,“客户机地址列表”字段的表示ALL代表所有的客户机地址LOCAL代表本机地址KNOW代表可解析的域名UNKNOW代表不可解析的域名以句点“.”开始的域名代表该域下的所有主机,例如“”代表“”域中的所有主机对某个子网中的所有主机使用“子网/掩码”的形式表示对于网络中的某个主机可直接使用IP地址表示“动作”字段使用“allow”表示允许,使用“deny”表示拒绝,.,TCPWrappers配置实例,配置要求使用TCPWrappers对vsftpd服务和telnet服务进行基于主机的访问控制vsftpd服务器和telnet服务器所在主机的地址为“”对于vsftpd服务只允许IP地址为“00”至“99”的主机进行访问由于telnet服务相对不是很安全,因此只允许IP地址为“22”的客户机访问,.,安装并启动telnet服务,telnet服务器的安装RHEL5系统中默认不安装telnet服务器telnet-server软件包在第3张安装光盘,需要手工进行安装#rpm-ivhtelnet-server-0.17-38.el5.i386.rpmtelnet服务由xinetd调度启动telnet在xinetd服务中的启动配置文件/etc/xinetd.d/telnettelnet服务默认不启动,需手工设置#chkconfigtelneton#servicexinetdrestart,.,测试telnet服务器,使用telnet命令登录telnet服务器telnet命令是telnet服务的客户端程序#telnet用户telnet登录的过程中会提示输入用户名和用户口令telnet服务的安全性telnet服务使用明文传输所有的内容(包括用户登录口令),因此存在安全隐患应尽量使用SSH服务替代telnet服务,.,将vsftp改为由xinetd服务启动,将/usr/share/doc/vsftpd-2.0.5/vsftpd.xinetd文件复制到/etc/xinetd.d目录下,并改名为ftp#cp/usr/share/doc/vsftpd-2.0.5/vsftpd.xinetd/etc/xinetd.d/ftp将vsftpd服务的主配置文件vsftpd.conf中的listen=YES改为listen=NO或用#注释掉关闭独立启动的vsftpd服务,并启动非独立启动的vsftpd服务#servicevsftpdstop#chkconfigftpon#servicexinetdrestart,.,TCPWrappers配置实例,TCPWrappers策略配置hosts.deny文件in.telnetd,vsftpd:ALLhosts.allow文件in.telnetd:22vsftpd:?采取先“全部禁止”再“逐个开放”的策略设置方法,可以较好的实现“只允许”的访问策略,.,TCPWrappers配置实例,EXCEPT关键字的使用EXCEPT用于排除指定项in.telnetd,vsftpd:192.168.1.EXCEPT0ALLEXCEPTvsftpd:00运行shell命令vsftpd:ALL:spawn(/bin/echo%h-%d-%u/var/log/tcpwrap.log)&,.,SSH的起源与工作原理,SSH(SecureSHell),实现了与Telnet服务类似的远程登录功能SSH协议在网络中使用密文传输数据SSH服务器中还支持使用scp、rsync和sftp等客户端程序进行远程主机的文件复制,.,SSH的认证方式,SSH协议提供两种用户认证方式基于口令的安全认证与telnet类似,提供正确的用户口令后可以登录远程服务器基于密钥的安全认证使用公钥和私钥对的方式对用户进行认证,.,SSH密钥的认证原理,SSH服务中使用密钥进行用户认证,每个用户都需要生成自己的公钥和私钥对文件,用户的公钥文件需要保存在SSH服务器主机中,用户私钥文件保存在SSH客户端主机中,.,OpenSSH服务器的特点,OpenSSH是著名的开源软件项目OpenSSH是SSH协议的免费实现版本OpenSSH可应用于大多数UNIX系统绝大多数Linux发行版本都采用OpenSSH作为SSH服务器,.,OpenSSH软件包的组成,RHEL5系统中OpenSSH服务器和客户端软件是默认安装的openssh软件包是实现ssh功能的公共软件包openssh-server软件包实现了SSH服务器的功能openssh-clients软件包中包含了SSH服务的客户端程序openssh-askpass和openssh-askpass-gnome只有在Linux的图形界面下使用SSH服务时才需要,.,OpenSSH服务器的启动和停止,OpenSSH的服务程序名称是sshdsshd服务程序的启动脚本/etc/init.d/sshdsshd服务程序缺省状态为自动启动sshd服务的启动与停止启动服务程序servicesshdstart停止服务程序servicesshdstop,.,OpenSSH服务的配置文件,配置目录OpenSSH服务器和客户机的所有配置文件都保存在同一目录中/etc/ssh/服务器配置文件SSH服务器的配置文件是sshd_config/etc/ssh/sshd_config客户机配置文件SSH客户程序的配置文件是ssh_config/etc/ssh/ssh_config,.,OpenSSH服务的配置文件,服务器端的主要配置项Port设置sshd监听的端口号ListenAddress设置sshd服务器绑定的IP地址HostKey设置包含计算机私人密匙的文件ServerKeyBits定义服务器密匙的位数PermitRootLogin设置root能不能用ssh登录PermitEmptyPasswords设置是否允许用口令为空的帐号登录AllowUsers设置允许登录的用户,后面可以跟着任意的数量的用户名的匹配串(patterns)或serhost这样的匹配串,这些字符串用空格隔开。主机名可以是DNS名或IP地址,.,OpenSSH的用户登录,使用ssh命令登录SSH服务器#sshroot首次登录SSH服务器为了建立加密的SSH连接需要用户在客户端确认服务器发来的RSA密钥(输入yes)用户认证每次登录SSH服务器都需要输入正确的用户口令SSH登录使用的是SSH服务器主机中的用户帐号,.,SSH的用户目录,“.ssh”目录在SSH客户主机的用户宿主目录中,使用名为“.ssh”的目录保存用户的SSH客户端信息/.ssh/“.ssh”目录在用户首次进行SSH登录后自动建立“known_hosts”文件“known_hosts”文件位于“.ssh”目录中“known_hosts”文件用于保存当前用户所有登录过的SSH服务器的RSA密钥,.,基于密钥SSH用户认证,设置密钥认证的一般步骤在SSH客户端生成用户的公钥和私钥对文件将SSH客户的公钥添加到SSH服务器中用户的认证文件中验证密钥的认证,.,基于密钥SSH用户认证,在SSH客户端生成用户的公钥和私钥对使用ssh-keygen命令生成密钥对$ssh-keygen-trsa公钥和私钥文件ssh-keygen命令将在“.ssh”目录中生成公钥和私钥文件id_rsa是私钥文件,内容需要严格保密id_rsa.pub是公钥文件,可发布到SSH服务器中,.,基于密钥SSH用户认证,复制公钥文件将客户端中的用户公钥文件复制到SSH服务器中公钥文件的复制可使用软盘、U盘或网络将公钥内容追加到authorized_keys文件authorized_keys文件保存在SSH服务器中用户目录的“.ssh”子目录中authorized_keys用于保存所有允许以当前用户身份登录的SSH客户端用户的公钥内容使用“”重定向符将用户公钥追加到authorized_keys文件中catid_rsa.pub/.ssh/authorized_keys,.,基于密钥SSH用户认证,基于密钥的用户认证过程用户使用ssh命令登录SSH服务器时,将使用客户机中的私钥与服务器中的公钥进行认证,认证成功后将允许用户登录密钥的认证过程是ssh命令与SSH服务器自动完成的用户登录过程中将不再提示输入用户口令,.,禁止root用户登录ssh服务器,为了提高Linux服务器的安全性,可以禁止root用户进行SSH登录设置sshd_config文件#vi/etc/ssh/sshd_config/添加设置行PermitRootLoginno重新启动sshd服务程序#servicesshdrestart再次登录SSH服务器时将不能使用root帐号进行登录,.,SSH命令的基本使用,ssh命令的两种格式格式1:sshusernamesshserver格式2:ssh-lusernamesshserver两种命令格式具有相同的功能ssh命令中需指定登录的用户名和SSH服务器地址不指定用户名的ssh命令ssh命令中如果不指定用户名,将使用SSH客户机中当前用户的名字登录SSH服务器#ssh,.,运行SSH服务器中的窗口程序,运行服务器中的图形程序是SSH的重要应用ssh命令需要在图形界面虚拟终端下运行命令格式:ssh-Xusernamesshserver,xlock是运行在SSH服务器中,而显示在SSH客户机中的窗口程序,.,sftp的使用,SSH服务器对sftp的支持sftp是SSH服务器中的子系统在SSH服务器中需要存在对sftp的配置#grepsftp/etc/ssh/sshd_configSubsystemsftp/usr/libexec/openssh/sftp-serversftp命令的使用sftp登录命令的格式与ssh命令类似:sftpusernamesshserversftp命令实现了类似ftp命令的功能和命令交互界面,.,scp命令的使用,scp命令可以实现SSH服务器与客户机之间的文件复制scp命令的格式类似于cp命令SSH服务器可以作为scp命令中的源文件或目标文件命令实例将SSH服务器中的文件复制到客户机#scproot192.16

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论