在linux服务器上搭建相对安全的FTP服务器
一、如何在Linux服务器上安装vsftp不在多说,直接介绍如何进行安全性配置;
二、编辑vsftp.conf文件
关键配置项如下:
anonymous_enable=NO /禁止匿名用户登录
local_enable=YES /允许本地用户登录
write_enable=YES /允许登陆后写
local_umask=022
xferlog_enable=YES /记录日志
xferlog_file=/var/log/xfer log /日志文件
userlist_enable=YES /限制userlist里面的本地用户不能访问,userlist里面可以把root等禁止ftp登录的本地账号写进去
所有配置项的注释可参考:
http://blog.csdn.net/chenhongqian/article/details/50462382
三、创建FTP账号
# useradd –d /home/myftp myftp
# passwd myftp
# usermod -s /sbin/nologin myftp //限定用户myftp不能本地登录
四、创建一个文件夹(scripts)只能下载,不能上传
# mkdir scripts /home/myftp
#chmod 555 scripts
五、创建一个文件夹(results)只能上传,不能下载和删除
这个有点难度,因为用户不能对自己上传的文件进行下载和删除,需要使用特殊的方法。
# mkdir results /home/myftp
#chmod 755 results
#chattr +i /home/results
六、配置SSL加密
1、通过rpm -qa | openssl 查看是否已安装openssl,未安装请先安装
2、新建目录,为了放置证书,有可能certs文件夹已经存在,但要确认已存在的文件夹是否仅是个链接。
- mkdir -p /etc/ssl/certs
- chmod 700 /etc/ssl/certs
3、执行生成证书的命令:
- openssl req -x509 -nodes -days 365 -newkey rsa:1024 -keyout /etc/ssl/certs/vsftpd.pem -out /etc/ssl/certs/vsftpd.pem
4、上述证书生成过程中需要填写信息,按提示添加国家、省份、邮箱等即可,可以随便填,信息后续用不到;
5、然后进到/etc/ssl/certs目录下看证书有没有生成
6、然后我们修改vsftpd的配置文件在最后添加如下信息
- # Turn on SSL
- ssl_enable=YES
- # Allow anonymous users to use secured SSL connections
- allow_anon_ssl=YES
- # All non-anonymous logins are forced to use a secure SSL connection in order to
- # send and receive data on data connections.
- force_local_data_ssl=YES
- force_anon_data_ssl=YES
- # All non-anonymous logins are forced to use a secure SSL connection in order to send the password.
- force_local_logins_ssl=YES
- force_anon_logins_ssl=YES
- # Permit TLS v1 protocol connections. TLS v1 connections are preferred
- ssl_tlsv1=YES
- # Permit SSL v2 protocol connections. TLS v1 connections are preferred
- ssl_sslv2=NO
- # permit SSL v3 protocol connections. TLS v1 connections are preferred
- ssl_sslv3=NO
- # Disable SSL session reuse (required by WinSCP)
- require_ssl_reuse=NO
- # Select which SSL ciphers vsftpd will allow for encrypted SSL connections (required by FileZilla)
- ssl_ciphers=HIGH
- # This option specifies the location of the RSA certificate to use for SSL
- # encrypted connections.
- rsa_cert_file=/etc/ssl/cert/vsftpd.pem
7、配置修改完成后,重新vsftpd服务。
备注:如服务启动失败,请确认证书存储的位置与下面填写的是否符合 sa_cert_file=/etc/ssl/cert/vsftpd.pem
8、登陆查看是否已加密
状态:
正在连接 172.20.100.XX:21...
状态: 连接建立,等待欢迎消息...
状态: 初始化 TLS 中...
状态: 正在验证证书...
状态: TLS 连接已建立。
状态: 已登录
状态: 读取目录列表...
备注:需要使用工具链接,如FileZilla等,直接通过浏览器可能无法正常登陆。
在linux服务器上搭建相对安全的FTP服务器的更多相关文章
- FTP服务器上传工具,FTP服务器上传工具下载!
IIS7服务器管理工具能够作为FTP的客户端,进行FTP的命令操作,可在客户端,下载,安装FTP软件! 同时,它也可以作为VNC的客户端,进行VNC的命令操作!它能够批量连接Windows和Linux ...
- asp.net 服务器 上传文件到 FTP服务器
private string ftpServerIP = "服务器ip";//服务器ip private string ftpUserID = "ftp的用户名" ...
- 【FastDFS】小伙伴们说在CentOS 8服务器上搭建FastDFS环境总报错?
写在前面 在[冰河技术]微信公众号的[分布式存储]专题中,我们分别搭建了单节点FastDFS环境和高可用FastDFS集群环境.但是,之前的环境都是基于CentOS 6.8服务器进行搭建的.很多小伙伴 ...
- 在CentOS 8服务器上搭建FastDFS环境
什么是FastDFS? 这里,我就摘录下百度百科上对于FastDFS的描述. FastDFS是一个开源的轻量级分布式文件系统,它对文件进行管理,功能包括:文件存储.文件同步.文件访问(文件上传.文件下 ...
- Linux下自动备份MySQL数据库并上传到远程FTP服务器
Linux下自动备份MySQL数据库并上传到远程FTP服务器且删除指定日期前的备份Shell脚本 说明: 1.备份MySQL数据库存放目录/var/lib/mysql下面的xshelldata数据库 ...
- Linux CentOS 6.5 下 vsftpd ftp服务器搭建
Linux CentOS 6.5 下 vsftpd ftp服务器搭建 by:授客 QQ:1033553122 操作系统环境:CentOS 6.5-x86_64 下载地址:http://www.ce ...
- 在Ubuntu14.04系统POWER8服务器上搭建Docker Registry服务
本文描述了如何在POWER8服务器上搭建一个本地化的Docker镜像仓库,主要涉及镜像制作,Docker Registry服务启动等.希望能够对在非X86服务器上搭建Docker仓库的同学提供参考. ...
- linux系统下搭建自己的web服务器
之前在windows 2008 server上搭建了一个用于测试的web服务器,但是在打开网站的时候特别的慢,尤其是图片的加载都会失败,当时以为是路径的问题,但是在服务器上自己打开都特别慢,自己实在找 ...
- 在阿里云上搭建自己的git服务器
这篇文章我就来介绍一下如何在一台全裸的阿里云主机上搭建自己的git服务器. 1. 安装git 首先安装git,一般而言,现在的服务器已经内置了git安装包,我们只需要执行简单的安装命令即可安装.比如: ...
随机推荐
- Bootstrap基础篇—常见的CSS类
一.标题 标签 大小 h1 36px h2 30px h3 24px h4 18px h5 14px h6 12px 二.常见的内联样式 标签 用途 del 删除的文本 s 无用的文本 ins 插入的 ...
- 使用 adb 命令一次性为多个设备安装 apk
使用 adb 命令一次性为多个设备安装 apk 原创 2016年07月15日 10:40:53 3154 命令简介 adb install [-lrtsdg] (file) 把包文件推送到设备上并安装 ...
- thinkphp5使用workerman的定时器定时任务在某一个时间执行
1.首先通过 composer 安装workerman,在thinkphp5完全开发手册的扩展->coposer包->workerman有详细说明: #在项目根目录执行以下指令compos ...
- Qt-QSplashScreen-程序启动动画
多数大型应用程序启动时可会在程序完全启动前显示一个启动画面,在程序完全启动后消失,程序启动画面可以显示相关产品的一些信息,使用户在等待程序启动时同时了解产品的相关功能,这也是一种宣传方式. 首先运行界 ...
- 怎样用Eclipse将Java源代码生成可执行文件[转]
eclipse将java源代码生成jar可执行文件 用eclipse做了一个web项目的自动化测试,自己用的时候倒是很方便,打开eclipse直接运行即可,但是分享给其他小伙伴用的时候就不太方便,希望 ...
- Selenium基础之--01(将浏览器最大化,设置浏览器固定宽、高,操控浏览器前进、后退)
1,将浏览器最大化 我们知道调用启动的浏览器不是全屏的,这样不会影响脚本的执行,但是有时候会影响我们"观看"脚本的执行. coding=utf-8 from selenium im ...
- 【转】: 探索Lua5.2内部实现:虚拟机指令(1) 概述
Lua一直把虚拟机执行代码的效率作为一个非常重要的设计目标.而采用什么样的指令系统的对于虚拟机的执行效率来说至关重要. Stack based vs Register based VM 根据指令获取操 ...
- HTML 之 表单
关于HTML的表单 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset=&q ...
- Python版本切换和Pip安装
Python版本切换 现在常用的linux系统中都会默认携带python运行环境,在ubuntu 16.04 和centos 7.3中携带有Python 2.7 和Python3.5两个版本, 默认使 ...
- C语言struct中的长度可变数组(Flexible array member)
C_struct中的长度可变数组(Flexible array member) Flexible array member is a feature introduced in the C99 sta ...