服务器之家:专注于服务器技术及软件下载分享
分类导航

Linux|Centos|Ubuntu|系统进程|Fedora|注册表|Bios|Solaris|Windows7|Windows10|Windows11|windows server|

服务器之家 - 服务器系统 - Linux - selinux导致ftp上传失败 工作中的真实案例

selinux导致ftp上传失败 工作中的真实案例

2019-12-11 16:17Linux教程网 Linux

这是一台squid代理服务器(一台式机,安装的是redhat 5.4 64位操作系统),每天下午4点一台服务器通过ftp上传主机数据库巡检报告到这台代理PC机的一个用户家目录下的xunjian目录下,这台PC再通过发送邮件的方式将巡检报告发给组内成员

这是一台squid代理服务器(一台式机,安装的是redhat 5.4 64位操作系统),每天下午4点一台服务器通过ftp上传主机数据库巡检报告到这台代理PC机的一个用户家目录下的xunjian目录下,这台PC再通过发送邮件的方式将巡检报告发给组内成员,进行巡检 
此为背景,之前的selinux设置的为Permissive,不料同事中午睡觉的时候,脚这么一碰,将这台代理PC重启了,重启后,连续2天的巡检报告都没有通过邮件收到,赶紧解决吧 

1、手动的执行ftp上传动作,报如下错误:553 Could not create file. 

sshuser@station90.example.com:~/xunjian/0108> ftp 192.168.1.123 
Connected to 192.168.1.123. 
220 (vsFTPd 2.0.5) 
Name (192.168.1.123:oracle): oracle 
331 Please specify the password. 
Password: 
230 Login successful. 
Remote system type is UNIX. 
Using binary mode to transfer files. 
ftp>binary 
200 Switching to Binary mode. 
ftp> put xunjian_0108.zip 
local: xunjian_0108.zip remote: xunjian_0108.zip 
229 Entering Extended Passive Mode (|||10717|) 
553 Could not create file. 

2、代理PC的oracle家目录,肯定是有读写权限的,因为是代理PC重启导致的,突然想到selinux若开启的话,是不允许用户的家目录进行ftp的,需要将ftp_home_dir这个sebool打开,如下所示: 

[root@squid ~]# getenforce 
Enforcing 
[root@squid ~]# getsebool -a | grep ftp_home_dir 
ftp_home_dir --> off 
[root@squid ~]# setsebool ftp_home_dir on 

3、这时候去上传,就可以成功了,如下所示 

sshuser@station90.example.com:~/xunjian/0108> ftp 192.168.1.123 
Connected to 192.168.1.123. 
220 (vsFTPd 2.0.5) 
Name (192.168.1.123:oracle): oracle 
331 Please specify the password. 
Password: 
230 Login successful. 
Remote system type is UNIX. 
Using binary mode to transfer files. 
ftp> bi 
200 Switching to Binary mode. 
ftp> put xunjian_0108.zip 
local: xunjian_0108.zip remote: xunjian_0108.zip 
229 Entering Extended Passive Mode (|||19974|) 
150 Ok to send data. 
100% |***********************************************************************| 577 KB 2.31 MB/s 00:00 ETA 
226 File receive OK. 
591290 bytes sent in 00:00 (2.18 MB/s) 

4、另外一种方式,就是将selinux设置为Permissive 

[root@squid ~]# getenforce 
Enforcing 
[root@squid ~]# setenforce 0 
[root@squid ~]# getenforce 
Permissive 

5、同时在/etc/rc.local中添加这么一行,那么下次系统重启后,就不会发生这样的情况了 

[root@squid ~]# which setenforce 
/usr/sbin/setenforce 
[root@squid ~]# cat /etc/rc.local | tail -n 1 
/usr/sbin/setenforce 0 

好啦,这样就顺利解决问题了,希望对一些朋友有所帮助

延伸 · 阅读

精彩推荐
  • Linuxssh 登录很慢该如何解决

    ssh 登录很慢该如何解决

    这篇文章主要介绍了ssh 登录很慢该如何解决的相关资料,这里提供了两种方法,DNS反向解析及关闭ssh的gssapi认证的解决办法,需要的朋友可以参考下...

    linuxeye9922021-12-16
  • LinuxLinux系统下无法卸载挂载的目录怎么办?

    Linux系统下无法卸载挂载的目录怎么办?

    我们在日常运维中经常性会遇到需要进行磁盘的扩容、卸载、挂载等操作,但是有时候这个系统上跑的应用并没有停止或者有其他的运维同事在操作这个目...

    今日头条10302020-12-30
  • Linux在Linux系统中创建新的亚马逊AWS访问密钥的方法

    在Linux系统中创建新的亚马逊AWS访问密钥的方法

    如何在Linux系统中创建新的亚马逊AWS访问密钥?我在配置一个需要访问我的亚马逊AWS帐号的应用时被要求提供AWS访问密钥ID和秘密访问密钥,我怎样创建一个...

    Linux教程网6182019-10-30
  • Linux理解 Linux/Unix 登录脚本的技巧

    理解 Linux/Unix 登录脚本的技巧

    有一些常见的情况,例如从Debian的包管理程序到Iaas的管理中,很多任务需要设置环境变量才能正常运行。 有时,程序通常只需要在 登陆时运行一次,例如...

    未知1042023-05-12
  • Linuxlinux驱动程序开发详细介绍

    linux驱动程序开发详细介绍

    前提,一般来说内核代码的错误可能会引起一个用户进程的死亡,或者整个系统的瘫痪,更严重的后果,可能导致磁盘损伤~因此建议最好有一台实验机进行...

    Linux教程网5392019-12-17
  • Linuxlinux设置tomcat自启动的方法

    linux设置tomcat自启动的方法

    这篇文章主要介绍了linux设置tomcat自启动的方法,需要的朋友可以参考下...

    Linux教程网8512021-10-10
  • Linux将 Linux 终端与 Nautilus 文件管理器结合起来

    将 Linux 终端与 Nautilus 文件管理器结合起来

    Nautilus 是 GNOME 桌面环境中的图形化文件浏览器。你可以使用它来访问和管理系统中的文件和文件夹。 尽管并非所有人都喜欢使用终端来管理文件和目录,...

    未知812023-08-08
  • Linuxlinux top命令详解

    linux top命令详解

    这篇文章主要介绍了linux top命令详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    sparkdev5622022-03-01