阿里云 ubuntu16.04 下 ftp 的快速应用(包罗疑难问题解决方案)

本文主要是介绍阿里云 ubuntu16.04 下 ftp 的快速应用(包罗疑难问题解决方案),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

安装 ftp

1.在线安装 vsftpd

apt-get install vsftpd

2.ftp的配置文件在

/etc/vsftpd.conf

3.ftp命令 启动 停止 重启

service vsftpd start
service vsftpd stop
service vsftpd restart
配置 ftp 用户

1、环境:
ftp为vsftp。被限制用户名为 ftpuser。被限制路径为/var/www

2、建用户:在 root 用户下:

增加用户 ftpuser,并制定 ftpuser 用户的主目录为 /var/www

useradd -d /var/www -s /sbin/nologin ftpuser -m

为ftpuser设置密码

passwd ftpuser

3、(可跳过) 更改用户相应的权限设置(可选) :

//限定用户 ftpuser 不能telnet,只能ftp
usermod -s /sbin/nologin ftpuser 
//用户test恢复正常
usermod -s /sbin/bash ftpuser 
//更改用户test的主目录为/test
usermod -d /ftp ftpuser 

4.限制用户只能访问/home/ftp,不能访问其他路径
修改/etc/vsftpd.conf如下:

指定用户只能访问自己的根目录以下

chroot_list_enable=YES //限制访问自身目录
# (default follows)
chroot_list_file=/etc/vsftpd.chroot_list// 具体用户在 vsftpd.chroot_list 里面配置
// 一行一个用户名即可

所有用户只能访问自己的根目录以下

chroot_local_user=YES

假如我想有个别用户可以访问上级可以使用以上两个进行联合配置

// 当两者都设置为YES的时候,vsftpd.chroot_list里面的用户这时就可以访问上级目录了
chroot_local_user=YES
chroot_list_enable=YES
chroot_list_file=/etc/vsftpd.chroot_list

编辑 vsftpd.chroot_list文件,将受限制的用户添加进去,每个用户名一行

5.允许上传

write_enable=YES

6.使用ftp 命令登陆的时候总是提示如下的错误

root@itlvgo:/ ftp 47.100.213.70
Connected to 47.100.213.70.
220 (vsFTPd 3.0.3)
Name (47.100.213.70:root): ftpuser
331 Please specify the password.
Password:
530 Login incorrect.
Login failed.

这是因为ubuntu启用了PAM,
所在用到vsftp时需要用到 /etc/pam.d/vsftpd
这个文件(默认源码安装的不会有这个文件

解决办法:

vim /etc/vsftpd.conf

修改

pam_service_name=vsftpd

pam_service_name=ftp

之后重启服务即可。

service vsftpd restart

错误总结:

错误一 500
500 OOPS: vsftpd: refusing to run with writable root inside chroot()

从vsftpd_2.3.5版开始,取消了根目录的可写权限,所以我们需要将用户对更目录的写权限拿下去

具体权限的基本操作请参考 :

chmod u-w /vaf/www

对站点根目录进行了取消可写操作

错误二 553
553 Could not create file

在创建目录或者创建文件的时候会提示不能够创建.这其实就是权限不够造成的.

在创建用户的时候,一定要用 ftp 用户去创建,不然的话就需要你手动把站点根目录的权限放开.

具体操作见本文配置 ftp 用户

按照本文一步一步弄下来的是不会出问题的.

这篇关于阿里云 ubuntu16.04 下 ftp 的快速应用(包罗疑难问题解决方案)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/535408

相关文章

PyTorch中的词嵌入层(nn.Embedding)详解与实战应用示例

《PyTorch中的词嵌入层(nn.Embedding)详解与实战应用示例》词嵌入解决NLP维度灾难,捕捉语义关系,PyTorch的nn.Embedding模块提供灵活实现,支持参数配置、预训练及变长... 目录一、词嵌入(Word Embedding)简介为什么需要词嵌入?二、PyTorch中的nn.Em

Spring Boot3.0新特性全面解析与应用实战

《SpringBoot3.0新特性全面解析与应用实战》SpringBoot3.0作为Spring生态系统的一个重要里程碑,带来了众多令人兴奋的新特性和改进,本文将深入解析SpringBoot3.0的... 目录核心变化概览Java版本要求提升迁移至Jakarta EE重要新特性详解1. Native Ima

WinForm跨线程访问UI及UI卡死的解决方案

《WinForm跨线程访问UI及UI卡死的解决方案》在WinForm开发过程中,跨线程访问UI控件和界面卡死是常见的技术难题,由于Windows窗体应用程序的UI控件默认只能在主线程(UI线程)上操作... 目录前言正文案例1:直接线程操作(无UI访问)案例2:BeginInvoke访问UI(错误用法)案例

Spring Security常见问题及解决方案

《SpringSecurity常见问题及解决方案》SpringSecurity是Spring生态的安全框架,提供认证、授权及攻击防护,支持JWT、OAuth2集成,适用于保护Spring应用,需配置... 目录Spring Security 简介Spring Security 核心概念1. ​Securit

MySQL逻辑删除与唯一索引冲突解决方案

《MySQL逻辑删除与唯一索引冲突解决方案》本文探讨MySQL逻辑删除与唯一索引冲突问题,提出四种解决方案:复合索引+时间戳、修改唯一字段、历史表、业务层校验,推荐方案1和方案3,适用于不同场景,感兴... 目录问题背景问题复现解决方案解决方案1.复合唯一索引 + 时间戳删除字段解决方案2:删除后修改唯一字

Redis中Stream详解及应用小结

《Redis中Stream详解及应用小结》RedisStreams是Redis5.0引入的新功能,提供了一种类似于传统消息队列的机制,但具有更高的灵活性和可扩展性,本文给大家介绍Redis中Strea... 目录1. Redis Stream 概述2. Redis Stream 的基本操作2.1. XADD

JSONArray在Java中的应用操作实例

《JSONArray在Java中的应用操作实例》JSONArray是org.json库用于处理JSON数组的类,可将Java对象(Map/List)转换为JSON格式,提供增删改查等操作,适用于前后端... 目录1. jsONArray定义与功能1.1 JSONArray概念阐释1.1.1 什么是JSONA

nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析(结合应用场景)

《nginx-t、nginx-sstop和nginx-sreload命令的详细解析(结合应用场景)》本文解析Nginx的-t、-sstop、-sreload命令,分别用于配置语法检... 以下是关于 nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析,结合实际应

PostgreSQL的扩展dict_int应用案例解析

《PostgreSQL的扩展dict_int应用案例解析》dict_int扩展为PostgreSQL提供了专业的整数文本处理能力,特别适合需要精确处理数字内容的搜索场景,本文给大家介绍PostgreS... 目录PostgreSQL的扩展dict_int一、扩展概述二、核心功能三、安装与启用四、字典配置方法

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os