How to add warning notification of ssh connection for server

Why we need ssh connection notification

It is very necessary to be noticed if someone loged into your server via ssh for safety considering.

How to deploy

Prometheus alert setup

First of all, you need to deploy prometheus alert program following the official instruction, so that you can get a webhook to use, which can reduce the risk of personal information leakage.

The next, you need to go to prometheus alert web page. Click custom template, choose an email setting.

Screenshot 2023-10-16 at 08.42.32

Server configuration

Install nali——An ip address lookup tool

1
2
3
4
5
cd /root
wget https://github.com/zu1k/nali/releases/download/v0.8.0/nali-linux-amd64-v0.8.0.gz
gunzip nali-linux-amd64-v0.8.0.gz
mv nali-linux-amd64-v0.8.0 nali
chmod +x nali

Setup ssh auto task

1
vim /etc/ssh/ssh_email.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#! /bin/bash
#-----------------------------------------------------#
# #
# Author: doublefire.chen #
# Original_author: xingdp #
# Date:2024-12-22 #
# Name:ssh_email.sh #
# Version: V2.0 #
# Description:SSH remote online mail reminder #
# #
#-----------------------------------------------------#
if [ -z "${SSH_CONNECTION}" ];then
echo '$SSH_CONNECTION:not exists'
exit 0
fi
cd ~
# 定义变量
user=`echo ${LOGNAME}`
# 某用户不需要提醒
if [ "${user}" == "git" ];then
exit 0
fi
from_ip=`echo ${SSH_CONNECTION} | awk '{print$1}'`
from_port=`echo ${SSH_CONNECTION} | awk '{print$2}'`
server_ip=`echo ${SSH_CONNECTION} | awk '{print$3}'`
from_regeion=`./nali ${from_ip} | awk '{ for (i = 2; i <= NF; i++) { output = output $i " " } print output }'`
hostname_1=`echo ${HOSTNAME} "(" $server_ip ")"`
server_time=`echo $(date +"%Y-%m-%d %R")`


# 某IP段不需要提醒
#ip_exit=`echo ${from_ip}|cut -d "." -f 1,2,3`
#if [ "${ip_exit}" == "192.168.1" ];then
#exit 1
#fi

# 发送邮件
#echo -e "
#*********** 服务器登录提醒 ***********\n
#
# 登录主机: ${hostname_1}\n
# 登录用户: ${user}\n
# 登录时间: ${server_time}\n
# 登录IP地址:${from_ip}\n
# 登录IP端口:${from_port}\n
# 登录IP区域:${from_regeion}\n
#
#**************************************"
# 使用curl将server_ip作为POST请求的JSON数据发送给服务器
JSON="{\"hostname_1\": \"${hostname_1}\",\"user\": \"${user}\",\"server_time\": \"${server_time}\",\"from_ip\": \"${from_ip}\",\"from_port\": \"${from_port}\",\"from_region\": \"${from_regeion}\"}"
curl -s -o /dev/null 'https://your_prometheus_alert_domain/prometheusalert?type=email&tpl=graylog2-email&email=your@email.com' \
--data-raw "${JSON}" \
--compressed

1
2
chmod +x /etc/ssh/ssh_email.sh
vim /etc/ssh/sshrc
1
bash /etc/ssh/ssh_email.sh

Reference