GNU/Linux >> Tutoriels Linux >  >> Linux

Attaque de script shell sur le serveur Apache, via un cron d'origine inconnue

Une fois que OP a ajouté des journaux, il est devenu clair que ce problème est lié à l'exploit d'exécution de code à distance pour Struts 2 (CVE-2017-5638).

Quelques liens supplémentaires :

  1. Nouvel exploit d'exécution de code à distance Struts2 pris dans la nature.
  2. CVE-2017-5638 - Apache Struts2 S2-045.

La solution consiste à mettre à niveau votre Struts vers la version 2.3.32 ou 2.5.10.1.


J'ai déjà rencontré des problèmes similaires lorsque j'étais administrateur système. Je pense que vous devez distinguer s'il s'agit de votre serveur Tomcat ou de votre application Java.

Lorsque vous démarrez Tomcat sans "l'application Java infectée", le cron est-il activé ? (Je veux dire, supprimer votre application de Tomcat et la démarrer) Si c'est le cas, vous avez un problème plus important, vous devrez vérifier les scripts de démarrage et chaque application déployée sur le serveur Tomcat.

Sinon, nous sommes sûrs que votre application est le problème.

Si tel est le cas, accédez à :

$CATALINA_BASE/webapps/your_app 

Vérifiez l'intégrité de votre application, y a-t-il des fichiers supplémentaires que vous ne reconnaissez pas ?

Allez maintenant dans le répertoire webapps de votre installation tomcat :

$CATALINA_BASE/webapps/

Dans ce répertoire, effectuez :

grep -R '91.230.47.40' *

Pour trouver l'éventuel fichier/ligne de code à l'origine de l'infection, il peut s'agir d'un fichier de votre application ou d'un nouveau.

Avez-vous votre code dans un système CSV ?

Créez le fichier war en dehors du serveur infecté à partir de votre dépôt CSV et faites :

md5sum your_app.war

Supprimez votre application du serveur Tomcat et redéployez-la, vérifiez que vous téléchargez la guerre correcte via md5, puis vérifiez si la crontab est invoquée.

Si vous fournissez des commentaires sur cette étape, je serai heureux de vous aider.


Nous devions juste combattre ce type d'attaque sur un serveur, il continuait à redémarrer en écrasant crontab pour notre utilisateur tomcat comme décrit ci-dessus. L'adresse IP était identique. Grep de l'intégralité du répertoire des applications Web pour l'adresse IP n'a pas révélé de coupable.

Dans notre cas, nous n'utilisons pas d'entretoises, mais nous avions les applications "host-manager" et "manager" dans les applications Web, et nous avions JMX activé/port ouvert. Le redémarrage sans ceux-ci semble avoir été résolu, donc mon intuition est que la vulnérabilité pourrait être dans l'un d'eux. Plus précisément, il y avait une vulnérabilité JMX corrigée dans 7.0.73 qui pourrait être notre coupable (https://tomcat.apache.org/security-7.html#Fixed_in_Apache_Tomcat_7.0.73).

Une autre précaution que nous prenons maintenant est de restreindre l'accès à wget et chmod à root uniquement (faites simplement chmod 770 sur ces binaires).


Linux
  1. Apache avec Tomcat, un guide d'installation et de configuration étape par étape

  2. Utilisation d'un script d'encapsulation Cron

  3. Ssh - Script Shell pour se connecter à un serveur Ssh ?

  4. Déterminer Shell dans le script pendant l'exécution ?

  5. Déterminer le chemin d'accès au script shell sourcé ?

Installer le serveur Apache Tomcat 9 sur Ubuntu 20.04

Comment lier Apache Tomcat à IPv4 dans CentOS/Redhat

Comment exécuter des commandes Shell via un serveur HTTP

Comment installer le serveur Apache Tomcat sur Ubuntu 22.04

Comment configurer Nginx comme équilibreur de charge pour Apache ou Tomcat pour HTTP/HTTPS

Serveur Apache/Linux, attaque DoS depuis sa propre IP