Opened 7 years ago

Closed 7 years ago

#1667 closed defect (fixed)

petascope and SELinux on CentOS

Reported by: Dimitar Misev Owned by: Bang Pham Huu
Priority: major Milestone: 9.7
Component: petascope Version: development
Keywords: Cc: Peter Baumann, bbell
Complexity: Medium

Description

Running petascope on CentOS 7 where SELinux is enabled (can be checked with sestatus) fails, as SELinux prevents java to communicate with rasdaman.

At http://rasdaman.org/wiki/FAQ#PetascopecannotconnecttorasdamaninCentos7 we give two possible solutions:

  1. disable SELinux completely
  2. allow the rasdaman ports 7001-7010 in SELinux

Option 2. doesn't work however, it can be tested by running the systemtest; there are audit errors like this:

SELinux is preventing /usr/lib/jvm/java-1.8.0-openjdk-1.8.0.151-5.b12.el7_4.x86_64/jre/bin/java from name_connect access on the tcp_socket port 7001.
SELinux is preventing /usr/lib/jvm/java-1.8.0-openjdk-1.8.0.151-5.b12.el7_4.x86_64/jre/bin/java from execute access on the file /tmp/rasdaman/gdal_java/2017.12.25.09.33.50/libosrjni.so.
SELinux is preventing /usr/lib/jvm/java-1.8.0-openjdk-1.8.0.151-5.b12.el7_4.x86_64/jre/bin/java from write access on the directory tomcat.

We need to find out how to allow these events in particular without completely disabling SELinux.

Change History (4)

comment:1 by Dimitar Misev, 7 years ago

Priority: criticalmajor

comment:2 by Vlad Merticariu, 7 years ago

Milestone: 9.5Future

comment:3 by Dimitar Misev, 7 years ago

Cc: bbell added
Milestone: Future9.7
Owner: changed from bphamhuu, vmerticariu to Bang Pham Huu
Status: newassigned

Perhaps have a look here, it has a section about JNI as well: https://noobient.com/post/165972214381/selinux-woes-with-tomcat-on-centos-74

comment:4 by Bang Pham Huu, 7 years ago

Resolution: fixed
Status: assignedclosed

This problem should regard to Administrator as SELinux restricts permission by default and not what Petascope can do anything. Below are 2 solutions to make Petascope work when SELinux is enabled (enforcing):

First, install this package:

yum install policycoreutils-python

Then, either:

  • disable SELinux for tomcat (from enforcing to permissive) by:
semanage permissive -a tomcat_t
  • or create a custom configurable rules for SELinux to allow tomcat can read JNI and connect to rasservers's ports.
    • Create a config file first (e.g: test2.te)
      module test2 1.0;
      
      require {
      	type tomcat_t;
      	type tomcat_var_lib_t;
      	type usr_t;
      	type tomcat_exec_t;
      	type unconfined_service_t;
      	type afs_pt_port_t;
      	type tomcat_tmp_t;
      	type tmpfs_t;
      	type afs3_callback_port_t;
      	class tcp_socket name_connect;
      	class file { append create execute read relabelfrom rename write };
      	class shm { associate getattr read unix_read unix_write write };
      }
      
      #============= tomcat_t ==============
      allow tomcat_t afs3_callback_port_t:tcp_socket name_connect;
      allow tomcat_t tmpfs_t:file { read write };
      allow tomcat_t tomcat_tmp_t:file { execute relabelfrom };
      allow tomcat_t tomcat_var_lib_t:file execute;
      allow tomcat_t unconfined_service_t:shm { associate getattr read unix_read unix_write write  };
      
      
    • Create a bash script to generate a binary package from this config file:
      deployse.sh 
      #!/bin/sh
      
      set -e
      
      MODULE=${1}
      
      # this will create a .mod file
      checkmodule -M -m -o ${MODULE}.mod ${MODULE}.te
      
      # this will create a compiled semodule
      semodule_package -m ${MODULE}.mod -o ${MODULE}.pp
      
      # this will install the module
      semodule -i ${MODULE}.pp
      
    • Load this rule module to SELinux
      ./deployse.sh test2
      

In both cases, restart Tomcat and check that Tomcat can start normally and import data, query data from rasservers.

Note: See TracTickets for help on using tickets.