Monday, February 1, 2016

Install CentOS version 6.5

29/01/2016

  1. Install Centos v 6.5 and update base software
    Download CentOs version 6.5 จาก FTP:172.16.0.192 path to downloads:/wwwdata/repodata/iso/centos/6.5/i386 เลือก CentOS-6.5-i386-minimal.iso (ดูภาพด้านล่าง)


ติดต้้ง OS Centos version 6.5 ไว้บนเครื่องโน๊ตบุ๊กตัวเอง VirtualBox ใช้ไอพี 172.16.106.100 และทำการอัพเดตโปรแกรมพื้นฐานและ Service ต่าง ๆ ให้เป็นปัจจุบัน upgrade version 6.5 to 6.7
    #yum update
   

  1. Filter ssh
    คอนฟิก service ssh ซึ่งใช้สำหรับ Remote จากภายนอกเข้ามาควบคุมและจัดการคอนฟิกต่าง ๆ ให้มีความปลอดภัย ดังนี้
    2.1 add user sysadmin เพื่อใช้สำหรับ login ssh ปรับไม่ให้ใช้ root login


    2.2 แก้ไขค่าคอนฟิก ssh ดังนี้
#cp /etc/ssh/sshd_config /etc/ssh/sshd_config.bak     ---> Backup file config

แก้ไขไฟล์ sshd_config * ลบไฟล์เก่าทิ้งแล้วก็อปปี้ข้อมูลด้านล่างใส่เข้าไปได้เลย
#vi /etc/ssh/sshd_config

-------------------------------------------------------------------------
Port 55001
ListenAddress 0.0.0.0

Protocol 2

HostKey /etc/ssh/ssh_host_rsa_key
HostKey /etc/ssh/ssh_host_dsa_key
ServerKeyBits 1024

# Logging
SyslogFacility AUTH
LogLevel INFO

LoginGraceTime 600
PermitRootLogin no
MaxAuthTries 3
MaxSessions 5

RhostsRSAAuthentication no
IgnoreRhosts yes

PermitEmptyPasswords no
PasswordAuthentication yes
AllowUsers sysadmin

ChallengeResponseAuthentication no

GSSAPIAuthentication yes
GSSAPICleanupCredentials yes

UsePAM yes

AcceptEnv LANG LC_CTYPE LC_NUMERIC LC_TIME LC_COLLATE LC_MONETARY LC_MESSAGES
AcceptEnv LC_PAPER LC_NAME LC_ADDRESS LC_TELEPHONE LC_MEASUREMENT
AcceptEnv LC_IDENTIFICATION LC_ALL LANGUAGE
AcceptEnv XMODIFIERS

X11Forwarding yes
Subsystem       sftp    /usr/libexec/openssh/sftp-server
--------------------------------------------------------------------------------

[root@dmtest ~]# service sshd restart
Stopping sshd:                                             [  OK  ]
Starting sshd:                                             [  OK  ]
[root@dmtest ~]#]# netstat -pnat
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address               Foreign Address             State       PID/Program name   
tcp        0      0 0.0.0.0:55001               0.0.0.0:*                   LISTEN      1234/sshd         
tcp        0      0 127.0.0.1:25                0.0.0.0:*                   LISTEN      1077/master       
tcp        0      0 172.16.106.100:55001        172.16.106.219:51690        ESTABLISHED 1171/sshd         
tcp        0      0 ::1:25                      :::*                        LISTEN      1077/master


  1. Filter iptables
    ปรับ Firewall ภายในเพื่อให้เปิดเฉพาะ service ที่จำเป็นต้องให้บริการ เช่น service ssh สำหรับการรีโมทย์จากภายนอกเข้ามา ส่วน service อื่น ๆ ที่จะติดตั้งในอนาคต ค่อยมา Filter อีกทีนึง
    พิมพ์คำสั่งดังนี้

#cp /etc/sysconfig/iptables /root/iptables   -- Backup file itapbles ก่อนทำการแก้ไข

แล้วพิมพ์คำสั่งต่าง ๆ ดังนี้
#
iptables -F
iptables -P INPUT DROP
iptables -P FORWARD DROP
iptables -P OUTPUT ACCEPT
iptables -A INPUT -i lo -j ACCEPT
iptables -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
iptables -A INPUT -p tcp -m tcp --dport 55001 --syn -j ACCEPT
iptables -A INPUT -p tcp --dport 55001 -m state --state NEW -m recent --set
iptables -A INPUT -p tcp --dport 55001 -m state --state NEW -m recent --update --seconds 600 --hitcount 3 -j DROP
iptables -A INPUT -p icmp --icmp-type echo-request -j ACCEPT
#
**
# เพิ่มเติม ป้องกันการปิง DDos #
#echo 1 > /proc/sys/net/ipv4/tcp_syncookies
#
[root@mailtest ~]# iptables -N syn-flood
[root@mailtest ~]# iptables -A syn-flood -m limit --limit 100/second --limit-burst 150 -j RETURN
[root@mailtest ~]# iptables -A syn-flood -j LOG --log-prefix "SYN flood:"
[root@mailtest ~]# iptables -A syn-flood -j DROP
[root@mailtest ~]# iptables -L -v
#
Ref: techsuii
**
เสร็จแล้ว บันทึกค่าคอนฟิก
#
/sbin/service iptables save
#
รีสตาร์ท service iptable เพื่อปรับใช้งาน
#
service  iptables restart
#
เรียกดูผลการปรับค่าคอนฟิก
#
iptables -L -v
#
Chain INPUT (policy DROP 33 packets, 6154 bytes)
pkts bytes target     prot opt in     out     source               destination       
    8   560 ACCEPT     all  --  lo     any     anywhere             anywhere          
1036 96416 ACCEPT     all  --  any    any     anywhere             anywhere            state RELATED,ESTABLISHED
    1    60 ACCEPT     tcp  --  any    any     anywhere             anywhere            tcp dpt:55001 flags:FIN,SYN,RST,ACK/SYN
    0     0            tcp  --  any    any     anywhere             anywhere            tcp dpt:55001 state NEW recent: SET name: DEFAULT side: source
    0     0 DROP       tcp  --  any    any     anywhere             anywhere            tcp dpt:55001 state NEW recent: UPDATE seconds: 600 hit_count: 3 name: DEFAULT side: source
    0     0 ACCEPT     icmp --  any    any     anywhere             anywhere            icmp echo-request

Chain FORWARD (policy DROP 0 packets, 0 bytes)
pkts bytes target     prot opt in     out     source               destination       

Chain OUTPUT (policy ACCEPT 803 packets, 139K bytes)
pkts bytes target     prot opt in     out     source               destination       

Chain RH-Firewall-1-INPUT (0 references)
pkts bytes target     prot opt in     out     source               destination

No comments: