zoukankan      html  css  js  c++  java
  • CentOS 6.5部署HTTP WEB服务器和FTP服务器

    转载自:http://www.server110.com/linux/201403/8613.html

    [题记]本文使用CentOS 6.5 minimal快速搭建HTTP服务器和仅供授权用户登陆的FTP服务器。意在使用授权FTP用户通过登陆指定的服务器文件夹来上传、下载、修改、更新、删除位于/var/www/html目录内的网站文件。同时又保持SeLinux和iptables防火墙的工作状态,使其得以安全有效的运行。

    CentOS-6.5快速搭建HTTP服务器和仅供授权用户登陆的FTP服务器

    第一步 启动CentOS 6.5
    假设你已经安装好了CentOS,虚拟机中或实体服务器。

    CentOS-6.5快速搭建HTTP服务器和仅供授权用户登陆的FTP服务器

    第二步 登陆系统
    # yum install httpd vsftpd mysql mysql-server php php-mysql
    为了自己能掌握,所以采取了默认输入y确认安装的方法。

    CentOS-6.5快速搭建HTTP服务器和仅供授权用户登陆的FTP服务器

    第三步 确认安装列表
    # y
    回车确认

    CentOS-6.5快速搭建HTTP服务器和仅供授权用户登陆的FTP服务器

    第四步 设置开机启动
    # chkconfig httpd on
    配置HTTP服务开机启动。
    # chkconfig vsftpd on
    配置FTP服务开机启动。
    # chkconfig mysqld on
    配置MySQL服务开机启动。

    CentOS-6.5快速搭建HTTP服务器和仅供授权用户登陆的FTP服务器

    第五步 检查服务配置状态
    # chkconfig
    2、3、4、5启动。

    CentOS-6.5快速搭建HTTP服务器和仅供授权用户登陆的FTP服务器

    第六步 启动服务
    # service httpd start
    启动HTTP服务。
    # service vsftpd start
    启动FTP服务。
    # service mysqld start
    启动MySQL服务。

    CentOS-6.5快速搭建HTTP服务器和仅供授权用户登陆的FTP服务器

    ===================以上是配置WEB服务器========现在已经可以用公网IP访问服务器了==================

    Apache配置文件位置:/etc/httpd/conf/httpd.conf

    PHP.ini的位置:/etc/php.ini

    第七步 配置FTP用户、用户组及相应权限
    # groupadd webftp
    添加webftp用户组,用来承载我们的FTP授权用户。
    # useradd -g webftp -M -d /var/www -s /sbin/nologin wwwer
    使用-g参数将它归集到webftp用户组下,-M参数不设置它的主目录(没有-M参数/home里会有个wwwer文件夹,这个文件夹没多少实际用处,所以不用设置),-d参数设定它的初始登入目录为/var/www,-s参数设定它不需要登陆系统/sbin/nologin,它被命名为wwwer(之所以这样命名,也就是根据初始登入目录来设置的,下同,登陆到www目录有一个好处是它可以直接FTP进去修改诸如404一类的页面,而不用其他过程来配置)。
    # useradd -g webftp -M -d /var/www/html -s /sbin/nologin htmler
    同样的方法在webftp用户组继续添加用户htmler,它也不设置主目录,也不需要登陆系统,设定它的初始登入目录为/var/www/html。
    # passwd wwwer
    为wwwer添加密码,两次输入。
    # passwd htmler
    为htmler添加密码,两次输入。
    # chown -R wwwer.webftp /var/www
    更改/var/www目录及其下所有文件和文件夹(-R)的所有者为webftp用户组下的wwwer用户。
    # chown -R htmler.webftp /var/www/html
    同样将/var/www/html目录及其下所有文件和文件夹chown给html。

    CentOS-6.5快速搭建HTTP服务器和仅供授权用户登陆的FTP服务器

    第八步 不启用匿名用户
    # vi /etc/vsftpd/vsftpd.conf
    按I键进入编辑模式,找到anonymous_enable=YES,更改YES为NO,然后按ESC键退出编辑,输入“:wq”存盘并退出。

    CentOS-6.5快速搭建HTTP服务器和仅供授权用户登陆的FTP服务器

    第九步 配置基本安全策略
    # getsebool -a | grep ftp
    列出所有selinux全部ftp策略。
    #setsebool allow_ftpd_full_access on
    允许FTP完全访问。
    # iptables -I INPUT -p tcp --dport 80 -j ACCEPT
    插入防火墙规则(CentOS里用-A添加一条规则会处于链表尾,但表尾貌似不起作用,所以用-I插入到链表头),这条规则的意思是所有INPUT到服务器的包,-p如果是tcp协议的,--dport目标端口是80端口的,-j那么就ACCEPT。
    # iptables -I INPUT -p tcp --dport 21 -j ACCEPT
    同样的方法接受所有要到达服务器21端口的tcp包。
    # modprobe ip_conntrack_ftp
    载入IP连线跟踪模块。记住最后这一步(第九步)的基本安全策略配置在重启后全部失效,你需要重新配置一遍,当然通过修改selinux和iptables的配置文件或service iptables save是可以保持这些策略的。但你应该清晰的认识到一个问题:一个服务器应该总是保持开启状态的,如果服务器重启了,那么只有两种可能,一种是在你的控制之下,一种不在你的控制之下,当服务器重启事件不在你的控制之下时,那么你应该认识到这是很危险的情况,那么刚才那些“放行”的策略应该完全失效而不是继续保持才对。也正因为如此,我想这可能是CentOS这样做的其中一个原因。如果你要添加的规则比较多可以先保存到一个txt文件里,直接cp过来就okay。

    CentOS-6.5快速搭建HTTP服务器和仅供授权用户登陆的FTP服务器效果测试
    HTTP、FTP测试均已成功,而且我们添加的wwwer和htmler也拥有了对这些文件的有效权限。如果你的网站程序需要某些777的权限,你也可以直接通过FTP修改的。

  • 相关阅读:
    js关于页面坐标api
    js面向对象之创建对象
    Web前端安全问题
    js操作cookie
    css清除浮动
    块级格式化上下文(block formatting context)
    《python核心编程》笔记——系统限制
    《python核心编程》笔记——文件的创建、读取和显示
    黑客们的故事连载十二 “蠕虫来袭”:莫里斯
    黑客们的故事连载十一 下村努—虚拟战争追逐
  • 原文地址:https://www.cnblogs.com/itlqs/p/5861743.html
Copyright © 2011-2022 走看看