Learn how to master Linux commands, the Security Response will be a good entry cz it involves many Linux commands related to user management, privilege control, and task monitoring which are useful when using Linux
Linux Reinforce
| 1 | $ chattr +a xxx --only appendable | 
Security Response
- PDCERF: Perparation, Detection, Containment, Eradication, Recovery, Follow-up
- Confirm attacking time, IP address, and the evil file (process or rootkit) last
check suspicious users
| 1 | # search privileged users | 
port and process
| 1 | # netstat used for port info | 
startup item and timed tasks
| 1 | $ more /etc/rc.local | 
log check
| 1 | # locate IP which brute force root password: | 
and as you can see, both /var/log/auth.log(replace the /vat/log/secure) and the command “journalctl -xa”, can be used to check logs
- add user log e.g.1 
 2
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16Jul 10 00:12:15 localhost useradd[2382]: new group: name=user, GID=1001 
 Jul 10 00:12:15 localhost useradd[2382]: new user: name=user, UID=1001, GID=1001, home=/home/user
 , shell=/bin/bash
 Jul 10 00:12:58 localhost passwd: pam_unix(passwd:chauthtok): password changed for user
 #grep "useradd" /var/log/auth.log
 ```
 - delete user log e.g.
 ```bash
 Jul 10 00:14:17 localhost userdel[2393]: delete user 'user'
 Jul 10 00:14:17 localhost userdel[2393]: removed group 'user' owned by 'user'
 Jul 10 00:14:17 localhost userdel[2393]: removed shadow group 'user' owned by 'user'
 # grep "userdel" /var/log/auth.log
 ```
 - su switch user log e.g.
 ```bash
 Jul 10 00:38:13 localhost su: pam_unix(su-l:session): session opened for user good by root(uid=0)
view hidden processes
| 1 | $ ps -ef | awk'{print $2}'|sort -n| uniq > tasklist1.txt | 
Commands Summary
Files Recovery
if an important file were deleted, while a process which opens this file is alive, this process can still be read or written through it’s file descriptor.
e.g.
- see /var/log/secure, only to find it was deleted  
- use “lsof” to see process that opens it  
- as we can see, pid is 1264, and fd (file descriptor) is 4. so we can find info in /proc/1264/fd/4  
- use I/O redirection to redirect it to file  
- see /var/log/secure, and now we recovered the deleted file  
Tools
The ext3grep is to recovery file deleted by rm - rf on ext3 disk.
First unmount that disk to stop writting, and then install ext3grep. You can find it in apt repo, or compile it on your own.
Installation:
| 1 | $ apt install e2fslibs-dev | 
Scan file name:
| 1 | $ ext3grep /dev/sdbx --dump-names | 
And recover all:
| 1 | $ ext3grep /dev/sdbx --restore-all | 
Or recover someone:
| 1 | $ ext3grep /dev/sdbx --restore-file var/lib/mysql/aqsh/tb_b_attench.MYD | 
Another tool is extundelete, you can install it through apt or get it on sourceforge.
Installation:
| 1 | $ wget http://nchc.dl.sourceforge.net/project/extundelete/extundelete/0.2.4/extundelete-0.2.4.tar.bz2 | 
The usage of it is similar to ext3grep, and it can recover by directory
| 1 | $ ./extundelete --restore-file var/lib/mysql/aqsh/tb_b_attench.MYD /dev/sdbx | 
Useful Scripts
Normal
get busybox to analysis
| 1 | $ cd /bin/ | 
show malicious processes
| 1 | $ perf top -s pid,comm,dso,symbol | 
delete ddos trojans or mining scripts, can be used directly(from a SRC event)
| 1 | ps auxf | grep -v grep | grep hwlh3wlh44lh | awk '{print $2}' | xargs kill -9 | 
Operations related:
find zombie process
| 1 | $ ps -ef | grep defunct | 
count
| 1 | # simply use the top to see things like ... | 
kill zombie process
| 1 | $ ps -e -o ppid,stat | grep Z | cut –d" " -f2 | xargs kill -9 | 
Tide sec team’s auto script( in Chinese)
It is an automatic script written in pithon2, and is useful in linux security response.
It gather system information and service log, then generate a log file to save results.
This script can be found Here
A miner cleaner
This was extracted from a mining trojan, to get rid of every competitors on the victim.
Get it Here to clear mainstream mining trojans.
Clean your ass finally
After the attack, you better get your ass cleaned to be untraceable.
We have a simple cleaner Here. Another better script is Here in Chinese, which could even fake log info.
Key Files
“Key” here means important
Use lsattr to see hidden attribution
- About hidden attributionUse1 
 2
 3
 4
 5
 6
 7
 8
 -a show all files and directories including .(current dir) and ..(parent dir)
 -d show dirs' names
 -l just list
 -R Recursive processing, which processes all files and subdirectories in the specified directory together.
 -v show versions of files and dirs
 -V show versionsgetfaclto see things about ACL (Access Control List)
- About ACL attribution1 
 2
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14-a, --access: only displays file access control lists 
 -d, --default: only displays the default access control list
 -c, --omit-header: not display comment headers
 -e, --all-effective: show all valid permissions
 -E, --no-effective: show invalid permissions
 -s, --skip-base: skip files with only base entries
 -R, --recursive: recursively display subdirs
 -L, --logical: logical traversal (follow the symbolic link)
 -P, --physical: physical traversal (does not follow symbolic links)
 -t, --tabular: Use tab-delimited output format
 -n, --numeric: show the user/group ID of the number
 -p, --absolute-names: not remove the '/' symbol before the path
 -v, --version: display version and exit
 -h, --help: display this help informationTools
- chkrootkit
 later…
- rkhunter
 later…
- clamav
 later…